# int<sub>e</sub>

### **THE l**2**ICE™ INTEGRATED INSTRUMENTATION AND IN-CIRCUIT EMULATION SYSTEM USER'S GUIDE**

### THE PICE™ **INTEGRATED INSTRUMENTATION AND IN-CIRCUIT EMULATION SYSTEM USER'S GUIDE**

Order Number: 166298-001

Copyright 1985, Intel Corporation, All Rights Reserved Intel Corporation, 3065 Bowers Avenue, Santa Clara, California 95051



This equipment generates, uses, and can radiate radio frequency energy and if not installed and used in accordance with the instruction manual, may cause interference to radio communications. As temporarily permitted by regulation, it has not been tested for compliance with the limits for Class A Computing Devices pursuant to Subpart J of Part 15 of FCC rules, which arc designed to provide reasonable protection against such interference. Operation of this equipment in a residential area is likely to cause interference in which case the user, at his own expense, will be required to take whatever measures may be required to correct the interference.

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

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

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

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

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

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

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

Intel Corporation makes no warranty for the use of its products and assumes no responsibility for any errors which may appear in this document nor does it make a commitment to update the information contained herein.

Intel retains the right to make changes to these specifications at any time, without notice.

Contact your local sales office to obtain the latest specifications before placing your order.

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



MDS is an ordering code only and is not used as a product name or trademark. MDS® is a registered trademark of Mohawk Data Sciences Corporation.

" MULTIBUS is a patented Intel bus.

Copyright 1985, Intel Corporation. All Rights Reserved

### **CONTENTS**

#### **umummmm** int<sub>e</sub>l' www

#### Page



#### CHAPTER 1 PICE™ SYSTEM OVERVIEW





#### CHAPTER 3 INTRODUCTION TO USING THE PICE™ SYSTEM



#### Page



### CHAPTER 4 THE PICE™ SYSTEM PERSONALITY MODULES (PROBES)







#### **CHAPTER 5 COPROCESSOR SUPPORT**



#### **CHAPTER 6 MULTIPLE-PROBE SYSTEMS**



#### APPENDIX A PICE™ SYSTEM NON-HOST HARDWARE INSTALLATION



#### APPENDIX B CONFIGURING THE IPICE™ SYSTEM FOR NON-STANDARD **HOST TERMINALS**



#### **Glossary**

#### **Index**

#### **TABLES\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_**



#### **FIGURES\_\_\_\_\_\_\_\_\_\_\_\_\_ ;\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_**



#### **FIGURES (continued)\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ Page**



### **PREFACE**

**■ ■ ■ ■ ■ in te rs**

This manual introduces Intel's Integrated Instrumentation and In-Circuit Emulation (PICE™) system. It assumes that you are familiar with the architecture of the iAPX 86, iAPX 88, iAPX 186, iAPX 188, and iAPX 286 microprocessors. It also assumes that you are familiar with the concept of in-circuit emulation.

- Chapter 1 describes the hardware/software design process and explains how the PICE system aids this design process. Chapter 1 also provides general information about the features and components of the PICE system, describes the hardware components of the PICE system, and describes the PICE system software packages.
- Chapter 2 provides an overview of the PICE system on-line tutorial and contains a listing of the program debugged during the tutorial session.
- Chapter 3 introduces the user to the PICE system. This chapter reinforces and augments information provided in the on-line tutorial. It explains symbolic debugging, PICE debug procedures, file handling, the PICE editor, and the single-line assembler. The chapter also contains a sample program that illustrates how to get the PICE system up and running; it describes how to set up and work with the PICE memory and I/O maps; and it describes how to set breakpoints and interpret the trace buffer.
- Chapter 4 is an overview of how the PICE system operates with the 8086/8088, 80186/80188, and 80286 personality modules (probes). This chapter also describes special considerations that pertain to each of the probes.
- Chapter 5 describes the special debugging aids offered by the PICE system for prototypes that use coprocessors and processor extensions.
- Chapter 6 describes the operation of PICE systems with more than one probe.
- Appendix A explains how to install  $PICE$  system hardware, except hardware that is installed on the host system.
- Appendix B shows how to configure the  $P<sup>1</sup>ICE$  system to run with non-standard terminals.
- Host Installation Appendixes explain how to install the PICE system hardware in the host system and how to install the PICE system software.
- Glossary defines specific PICE system terms used in this manual.

Index

#### **Related Publications**

The following manuals contain additional information about the PICE system and its operating environment.

Copies of the publications listed are available through the Intel Literature Department.

#### **I**2**ICE™ System Publications Library**

The following manuals are supplied (together with this manual) with the PICE system; they contain additional information about the PICE system and its operating environment. Copies of the publications listed are also available through the Intel Literature Department, located at the following address:

Literature Department Intel Corporation 3065 Bowers Avenue Santa Clara, CA 95051 (800) 548-4725

• *PICE™ Integrated Instrumentation and In-Circuit Emulation System* (data sheet), order number 210469.

This publication provides an overview of the PICE system. It describes the hardware and software, provides some general application information, and lists the system specifications. The data sheet is available through Intel sales offices as well as the Intel Literature Department.

• *PICE™ Reference Manual*, order number 166302. This manual is the principle reference for the PICE command language. It includes descriptions of PICE commands and PICE topics that are not probe-specific.

- *PSCOPE-86 High-Level Program Debugger User's Guide*, order number 121790 [This manual is only supplied to users with Intel hosts.] The manual describes the operation of PSCOPE-86, a high-level language symbolic debugger. It includes a tutorial and invocation sections, a command dictionary, an error message listing, and configuration information for non-Intel terminals.
- *AEDIT Text Editor User's Guide*, order number 121756 This manual describes features and operation of the screen editor that is part of the PICE system software.

#### **Reference Publications**

The publications in the following sections are not supplied with the PICE system.

#### **Hardware Reference Publications**

- *Memory Components Handbook*, order number 210830. This catalog contains data sheets on the memory components manufactured by Intel Corporation.
- *Microsystems Components Handbook*, order number 230843 (two volumes). These handbooks contain data sheets on the microprocessor and peripheral products manufactured by Intel Corporation.
- *OEM Systems Handbook*, order number 210941. This catalog contains data sheets on integrated microcomputer systems, single-board computers, memory expansion boards, high-speed math boards (including the iSBC® 337 MULTIMODULE™ board), peripheral controllers, communications controllers, digital I/O expansion and signal conditioning boards, industrial control series, and analog I/O expansion. It also contains data sheets on systems software, such as the  $iRMX^{\tau_M}$  operating system.
- *Development Systems Handbook*, order number 210940. This catalog contains data sheets on microcomputer development systems (hardware and software), in-circuit emulators (including the  $PICE$  system), network development systems, system design kits, and third-party software.
- *iAPX 86/88, 186/188 User's Manual*, order number 210911. This manual contains product descriptions and operating instructions for 8-bit and 16-bit CPUs and support chips in the iAPX 86/88 and 80186/80188 families.
- *iAPX 186 High Integration 16-Bit Microprocessor* (data sheet), order number 210451. This publication provides an overview of the iAPX 186 microprocessor. It includes chip pinouts, a functional description, hardware, software, and timing specifications, and an instruction set summary.
- iAPX 286/10 High Performance Microprocessor with Memory Management and Protec*tion* (data sheet), order number 210253. This publication provides an overview of the iAPX 286/10 microprocessor. It includes chip pinouts, a functional description, chip architecture, hardware and timing specifications, and an instruction set summary.
- *iAPX 286 Hardware Reference Manual*, order number 210760. This manual is the hardware reference guide for iAPX 286 system designs.
- *iSBC® 337 MULTIMODULE™ Numeric Data Processor Hardware Reference Manual*, order number 142887.

This manual contains design and operation information on the iSBC 337 NDP MULTI-MODULE board. The manual includes installation, program interface, operation, and service information.

#### **Software Reference Publications**

• *ASM-86 Language Reference Manual*, order number 121703. This manual provides design and operating information about the ASM-86 assembly language. The manual provides an overview of the language, procedures for program structuring, information about data operation, and an appendix describing the 80186 instruction set.

- *iAPX 86/88 Family Utilities User's Guide*, order number 121616. This guide provides a full description of the utility commands that support 86/88 program development. It is intended for use with any language translator that generates object code compatible with the utility commands.
- *8087 Support Library Reference Manual*, order number 121725. This manual provides design and operating information about the library of support utilities for the 8087 processor. It provides overviews of the support library, procedures for program structuring, and information on data operation.
- *iAPX 286 Programmer's Reference Manual*, order number 210498. This manual describes the iAPX 286 architecture and instruction set.
- *iAPX 286 Utilities User's Guide*, order number 121934. This guide provides a full description of the utility commands that support 286 program development. It is intended for use with any language translator that generates object code compatible with the utility commands.
- *iAPX286 Operating Systems Writer's Guide,* order number 121960. This book is written for systems designers, operating system designers, and programmers using the Intel iAPX 286 microprocessor in its protected, virtual-address mode.
- *PL/M-86 Programming Manual,* order number 980466. This manual provides programming instructions for PL/M-86. It includes details on expressions and assignments, procedures, variables, and a sample program.
- *PL/M-86 User's Guide,* order number 121636.
- *PL/M-286 User's Guide,* order number 121945.
- *Pascal-86 User's Guide,* order number 121539.
- *FORTRAN-86 User's Guide,* order number 121570.
- *iC-86 Compiler User's Guide,* order number 122085. These guides provide introductory and overview information on the high-level languages supported by the I<sup>2</sup>ICE system. Each manual provides installation instructions, language information, compiler operating instructions, and information on interfacing to other software modules.

#### **Command Syntax**

The following syntax notation is used throughout the PICE manual set:

COMMANDS Command keywords appear in all uppercase letters. You must enter commands exactly as they appear, except that you may enter them in either uppercase or lowercase letters.





## **SERVICE INFORMATION**

**intal\* <del>- " "</del>"** 

The best possible service for your Intel product is provided by Intel Customer Engineers. These trained professionals provide prompt, efficient, on-site installation, preventive maintenance, and corrective maintenance services required to keep your equipment in the best possible operating condition.

Intel Customer Engineers provides the service needed through a prepaid service contract or on an hourly charge basis. For further information, contact your local Intel sales office.

In Phoenix, Arizona, there is a technical information center that will connect you with the software support group for your particular Intel product.

Telephone (602) 869-INFO (4636)

When an Intel Customer Engineer is not available, contact the Intel Product Service Center.

United States customers can obtain service and repair assistance from Intel Corporation by contacting the Intel Product Service Center in their local area. Customers outside the United States should contact their sales source (Intel Sales Office or Authorized Distributor) for service information and repair assistance.

Before calling the Product Service Center, have the following information available:

- 1. The date you received the product.
- 2. The complete part number of the product (including dash number). On boards, this number is usually silk-screened onto the board. On other MCSD products, it is usually stamped on a label.
- 3. The serial number of the product. On boards, this number is usually stamped on the board. On other MCSD products, the serial number is usually stamped on a label mounted on the outside of the chassis.
- 4. The shipping and billing address.
- 5. If the Intel Product warranty has expired, a purchase order number is needed for billing purposes.
- 6. Be sure to advise the Center personnel of any extended warranty agreements that apply.

Use the following telephone numbers for contacting the Intel Product Service Center:



Always contact the Product Service Center before returning a product to Intel for repair. You are given a repair authorization number, shipping instructions, and other important

information which helps Intel provide you with fast, efficient service. If you are returning the product because of damage sustained during shipment, or if the product is out of warranty, a purchase order is required before Intel can initiate the repair.

If available, use the original factory packaging material when preparing a product for shipment to the Intel Product Service Center. If the original packaging material is not available, wrap the product in a cushioning material such as Air Cap SD-240, manufactured by the Sealed Air Corporation, Hawthorne, N.J. Securely enclose it in a heavy-duty corrugated shipping carton, mark it "FRAGILE" to ensure careful handling, and ship it to the address specified by the Intel Product Service Center.

## **1 PICE™ SYSTEM OVERVIEW**

**intai B B B** 

Intel's Integrated Instrumentation and In-Circuit Emulation (PICE™) system offers real-time hardware and software emulation for designs using the iAPX 86, iAPX 88, iAPX 186, iAPX 188, and iAPX 286 microprocessor systems.

This chapter is an overview of the PICE system and its operating environment. It contains the following sections.

- The Microcomputer Development Process—this section reviews the role of an emulator in the microcomputer development process.
- An Introduction to the PICE™ System—this section describes the PICE system configuration, options, and accessories.
- Hardware Overview
- Software Overview
- The I<sup>2</sup>ICE™ System Command Language
- PICE™ System Specifications

#### **The Microcomputer Development Process**

Designing a product that contains a microcomputer requires close coordination of two separate but highly dependent design efforts: hardware development and software development. These two development efforts can be accomplished independently, but it is more efficient to work on them together. Figure 1-1 illustrates a typical microcomputer development process, using a development system and an emulator.

#### **Features of a Host Development System with an Emulator**

A host development system with an emulator offers the following resources:

- A stand-alone computer
- Development software such as assemblers and compilers
- Prototype hardware interface
- Mapping capability
- Break and trace capability



#### **Generalized Hardware Design Steps**

Although the complexity of hardware design varies from one design to another, the general process is the same. The following sequence illustrates the advantage of using a development system with an emulator.

- Organize the hardware into logical blocks with well-defined inputs and outputs. Determine the CPU, RAM, ROM, I/O, board layout, and bus interface requirements.
- Build a hardware prototype.
- Test the interaction of the prototype hardware with proven software. The user program resides initially in either the host development system's memory or the emulator's memory. You can reassign the user program, memory block by memory block, to prototype memory as you verify the code and as prototype memory becomes available.
- Test, debug, and verify each prototype module.

#### **Generalized Software Design Steps**

Software design follows a process similar to hardware design as illustrated in the following sequence.

• Organize the software into logical blocks with well-defined inputs and outputs. Complete the specifications for the software control logic and integrated system performance.

- Program the software modules. Desk-check each module as it is completed. Name and store the software modules as files in the development system's memory. Assemble or compile the modules. Link and load the combinations that are ready to be tested.
- Emulate the program using an emulator to debug the software.

#### **Hardware/Software Integration**

When the hardware and software designs are complete, system integration is already in progress. The usefulness of a development system with an emulator extends into the integration and test phases.

When an emulator is connected to the prototype system through the microprocessor socket and emulator hardware probes, the emulator can emulate, test, and trace prototype system operation.

After testing the prototype, the host development system with an emulator can be used to verify the product in production test. Test procedures developed for final prototype testing can serve as the basis for production test routines. The same procedures developed for hardware debugging and production test can also be used to troubleshoot and repair failing products at a repair center.

#### **An Introduction to the l**2**ICE™ System**

Intel developed the PICE system to address the requirements of designers who use Intel's iAPX microprocessors. The PICE system is a second-generation design tool that provides the following advantages:

- Full-speed, multiple microprocessor emulation
- Real-time emulation support for each of the iAPX microprocessors (86/88, 186/188, and 286)
- Software patching without recompiling or reassembling
- **Extensive breakpoint capabilities**
- Expanded logic analysis

The PICE system also offers the following features:

- Access to eight signals input from the prototype system and two signals output to the prototype system using the emulation clips. An additional output line is asserted when the PICE system breaks emulation, and another is asserted when the PICE system triggers a trace.
- An optional Intel Logic Timing Analyzer (iLTA) module which is a general-purpose, integrated, 16-channel, 100-MHz logic timing analyzer. With the mass storage provided by the host development system, you can store an unlimited number of scope displays for later analysis. Combined with the capabilities of the PICE system, the iLTA extends the range of development applications. [This option is not available for IBM PC hosts.]
- An optional high-speed (OHS) memory board. The PICE system provides up to 256K bytes of additional programmable wait-state RAM for each emulator. With the PICE system, you can specify zero wait-states for real-time emulation and simulate slow memories by inserting up to 15 wait states.
- Program memory mapping to high-speed (HS) memory (up to 32K-bytes) on the system map-I/O board, to OHS memory, or to host development system memory. [There is no mapping to IBM PC/AT or PC/XT host memory.]
- Multiprocessor debugging. The PICE system can control up to four emulators simultaneously.
- Coprocessor support, which provides debugging support for the 8087 numeric coprocessor and the 80287 numeric processor extension.
- Emulation flexibility. The iAPX 86/88 and 186/188 emulation personality modules (also called probes) each emulates two separate microprocessors. To change microprocessors, you need only change the personality module CPU chip and jumpers on the buffer and personality boards.

#### **NOTE**

Probe CPU chips must be provided by Intel. All probes use either bond-out chips or specially tested microprocessors.

- Symbolic debugging support for programs written in assembly language, PL/M, C, Pascal, and FORTRAN by both PSCOPE-86 and the PICE system command language. With the symbolic debugging capabilities you can access variables and memory locations with user-defined names.
- Two programmable event machines that allow break and trace on simple and complex event sequences.
- A real-time trace buffer that displays trace information in either a disassembled-instruction format or a microprocessor bus-cycle format.

#### **The Base Configuration of the PICE™ System**

Figure 1-2 shows a basic single-chassis PICE system. The base configuration is readily expandable to include a number of PICE system options.

The base configuration of the PICE system contains the following hardware:

- The host interface board, which resides in the host development system and handles communication between the host development system and the PICE instrumentation chassis.
- The FICE instrumentation chassis, which contains the communications board and provides slots for up to four PICE system boards. The communications board connects to the host interface board. The chassis slots also hold the map-I/O board and the break/trace board. •
- The map-I/O board, which contains high-speed RAM and the memory map. There are 32K bytes of high-speed RAM available to user programs through the memory map. The



**Figure 1-2 A Basic PICE™ System**

rest of the on-board RAM contains PICE system software that implements probe-specific commands.

- The break/trace board, which contains two programmable event machines that implement the break and trace specifications.
- The emulation clips assembly, which enables the PICE system to assert signals to the prototype hardware and to read signals from the prototype hardware.
- The probe buffer box, which contains the buffer board and the personality board. The buffer board connects to the break/trace board and the map-I/O board in the instrumentation chassis. The personality board connects to the prototype hardware through the user cable.
- System cables, which connect the instrumentation chassis to the host development system and to the probe buffer box. The host/instrumentation-chassis cable is either 10 or 40 feet long.

The base configuration of the I<sup>2</sup>ICE system contains the following software.

- The PICE system host software, which implements the non-probe-specific PICE system commands. After the PICE system software is loaded, it resides in the host development system.
- The PICE system probe (personality module) software, which implements the probespecific PICE system commands. After the probe software is loaded, it resides in the map-I/O board.
- The PICE system diagnostic software.
- The PSCOPE-86 high-level language software debugger which runs in the host development system and does not emulate in real-time. It is loaded in place of the PICE system host software. [PSCOPE-86 is an option for the IBM PC hosts.]
- The PICE system tutorial software.

#### **I**2**ICE™ System Options**

The PICE system is expandable. An PICE system can have up to four instrumentation chassis. Each chassis can emulate any of the five microprocessors. Each chassis provides up to 256K bytes of additional zero wait-state memory to user programs, and serves as a logic timing analyzer while retaining the basic PICE system functions.

Figure 1-3 shows the maximum configuration of an PICE system.

The PICE system options are as follows.

- The optional high-speed (OHS) memory board. This option increases the amount of PICE system memory available to user programs through the memory map. Each board adds 128K bytes of zero wait-state memory.
- The iLTA has all the features found in a stand-alone logic analyzer. In addition, the iLTA uses the mass storage and real-time breakpoint facilities of the PICE system. The iLTA monitors 16 channels at a maximum frequency of 100 MHz. [The iLTA system is not available for use with the IBM PC hosts.]

The iLTA hardware consists of one board, two probe pods, and test and hook-up accessories. Each instrumentation chassis can contain only one iLTA module, and the iLTA board must reside in the top slot.

The PICE system enables real-time emulation and debugging of up to four instrumentation chassis from a single host development system. A unit is composed of an instrumentation chassis, a probe buffer box, and an emulation clips pod. Each unit can emulate one of the five iAPX microprocessors. Optional high-speed memory residing in one chassis cannot be mapped into the emulation environment of another chassis.



**Figure 1-3 A Maximum Configuration PICE™ System**

#### **PICE™ System Accessories**

The PICE system accessories are as follows.

- An emulation clips assembly that consists of an emulation clips pod, an emulation clips cable, and an emulation clips terminator.
- Two logic probe pods (channels 0-7 and 8-F) that supplement the iLTA pods. Each pod can be ordered separately.
- Two iLTA terminator sets that supplement the terminator sets normally supplied with the iLTA. A 16-channel terminator set is used to hook-up to 16 separate signals. An 8-channel

terminator set is used for glitch detection and multi-threshold triggering. Each terminator set can be ordered separately.

• A microhook set that consists of 40 grabber clips (microhooks) that connect to wires belonging to the emulation clips terminator or to the iLTA terminators. The microhooks connect to individual leads of a dual in-line package (DIP). This set supplements the microhooks supplied with the emulation clips pod and the iLTA.

#### **Hardware Overview**

The hardware components of the PICE system are listed in Table 1-1 and discussed in the following sections.

#### **The Instrumentation Chassis**

The instrumentation chassis encloses a card cage and a backplane with four vacant slots, a switching power supply, and a communications board. As many as four chassis may be daisychained together in a fully-configured PICE system to allow multiprocessor emulation under the control of a single host development system.

Both the top and front covers of the instrumentation chassis are easily removed to allow access to system components. The four-slot card cage holds 12 in. by 12 in. (.30 m by .30 m) boards. Three fans on the side of the card cage provide cooling.

The internal switching power supply uses line power (110 or 220 VAC) to develop the regulated DC voltages used by the PICE system. (The host interface board obtains power from the host development system.) The power supply has five voltages: + 5VDC (two voltages),  $-5.2\overline{V}$ DC,  $+15\overline{V}$ DC, and  $-15\overline{V}$ DC.

The communications board is part of the rear panel of the instrumentation chassis. The board contains termination switches, rear panel connectors, and interface circuitry. The communications board handles communications with the host development system (using the host interface board). The communications board also provides the link between the PICE chassis in which it resides and other PICE chassis in the system. In multiple-chassis PICE systems, the communications board assigns sequential unit numbers (0 through 3) to each chassis.

#### **The Host Interface Board**

Each PICE system requires one host interface board. It resides in the host development system and controls up to four instrumentation chassis. For Intel hosts, the host interface board is a MULTIBUS® master board that makes possible direct memory access (DMA) to MULTIBUS board memory by the PICE system; for multiple-probe systems, the probes can share common MULTIBUS memory. IBM PC/AT and PC/XT hosts are provided with a PC-specific interface board that does not support MULTIBUS mapping.

#### **Table 1-1 PICE™ System Hardware Components**



#### **The Emulation Base Module**

The emulation base module provides a generic environment that an emulation personality module tailors to the microprocessor being emulated. Each instrumentation chassis contains one emulation base module. A fully-expanded MCE system contains four instrumentation chassis and four emulation base modules, each with an emulation personality module. The emulation base module consists of the following hardware:

- A map-I/O map board
- A brcak/trace board
- A buffer base assembly
- An emulation clips assembly

The map-I/O board contains the PICE memory map and memory. The PICE memory consists of 32K bytes of user-accessible, zero wait-state RAM. The PICE system uses 128K bytes of RAM to store the code for probe-specific commands. The memory map redirects an emulated microprocessor's memory and I/O port address space to combinations of memory and I/O belonging to the host development system, the prototype, and the PICE system.

The break/trace board uses two programmable event machines (one execution event machine and one system event machine) to trigger break and trace points. The event machines recognize complex, multilevel trigger event sequences. The break/trace board also contains a 1023 by 48-bit trace data buffer.

The buffer base assembly provides buffers, latches, multiplexers, and a wait-state generator for the emulation base module. The buffer base assembly is incomplete without the appropriate emulation personality module (probe). The buffer base assembly consists of the following hardware:

- The probe buffer box base
- The probe buffer box cable
- The emulation buffer board

The emulation buffer board resides in the probe buffer box base. The emulation buffer board contains the wait-state generator and the fan control circuit for the buffer box. With the waitstate generator you can simulate slow memories by inserting up to 15 wait-states into memory accesses. The probe buffer box cable connects the emulation buffer board to the break/trace board and the map-I/O board in the instrumentation chassis.

The emulation clips assembly consists of the following hardware:

- The emulation clips cable
- The emulation clips pod
- The emulation clips terminator
- The emulation clips microhooks

The emulation clips cable assembly attaches to the break/trace board in the instrumentation chassis. This assembly enables the monitoring of eight TTL-compatible input signals and the generation of two TTL-compatible output signals during emulation. The emulation clips assembly also provides system break and system trace outputs that aid multi-microprocessor debugging by enabling the PICE system to communicate with other PICE systems.

#### **System Interface Cables**

A single host/chassis interface cable connects the PICE system to the host interface board. Each additional instrumentation chassis in the PICE system is linked to the previous instrumentation chassis with two inter-chassis interface cables (an inter-chassis communication cable and an inter-chassis break cable). All chassis-to-chassis connection, termination, and chassis addressing is performed on the communications board of each instrumentation chassis.

#### **High-Speed Memory**

The high-speed (HS) memory consists of 32K bytes of programmable wait-state memory and resides on the map-I/O board.

#### **Optional High-Speed Memory Board**

The optional high-speed (OHS) memory board supplements the 32K bytes of high-speed PICE memory. The OHS memory module is a 12 in. by 12 in. (.30 m by .30 m) board with static RAM memory components. Each OHS memory board contains 128K bytes of zero wait-state memory. Each PICE system can contain two OHS memory boards for a total of 256K bytes of OHS memory.

#### **The Intel Logic Timing Analyzer (iLTA)**

The iLTA is a test and measurement module which combines all the features of a stand-alone logic analyzer with the event machines and storage capabilities of the PICE system. The iLTA consists of the logic probe assembly, the external trigger wires, the iLTA demonstration card assembly, and the logic probe assembly. [The iLTA system is not available for IBM PC hosts.]

#### **Emulation Personality Modules**

An emulation personality module (also called an emulation probe) configures the PICE emulation base module to support a specific microprocessor. Each emulation personality module consists of the following hardware:

- The personality board
- The probe buffer box cover
- The user cable with probe
- The selected CPU chip

In addition to supporting real-time emulation and debugging for the specified microprocessor, the emulation personality modules also provide debugging support for coprocessors. For example, the PICE system 8086/8088 and 80186/80188 emulation personality modules provide debugging support for the 8087 coprocessor. The 80286 emulation personality module provides debugging support for the 80287 numeric processor extension.

#### **Software Overview**

The PICE system software is a versatile and powerful debugging language. The usefulness of an PICE system extends throughout the development cycle, beginning with the symbolic debugging of prototype software and ending with the final integration of debugged software and prototype hardware (see Figure 1-4). Typical PICE system functions include setting breakpoints, controlling trace collection, writing debug procedures, and changing program variables. The PICE system software consists of the following:

- The PICE system host software, which resides in the host development system. It implements the PICE commands that are not probe-specific.
- The PICE system probe software, which resides on the map-I/O board in the PICE instrumentation chassis. It implements the probe-specific commands.
- PSCOPE-86, which is a high-level language symbolic debugger, designed for use with Pascal-86, PL/M-86, and FORTRAN-86. It is a separate product included with the PICE system. It runs in the host development system. [PSCOPE-86 is an option for IBM PC hosts.]
- The PICE system diagnostic software, which checks the PICE system and supplies information about a failing system.
- The optional iLTA software which is integrated with the PICE system software [not available for IBM PC hosts]. The iLTA software controls the iLTA, interprets the data collected and displayed by the iLTA, and runs the PICE system software.
- The PICE tutorial software, which introduces the PICE command language and leads users through several on-line debugging sessions.

#### **Software Environment**

The PICE system software requires that the host operating system provide certain service routines. For example, the PICE system file handling commands assume a system service routine that provides access to the disk drives. The host operating system must run in the 8086 environment.

The software also requires formatted media in the work device. The software creates a workfile in the work device that contains the user program symbol table. This table is treated as a virtual symbol table; that is, the entire symbol table need not reside in memory at the same time. This has different implications depending on what host development system you are using.



**Figure 1-4 The PICE™ System Debugging Capabilities**

#### **• Model 800 and Intellec® Series III development systems**

For the ISIS operating system the default work device is :F1:. The RUN program stores the name of the current work device. You can display the name of the default work device by entering RUN WORK. You can change the default work device by entering the following command:

#### **RUN WORK** *d&vice~mme*

For example, RUN WORK :F2: changes the default work device to drive 2. If you reset the system, the default work device is still drive 2.

When the Model 800 or the Series III development system is on an NDS-II, you must assign :F9: to your work device.

#### **• Intellec Series IV development system**

For the iNDX operating system, the work device must be defined. For example, assume that you specify a hard disk named WDO for the work device and the directory WORKDIR to contain the work file. The command is

#### **LNAME DEFINE :W0RK: FOR /WDO/WORKDIR**

#### **• IBM PC/XT and PC/AT hosts**

For the DOS operating system, the default work device is the current default drive. To change the work device, use the following SET command:

#### **SET** *:* **WORK: \*** *pathname*

#### **The l2ICE™ System Command Language**

The PICE system command language consists of commands, pseudo-variables, and functions.

The PICE system commands fall into the following categories:

- Utility commands—these general-purpose commands simplify the debugging process. For example, use the EVAL command to calculate the nearest source-code line number that corresponds to the address of an assembly language instruction. Another utility command is the HELP command which provides on-line help information.
- Environment commands—these commands set up the debugging environment. For example, use the MAP command to set up a memory map which specifies that the user program memory references access memory locations in high-speed PICE memory.
- Debug object manipulation commands—debug objects are debug procedures, debug variables, debug registers, and LITERALLY definitions. You can create, modify, and remove debug objects. Debug objects save keystrokes during a debugging session.
- Emulation commands—you can command the PICE system to begin emulation and break or trace under certain specified conditions. You can specify these break and trace conditions within a debug register or within the emulation command itself.
- File handling commands—with these commands you can access disk files. For example, the LOAD command loads a user program. The LIST command sets up a list file and records what appears on the development system console. You can also save debug object definitions in a disk file and load them in later debugging sessions.
- Probe-specific commands—these commands operate on individual probes. For example, the PINS command displays the state of selected signal lines. The resulting display contains different information for different probes.

The PICE system functions return a requested value that depends on the current state of the environment. For example, the Cl function accepts a character value from the console. It is useful when writing interactive debug procedures. Another PICE system function, ACTIVE, takes a symbolic user program symbol as an argument and returns a Boolean value. When TRUE, this value signifies that the user program variable exists. The variable may not exist if the PICE system is emulating and the current execution point has not yet reached the procedure that defines the variable.
The PICE system pseudo-variables are system-defined variables that can be used in expressions but cannot be removed by the user. For example, the dollar sign (\$) pseudo-variable represents the current execution point. The PCHECK pseudo-variable is a probe-specific Boolean pseudo-variable. Setting PCHECK to TRUE enables protection checking for the 80286 probe.

### **The PICE™ System Software**

The PICE system software consists of the following items:

- Host software
- Error/help software
- Probe software
- Diagnostic software
- Optional iLTA software and confidence tests
- PSCOPE-86 (optional for IBM PC hosts)
- Tutorial software

#### **The PICE™ System Host Disk(s)**

The host software is received on one or two disks. The disks are not system (bootable) disks. The host software is in the I2ICE.86 file for an Intellec development system (for an IBM PC host, the file is named I2ICE.EXE). The host software file is an object file.

#### **The PICE™ System Error/Help Disk**

The error/help disk is not a system (bootable) disk. It contains the following files:

- I2ICE.OVE—this file contains the error messages.
- I2ICE.OVH—this file contains the HELP messages.

#### **The PICE™ System Probe Disks**

When you invoke the PICE system software, the PICE host software is loaded into host system memory. The PICE host software then loads the PICE probe software into the PICE instrumentation chassis memory.

#### **The PICE™ System Diagnostic Disk**

The diagnostic disk is a single disk, packaged with the probe software.

The 8086/8088 diagnostic disk contains two files: ICT086.86 and ICT086.086. The ICT086.86 file loads into host memory, and the ICT086.086 file loads into PICE system memory.

The 80186/80188 diagnostic disk contains two files: ICT186.86 and ICT186.186. The ICT186.86 file loads into host memory, and the ICT186.186 file loads into FICE system memory.

The 286 diagnostic disk contains two files: ICT286.86 and ICT286.286. The ICT286.86 file loads into host memory, and the ICT286.286 file loads into I<sup>2</sup>ICE system memory.

#### **The iLTA Disks**

The iLTA software is on two double-density or three single-density disks packaged with the iLTA module. They are not system (bootable) disks.

The iLTA host software is provided on one double-density disk or two single-density disks. When contained on a double-density disk, the iLTA software has the same name as the FICE system host software. When contained on two single-density disks, one disk contains a file called I2ICE. 1, and the other contains a file called I2ICE.2.

The remaining disk contains the iLTA confidence tests. These tests reside in an FICE macro file.

#### **The PSCOPE-86 Disk**

The PSCOPE-86 disk is included with every FICE system hosted by an Intel host. PSCOPE-86 software is an option for IBM PC hosts. The contents of the PSCOPE.86 disk for Intel hosts are as follows:

- PSCOPE.86 the object file.
- PSCOPE.OVE the error and HELP messages.
- PROCS.MAC math and file handling procedures.
- \*.CRT The configuration data required for non-Intel terminals. The default configuration data are for an Intellec Series III terminal.
- $\bullet$  DC. $*$ SAMPLE.\* Sample programs that correspond to the examples used in the *PSCOPE-86 High-Level Program Debugger User's Guide.*
- README A supplement to the operating information in the *PSCOPE-86 High-Level Program Debugger User's Guide.*

If you have the DOS version of PSCOPE-86, see the manual *PSCOPE-86 High Level Program Debugger User's Guide for DOS User's* for information on PSCOPE-86 files.

#### **The FICE™ System Tutorial Disk(s)**

The FICE tutorial includes more than 100 files. Depending on your host, it is received on one or two disks. The files include the following:

\* SCR files. Each screen in the tutorial is contained in one file. The files are named SCR followed by the screen number. For example, the first screen is in file SCR1 and the first screen in module A is in file SCRA1.

- M files. Each module in the tutorial is activated by the commands in its associated M file. For example, to activate module B, the commands in file M.B are executed.
- I2ICE.MAC file. This I2ICE.MAC file is specially designed for use with the tutorial. When PICE software is activated, after the host and probe software is loaded, the I2ICE- .MAC file is executed. It causes the host system to ask users whether they want to use the tutorial.
- T.MAC file. This file is loaded when users answer "Yes" to the question displayed by the I2ICE.MAC file. The T.MAC file contains LITERALLY definitions needed to control display of the tutorial screens. It also contains definitions for several debug objects used during the tutorial.
- Source and object code files. A number of source and object code files are included. They all are versions of a change making program that is debugged during the tutorial.

# **I**2**ICE™ System Specifications**

The following sections describe the PICE system specifications. The *PICE™ Data Sheet* contains additional system specifications, including the following:

- Physical characteristics
- Electrical characteristics
- Environmental requirements

### **Host Requirements**

The host development systems that support the PICE system are the Model 800, the Intellec® Series III, the Intellec Series IV, and the IBM PC/XT and PC/AT The specifications in the following sections assume a stand-alone configuration.

The Model 800 must have the following configuration:

- A system console
- Two double-density disk drives
- The iSBC® 064A memory board
- The iSBC 012B memory board
- The RPB-86 or RPC-86 board

The Model 800 does not support the iLTA.

#### **NOTE**

References to the Model 800 assume that it has been upgraded to a Series III.

The Intellec Series III must have the following configuration:

- An integral system console
- Two double-density disk drives
- The iSBC 012B memory board
- An expansion chassis (MDS-201)

The III-820 board must be installed before the iLTA can run on an Intellec Series III.

The Intellec Series IV must have the following configuration:

- An integral system console
- A hard disk—this can be the integral 5.25 in., lOM-byte Winchester disk drive or a 32Mbyte peripheral Winchester disk drive
- The iSBC 012B memory board
- A 5.25 in., double-density disk drive

The IBM PC/XT and PC/AT must have the following configuration:

- 2A at 5VDC available for the PICE host interface board
- A hard disk
- At least 512K bytes of RAM (of which 384K bytes must be available for the PICE software)
- The ability to read 5 1/4 in., double-density disks (48 tpi)
- PC-DOS version 3.0 or later
- An open card slot (excluding slot J8 on the PC XT) for the PICE-to-PC interface board
- I/O address space 120 13F (hexadecimal) available for the PICE system

### **System Performance**



### **Emulation Clips**

The emulation clipsin lines are sampled once every bus cycle when the address bits become valid on the address bus. During emulation, the PICE system records the value of these lines in the trace buffer, once every execution cycle. Because not all clips data is stored, a clips value can cause a break, and its data will not appear in the trace buffer. Table 1-2 lists the DC characteristics of the emulation clipsin lines.

|                                    | <b>Input Voltage</b> |                              | <b>Input Current</b> |                  | <b>Output Current</b>        |                   |
|------------------------------------|----------------------|------------------------------|----------------------|------------------|------------------------------|-------------------|
|                                    | Low<br>$V_{IL}$      | High<br>V <sub>IH</sub><br>٧ | Low<br>ч.<br>uA      | High<br>Чн<br>uA | Low<br><sup>1</sup> oL<br>mA | High<br>łон<br>mA |
| clipsout lines                     |                      |                              |                      |                  | 33 at 0.7 V                  | 4.8 at 2.0 V      |
| <b>SYSBREAK</b><br><b>SYSTRACE</b> |                      |                              |                      |                  | 38 at 0.7 V                  | 1.0 at 2.0 V      |
| clipsin lines                      | 1.05                 | 2.5                          | 50                   | 50               |                              |                   |

**Table 1-2 PICE™ System Emulation Clips—DC Characteristics**

### **The Target System User Interfaces**

The three target system interfaces are the 8086/8088 probe, the 80186/80188 probe, and the 80286 probe.

Consult the PICE™ data sheet for the latest probe electrical characteristics and for the timing differences between the probe and the corresponding chip.

# **GUIDE TO THE PICE™ SYSTEM TUTORIAL**

int<sub>e</sub>j **um** 

To quickly learn how to use the PICE™ commands and features, it is recommended that you use the PICE tutorial. The tutorial is the quickest way to become acquainted with the wide variety of PICE commands. Intel recommends that new users complete the main path of the tutorial (and many of the tutorial aid modules) before they proceed to debug their own programs.

The installation appendix for your host software explains how to install the tutorial software.

This chapter supplements the on-line PICE tutorial. It includes the following sections:

- Tutorial Use—This section explains how to use the tutorial, how to deactivate it, and how to reactivate it.
- Tutorial Screens and Structure—This section reproduces two screens from the tutorial. It also lists all the tutorial screens, shows a sample emulation session, provides a diagram of the tutorial flow, and provides a subject index of the tutorial.
- Tutorial Program Listings—This section provides a list file of the PL/M sample program used in the tutorial. It also includes an assembly language listing that is generated by using the CODE option while assembling the PL/M program.
- Sample Programs in C, FORTRAN, and Pascal—This section provides sample source code in C, Pascal, and FORTRAN. (The source code is also on the tutorial disk.) These programs are *not* for use with the PICE tutorial. They are for users who have learned PICE commands and wish to experiment with the commands while emulating programs in one or more of these other high-level languages.

# **Tutorial Use**

The PICE tutorial is easy to access. Each time the user invokes the PICE software, the user's host terminal will display the following question:

**DO YOU WANT TO USE THE I2ICE TUTORIAL? (Y OR N)**

### **Invoking the Tutorial During Program Debugging**

If you invoke the PICE software without invoking the tutorial, and later you wish to review information in one or more of the tutorial screens, you can invoke the tutorial by entering the following command.

#### **INCLUDE** *pathname* **I2ICE.MAC NOUST**

The *pathname* provides the location of the PICE software. See the Pathname entry in the *PICE™ System Reference Manual.*

### **Deactivating the Tutorial**

After you have become familiar with PICE commands, you may wish to deactivate the tutorial—that is, you may wish to eliminate the screen that asks whether you want to use the tutorial. To deactivate the tutorial, you must either delete or rename the I2ICE.MAC file.

### **Reactivating the Tutorial**

To reactivate the tutorial, select your situation from the following two possibilities:

- **You Now Use Your Own I2ICE.MAC File.** If you created your own I2ICE.MAC file after you deactivated the tutorial I2ICE.MAC file, use operating system commands to do one of the following:
	- Revise your I2ICE.MAC file. Locate the I2ICE.MAC file supplied with the tutorial. Append it to your I2ICE.MAC file. Examine the appended commands to ensure that they do not conflict with the commands you created.
	- Rename your I2ICE.MAC file. Rename your I2ICE.MAC file so that you can use it later. If you previously renamed the tutorial I2ICE.MAC file, rename it again to  $I2ICE.MAC$ . If you previously deleted the tutorial  $I2ICE.MAC$  file, copy the MCE.MAC file from the master tutorial disk to the disk or directory that has the PICE software.
- **You Do Not Use Your Own I2ICE.MAC File.** If no file named I2ICE.MAC exists, use operating system commands to restore the tutorial I2ICE.MAC file. Do one of the following:
	- $-$  If you previously renamed the tutorial I2ICE.MAC file, rename it again to I2ICE.MAC.
	- $-$  If you deleted I2ICE.MAC from the disk or directory that has the PICE software, copy the I2ICE.MAC file from the master tutorial disk to the disk or directory that has the PICE software.

# **Tutorial Screens and Structure**

After you have loaded the PICE and tutorial software (as specified in the software installation appendix for your host), screen 1 of the tutorial will be displayed (see Figure 2-1).



**Figure 2-1 Tutorial Introductory Screen: SCRl**

The tutorial is divided into a main path that has more than 45 screens, and two sets of aid screens. The main path introduces you to many of the I<sup>2</sup>ICE commands as it leads you through several emulation and debugging sessions. One set of aid screens elaborates on topics briefly mentioned in the main path. The other set of aid screens explains some of the FICE system features.

The FICE tutorial screens are created with FICE commands. This means that when you use the tutorial, you are also using FICE software. As a consequence, whenever the cursor appears next to the FICE prompt (\*), you can enter any FICE commands you wish. Once you enter the FICE commands recommended on a particular tutorial screen, you need not immediately advance to the next screen. Instead, you can experiment with commands to ensure that you understand the concepts presented in the tutorial screen. Then, when you are ready for the next screen, you can call it up by typing N (for Next screen) followed by the  $\leq$  RETURN  $>$  (or  $\leq$  Enter  $>$ ) key.

- 1. For Intel hosts, commands are entered with the <RETURN> key. For IBM PC hosts, use the  $\lt$  Enter  $>$  key.
- 2. On Series III hosts, pressing  $\langle \text{CTR} \rangle$  and D at the same time produces an asterisk prompt  $(*)$ , but this prompt is not for PICE software; it is the prompt for a development system debugger. Type  $G < RETURN >$  to return to PICE software.

This section provides a variety of information on the tutorial structure and contents. The main subsections and their topics are the following:

- Copies of Selected Tutorial Screens
- An Overview of the Tutorial Stucture
- List of All Tutorial Screens
- Tutorial Index

 $\bullet$ 

#### **Copies of Selected Tutorial Screens**

For your convenience, five tutorial screens are shown in the following subsections:

- Figure 2-1 Tutorial Introductory Screen: SCR1
- Figure 2-2 Tutorial Main Menu: SCR2
- Figure 2-3 Menu for the Emulation Aid Modules: AID1
- Figure 2-4 Menu for the PICE™ System Feature Aid Modules: AID2
- Figure 2-5 Emulation Display for Screens SCR12 through SCR15

Figure 2-1 shows the first tutorial screen for an Intellec system. This screen should appear after you have loaded PICE tutorial software as specified in the software installation appendix for your host.

Figure 2-2 shows the main tutorial menu. (See Figures 2-3 and 2-4 for the two tutorial aid module menus.)

Some topics that are briefly introduced in the main tutorial path are explained further in emulation aid modules. Figure 2-3 shows the menu for the emulation aid modules. To display this menu on your screen, type the following (for IBM PC hosts, use < Enter> for  $<$ RETURN $>$ ):

#### **RETURN >**

Figure 2-4 shows the modules included in the PICE tutorial that describe PICE features. To display this menu on your screen, type the following (for IBM PC hosts, use  $\leq$  Enter  $>$  for  $<$ RETURN $>$ ):

**AID2< RETURN >**



**Figure 2-2 Tutorial Main Menu: SCR2**

Screens SCR12 through SCR15 explain the input/output display that occurs in the first emulation session. Because the complete emulation display is long and somewhat complex, the tutorial user is asked to enter commands that interrupt the display so that individual portions of the display can be explained. Figure 2-5 shows how the display would appear if it were not interrupted. (The emulation display is longer than one screen; Figure 2-5 extends the screen size to show the entire display.)

### **An Overview of the Tutorial Structure**

Figure 2-6 provides an overview of the tutorial structure. On the left are the three main-path modules and their associated screens. In the center are the emulation aid modules. Arrows indicate the main path screens that reference the emulation aid modules. On the right are the feature aid modules.



**Figure 2-3 Menu for the Emulation Aid Modules: AID1**

### **List of All Tutorial Screens**

Tables 2-1, 2-2, and 2-3 list all the tutorial screens, as follows:

- Table 2-1 Main Tutorial Path Screens
- Table 2-2 Emulation Aid Module (AID1) Screens
- Table 2-3 PICE™ System Feature Aid Module (AID2) Screens

Each module is a major division of the tutorial. The modules can be entered in two ways: typing the module name or typing the name of the first screen in the module.

• Typing the module name. Each module has a name (e.g., MODI, MOD\_A). Typing the module name loads the first screen in the module and sets up any prerequisites needed to carry out the steps in the module. (For example, if the module assumes that the first 2K bytes of memory is mapped to high-speed memory (HS), typing the module name maps 2K bytes to HS and loads the first screen in the module.)



**NOTE: The tutorial for IBM hosts does not have MOD\_Z.**

#### **Figure 2-4 Menu for the PICE™ Feature Modules: AID2**

• Typing the screen name. Each screen has a name (e.g., SCR3, SCRA1). You can display any screen by simply typing its name; however, if you enter a module using the name of the first screen in the module (rather than the module name), you will not set prerequisites for that module. (Note that not all modules have prerequisites.)

SCREEN OUTPUT



**Figure 2-5 Emulation Display for Screens SCR12 Through SCR15**



2139

 $\overline{a}$ 

**Figure 2-6 Tutorial Structure**

| Module<br>Name                                                      | <b>Screen</b><br>Name                                                                                                                                                                                                                                                   | <b>Screen</b><br><b>Title</b>                                                                                                                                                                                                                                                                      | Topic                                                                                                                                                                                                   |
|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                     | SCR <sub>1</sub><br>SCR <sub>2</sub><br>AID1<br>AID <sub>2</sub>                                                                                                                                                                                                        | Welcome to I2ICE<br>Main Menu<br><b>Emulation Aid Menu</b><br>Aid Features Menu                                                                                                                                                                                                                    | (These screens are reproduced<br>in Figures 2-1 through 2-4.)                                                                                                                                           |
| MOD1<br>Basic<br>Emulation<br><b>Skills</b>                         | SCR <sub>3</sub><br>SCR4<br>SCR5<br>SCR6<br>SCR7<br>SCR8<br>SCR9<br>SCR <sub>10</sub><br>SCR11<br>SCR12<br>SCR13<br>SCR14<br>SCR <sub>15</sub><br>SCR16<br>SCR <sub>17</sub><br>SCR <sub>18</sub><br>SCR19                                                              | Introduction<br>Memory Mapping<br><b>Memory Allocation</b><br>Map Choices<br><b>MAPIO</b><br>I/O Allocation<br>LOAD<br>Save Address<br>Output Line<br><b>HOLDIO/HALT</b><br>Paid Request<br>Input Paid<br><b>Price Request</b><br><b>Bug Found</b><br>Variable Values<br>Addresses<br>Module 1 End | In this module, you work with<br>the MAP and MAPIO commands, learn<br>how to interpret I <sup>2</sup> ICE output,<br>and find the first program bug.                                                    |
| MOD <sub>2</sub><br>Inter-<br>mediate<br>Emulation<br><b>Skills</b> | SCR <sub>20</sub><br>SCR21<br>SCR22<br>SCR <sub>23</sub><br>SCR24<br>SCR <sub>25</sub><br>SCR26<br>SCR <sub>27</sub><br>SCR28<br>SCR <sub>29</sub><br>SCR30<br>SCR31<br>SCR <sub>32</sub><br>SCR <sub>33</sub>                                                          | loproc<br>Go with loproc<br><b>WAIT</b><br>Change<br>Value<br><b>NAMESCOPE</b><br>Breakpoint<br>Bua#1<br><b>Bug Explained</b><br><b>I2IČE TRACE</b><br><b>Fix Errors</b><br>Hi-level Patch<br>Bug1 PROC<br><b>GO WITH Patch</b>                                                                    | In this module, you learn how to<br>improve the screen display using a<br>procedure (PROC) written with l2ICE<br>commands. Then you use a high-level<br>patch to fix the bug discovered in<br>Module 1. |
| MOD <sub>3</sub><br>Advanced<br>Emulation<br>Skills                 | SCR <sub>34</sub><br>SCR <sub>35</sub><br>SCR <sub>36</sub><br>SCR <sub>37</sub><br>SCR <sub>38</sub><br>SCR <sub>39</sub><br>SCR <sub>40</sub><br>SCR41<br>SCR <sub>42</sub><br>SCR <sub>43</sub><br>SCR44<br>SCR <sub>45</sub><br>SCR <sub>46</sub><br>SCR47<br>SCR48 | Module 3 Intro<br>Specifying BREAK<br>BREAK a "a"<br>System Spec<br>Arming at "1"<br>Rearming<br>Ascii_digit<br>Decimal_digit 1<br>Decimal_digit 2<br>Decimal_Digit 3<br>Array[5]<br>BYTE<br>Bug 2 Found<br>Fix Source Code<br>Main Path End                                                       | In this modle, you learn some<br>advanced debugging techniques using<br>arm, break, and system<br>specifications.                                                                                       |

**Table 2-1 Main Tutorial Path Screens**

| Module<br><b>Name</b>                                        | <b>Screen</b><br>Name                                                                                            | <b>Screen</b><br>Title                                                                                                                                        | <b>Topic</b>                                                                                                   |  |
|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--|
| <b>MOD_A</b>                                                 | SCRA1                                                                                                            | <b>HELP Screens</b>                                                                                                                                           | (Reference SCR7)                                                                                               |  |
| MOD_B                                                        | SCRB1<br>SCRB <sub>2</sub>                                                                                       | Syntax MENU 1<br>Syntax MENU 2                                                                                                                                | (Reference SCR8)                                                                                               |  |
| MOD_C                                                        | SCRC1                                                                                                            | Line Editor                                                                                                                                                   | (Reference SCR10)                                                                                              |  |
| MOD_D                                                        | SCRD1                                                                                                            | <b>History Buffer</b>                                                                                                                                         | (Reference SCR18)                                                                                              |  |
| MOD_E<br>PICE<br>PROCs                                       | SCRE1<br>SCRE2<br>SCRE3<br>SCRE4                                                                                 | PROCs 1<br>PROCs <sub>2</sub><br>PROCs 3<br>PROCs 4                                                                                                           | These screens explain how to<br>DEFINE an I <sup>2</sup> ICE procedure.<br>(Reference SCR20)                   |  |
| <b>MOD_F</b>                                                 | SCRF1                                                                                                            | LITERALLY, MENU                                                                                                                                               | (Reference SCR25)                                                                                              |  |
| MOD G                                                        | SCRG1                                                                                                            | PICE Keywords                                                                                                                                                 | (Reference SCR27)                                                                                              |  |
| MOD_H<br>Monitorina<br>and Tracing<br>Program<br>Execution   | SCRH1<br>SCRH <sub>2</sub><br>SCRH3<br>SCRH4<br>SCRH5<br>SCRH6<br>SCRH7<br>SCRH <sub>8</sub>                     | Module H Intro<br><b>LSTEP</b><br><b>PSTEP</b><br><b>ISTEP</b><br><b>TRACE Data</b><br><b>GO TRACE TO</b><br><b>TRACE Registers</b><br><b>CYCLES Mode</b>     | These screens explain single-<br>stepping and the I <sup>2</sup> ICE<br>trace capability.<br>(Reference SCR29) |  |
| MOD J<br>Assembly<br>Language<br>Patches                     | SCRJ1<br>SCRJ2<br>SCRJ3<br>SCRJ4<br>SCRJ5                                                                        | Module J Intro<br>The Patch<br>Patch Error<br>Rerun Patch<br>Patch Works                                                                                      | These screens explain patching<br>with assembly language.<br>(Reference SCR33)                                 |  |
| <b>MOD_K</b><br>Error<br>Messages                            | SCRK1<br>SCRK2<br>SCRK3                                                                                          | Error Info 1<br>Error Info 2<br>Error Info 3                                                                                                                  | These screens explain the five<br>types of I <sup>2</sup> ICE system errors.<br>(Reference SCR40)              |  |
| <b>MOD_L</b><br>Using<br>Registers<br>for<br><b>Breaking</b> | SCRL1<br>SCRL2<br><b>SCRL3</b><br>SCRL4<br><b>SCRL5</b><br>SCRL6<br><b>SCRL7</b><br><b>SCRL8</b><br><b>SCRL9</b> | <b>BRKREG1</b><br>BRKREG 2<br><b>BRKREG3</b><br><b>BRKREG 4</b><br><b>BRKREG 5</b><br><b>BRKREG 6</b><br><b>BRKREG 7</b><br><b>BRKREG 8</b><br><b>BRKREG9</b> | These screens explain breaking<br>with break, system, or event<br>registers.<br>(Reference SCR46)              |  |
| MOD_M<br>Using the<br>$I^2ICE$<br>Screen<br>Editor           | SCRM1<br>SCRM2<br>SCRM3<br>SCRM4<br>SCRM5                                                                        | Screen Editor 1<br>Screen Editor 2<br>Screen Editor 3<br>Screen Editor 4<br>Screen Editor 5                                                                   | These screens explain the I2ICE<br>editor AEDIT commands.<br>(Reference SCR47)                                 |  |
| MOD N<br>Screen<br>Control                                   | SCRN1<br>SCRN2<br>SCRN3                                                                                          | Module N Intro<br>Screen Control<br><b>WRITE</b>                                                                                                              | These screens explain how to<br>control cursor movement.<br>(Reference AID1)                                   |  |

**Table 2-2 Emulation Aid Module (AID1) Screens**

| <b>Module</b>                             | <b>Screen</b>                                                        | <b>Screen</b>                                                                                                                                   | Topic                                                                                                                          |
|-------------------------------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| Name                                      | Name                                                                 | Title                                                                                                                                           |                                                                                                                                |
| MOD_P<br>Non-Symbolic<br>Memory<br>Access | SCRP1<br>SCRP2<br>SCRP3<br>SCRP4<br>SCRP5<br>SCRP6<br>SCRP7<br>SCRP8 | Module P Intro<br>Number Base<br>Memory Types 1<br>Memory Types 2<br>Memory Types 3<br>Setting Memory 1<br>Setting Memory 2<br>Setting Memory 3 | These screens explain how to<br>display and set memory values<br>using the memory type of your<br>choice.<br>(Reference SCR45) |

**Table 2-2 Emulation Aid Module (AID1) Screens (continued)**





 $\bar{z}$ 

 $\Delta \sim 10^{11}$  km  $^{-2}$ 

# **Tutorial Index**

The following index correlates PICE tutorial screen suffixes with tutorial topics and PICE commands. To display any screen cited in the index, add the tutorial screen prefix SCR to the suffix and type  $\langle RETURN\rangle$  (or  $\langle Enter\rangle$ ). For example, if the index entry of interest is K1, type  $SCRK1 < RETURN > (or < Enter >)$  to display the screen.









# **Tutorial Program Listings**

The PICE tutorial disk has source programs in PL/M, C, FORTRAN, and Pascal. However, the tutorial is designed to only be used with the PL/M program. The C, FORTRAN, and Pascal programs are included on the tutorial disk for convenience. After you learn PICE commands, you may wish to experiment with the commands while emulating the sample C, FORTRAN, or Pascal programs. See the sample programs in C, FORTRAN, and Pascal in this chapter to learn more about them. This section focuses only on the PL/M program (and its equivalent ASM program).

This part has three main sections:

- Overview of the PL/M Tutorial Program
- PL/M Program Listing for the Two-bug Version of the Change Maker Program
- The ASM-86 Listing for the No-bug Version of the Change Maker Program

#### **Overview of the PL/M Tutorial Program**

The program used for the tutorial debug session is written in PL/M. It is a change making program. The user is first asked to enter an integer amount (cents) for the money paid; then, the user is asked to enter an integer amount (cents) for the purchase price. The program calculates the change in dollars and coins, and prints out a listing of the change.

The tutorial disk contains six files associated with the PL/M tutorial program. All of these files begin with the prefix CMKER.

There are three versions of the PL/M program in absolute code. To make the debugging session realistic, the initial version of the PL/M program contains two errors that do not affect compilation, but show up at run time. A second version has one of the errors corrected, and the third version is error-free. The names of the three versions are as follows:



There are two versions of the PL/M program in source code—the code in each version is the same but the comments are different. These two versions are used in the tutorial for two tutorial sessions that introduce the PICE screen editor. In the sessions, users are asked to edit the PL/M source code to correct the two bugs detected during emulation. The names of the two source code files are as follows:

- CMKER2.S1 Source code with two bugs. This code is used in editing session 1.
- CMKER2.S2 Also source code with two bugs. This version is used in editing session 2.

In addition to the three absolute code CMKER files and the two source code CMKER files, the tutorial disk also contains the following CMKER list file:

CMKERO.LST A list file that includes the assembly code.

This file is supplied for your convenience. It is not used during the tutorial.

### **PL/M Program Listing for the Two-Bug Version of the Change Maker Program**

The tutorial refers to the list file in this section; the listing is for the CMKER program version with two bugs. (The two bugs are marked in the listing.)

The program was compiled using OPTIMIZE(O). Compile options are explained in the *PL/M-86 Programming Manual* (order number 121636).







63 2 CALL write(@text.string, text.cnt): 64 2 value = 0; 65 2 not\_done = TRUE; 66 2 DO WHILE not done;  $\sqrt{\ast}$  Flag  $\sqrt{\ast}$  Flag  $\sqrt{\ast}$  $67 \quad 3 \quad \text{char} = \text{read}$ ; 68 3 IF (char  $>$  = '0') AND (char  $\lt$  = '9') THEN /\* Keyboard entry can  $\lt$  \*/<br>69 3 DO: /\* be 0 through 9 \*/  $69 \quad 3 \qquad \qquad$  DO:  $\qquad \qquad$  /\* be 0 through 9  $\qquad \qquad$  \*/ /\* Translate the ASCII hex character to the decimal value  $*$ /<br>  $\angle$   $\angle$   $\angle$   $\angle$  **BUG** value = value \*10 70 4 value = value + char - '0';  $\begin{array}{ccc} \n7.1 & 4 & \text{value} = \text{value} \times 10 \\
 & \text{value} = \text{value} + 10 \\
\end{array}$  /\* BUG = value+char - '0' \*/ 71 4 value = value / 10;  $\angle$  /\* BUG = value + char- $\angle$ <sup>0'</sup> 72 4 END: 73 3 ELSE  $not\_done = false$ ; 74 2 END; 75 2 RETURN value; 76 2 END get\_input; 77 1 begin;: /\* Mainline \*/ 7« 1 DO; 79 2 CALL write (@lf\_cr, 2);<br> $\frac{\partial Q}{\partial q} = \frac{\partial Q}{\partial q}$  calc<sup>1</sup> – get input(@paid\_text);  $pal<sup>d</sup> - det input( $\omega$  paid_text);$ 81 2 purchased = get\_input(@purchased\_text); /\* and purchase price  $*$ / 82 2 CALL write (@If\_cr, 2); 83 2 change = paid - purchased;  $\sqrt{\ast}$  Figure change  $\frac{\ast}{\ast}$ 84 2 dollars = change  $/100$ ;  $\overline{\hspace{1cm}}$  /\* How many dollars?  $\overline{\hspace{1cm}}$  /\* 85 2 coins = change MOD 100;  $\angle$  /\* Are there coins?  $\angle$  /\* 86 2 quarters = coins/25;  $\frac{1}{8}$  /\* How many quarters \*/<br>87 2 coins = coins MOD 25: /\* etc. \*/ 87 2 coins = coins MOD 25;  $\sqrt{x}$  etc.  $\sqrt{x}$  /  $\sqrt{x}$  etc.  $88 \quad 2 \qquad \qquad \text{dimes} = \text{coins/10}$ ;  $89 \quad 2 \quad \text{coins} = \text{coins MOD 10}$ ;  $90 \quad 2 \qquad \qquad$  nickels = coins/5;<br> $91 \quad 2 \qquad \qquad$  pennies = coins M  $pennies = coins MOD 5$ ; 92 2 IF paid < purchased THEN 93 2 CALL write(@('NO CHEATING!'), 12); 94 2 ELSE CALL payment; 95 2 END; 96 1 HALT; 97 1 END;

## **The ASM-86 Listing for the No-Bug Version of the Change Maker Program**

The ASM-86 language listing for the change maker program was obtained by compiling the corrected version of the PL/M program using the CODE option. It is recommended that the compilation be done using OPTIMIZE(O) when debugging. In the assembly listing, notice the statement numbers at the right. The numbers reference the lines in the PL/M program list file. On the tutorial disk, this list file of corrected code is called CMKERO.LST.

Note that the compiler was invoked by the following command:

#### **PLM8&86 CMKERN.SRC COMPACT OPTIMIZE(O) DEBUG CODE**



#### ASSEMBLY LISTING OF OBJECT CODE

 $S$ TATEMENT  $\mathbb{R}$ 



















# **Sample Programs in C, FORTRAN, and Pascal**

On the tutorial disk are source code files for change maker programs written in C (CMAKR.C), FORTRAN (CMAKR.FOR), and Pascal (CMAKR.PAS). Though similar to the PL/M change maker program used in the PICE tutorial, the C, FORTRAN, and Pascal programs are provided only as examples and cannot be used with this tutorial.

 $\bar{1}$
Before emulating these programs with the system, they must be compiled, linked, located, and memory mapped in the PICE system. You will also have to add I/O routines if you want to simulate user interaction.

# **A Change Maker Program in C**

To debug a C program using the PICE system, use C86 V2.0 or higher. Load the absolute code and then type, "go til *'.main module name*" so that all symbolic information becomes available. Then, because the C compiler adds an underscore to the tail of every symbolic name, when entering a symbol name, use the underscore (i.e., *symbolname\_).*

/\* The Changemaker Program \* \* This program is written in C-86. \* \* The program is designed to function as a simple change maker. \* Amount paid and price are part of the program. The program calculates change distribution. \*/ main() { int dollars, quarters, dimes, nickels, pennies, remainder; float amt\_paid, price, total\_change; int response =  $'y$ ; *I\** INITIALIZE PRICE AND AMT TENDERED \*/ price  $= 9.49$ ; amt\_paid =  $10.00$ ;  $total\_change = amt\_paid - price;$ /\* FIGURE OUT COIN DISTRIBUTION \*/ remainder =  $total_{\text{c}}$ change  $*$  100; dollars = remainder/100; remainder  $=$  remainder  $%$  100; quarters = remainder  $/25$ ; remainder  $=$  remainder % 25;

{

```
dimes = remainder / 10:
              remainder = remainder % 10;
              nickels = remainder /5;
              remainder = remainder % 5;
              pennies = remainder;
} / * END * /
```
# **A Change Maker Program in FORTRAN**

- \* The Changemaker Program
- \*
- \* This program assumes an amount paid for an item
- of an assumed value and computes the change due and
- \* how to make that change in U.S. currency.
- \*

#### program CMAKER

real\*4 price, amt\_paid, change, coins integer\*4 dollars, quarters, dimes, nickels, pennies

#### \* \* \* \* \* \* \* CALCULATE CHANGE

price  $= 46.33$ amount\_paid  $= 50.00$  $change = amt\_paid - price$ 

#### \* \* \* \* \* \* \* FIGURE BILL AND COIN DISTRIBUTION

change = change  $*$  100.0 dollars =  $change / 100$ coins = MOD (change, 100.0) quarters  $=$  coins / 25  $coins = MOD (coins / 25.0)$  $dimes = \text{coins} / 10$  $coins = MOD (coins, 10.0)$  $nickels = coins / 5$  $\text{coins} = \text{MOD}$  (coins, 5.0)

#### \* \* \* \* \* \* \* CORRECTION FACTOR FOR REAL NUMBER ANOMALIES

 $coins = coins + 0.1$  $pennies = coins$ stop end

# **A Change Maker Program in Pascal**

### PROGRAM cmaker (INPUT, OUTPUT);

- (\* This Pascal program is non-interactive. It contains a purchase price \*)
- (\* and an amount paid, and puts the change in the memory location of the  $(*$  variables.  $\overline{\ast}$ \*)
- variables.

#### VAR



PROCEDURE init ( $*$  variables will be global  $*$ );

#### BEGIN



PROCEDURE getinput (\* purchase, paid \*);

```
BEGIN
  paid := 150;purebase := 108END;
```
PROCEDURE payout; (\* how many dollars, quarters, etc. \*)

 $\mathcal{A}$ 



BEGIN (\* mainline \*) init ( $*$  clear memory  $*$ ); getinput (\* user interaction \*);  $change := paid - purchase;$ payout ( $*$  put amount in memory  $*$ ) END.

# **INTRODUCTION TO USING THE l**2**ICE™ SYSTEM**

mt<sub>e</sub>r کا

In the installation appendix for your host software, you are encouraged to install the PICE tutorial software so that you can quickly learn PICE commands and features. The information in this chapter provides more detail on many of the topics covered in the tutorial.

The main sections of the chapter are the following:

- Invoking the I<sup>2</sup>ICE Software
- Entering PICE System Commands. This section describes command entry, the command line editor, the syntax menu, the command history buffer, string handling, and block commands.
- Creating Debug Objects. This section describes how to create PROCs, LITERALLY definitions, and debug registers.
- The PICE Screen Editor
- File Handling. This section explains the file handling commands LIST, INCLUDE, PUT, APPEND, and SAVE.
- Memory Types
- Managing the Memory and I/O Spaces
- The Emulation Clips
- Emulating a Program
- Breaking, Tracing, and Arming
- Hardware Slipping on a Breakpoint
- Even Addresses, Odd Addresses, and Breaking
- Moving the User Cable

# **Invoking the l**2**ICE™ Software**

The host development system can be an Intellec Series III, a Model 800 upgraded to a Series III, an Intellec Series IV, or an IBM PC/XT or PC/AT. The Intellec Series III and the Model 800 use the ISIS operating system, the Series IV uses the iNDX operating system, and the IBM PC hosts use the DOS operating system PC DOS (version 3.0 or greater).

#### NOTE

Version 1.8 of the PICE software requires that your host development system be configured with at least 5 12K bytes of mass memory.

• Series III

Invoke the PICE software by entering the following command (which assumes that the PICE software is on drive 0):

#### **-run 121CE**

Series IV

Invoke the PICE software by entering its filename, as follows.

#### **> I2ICE.86**

**IBM PC/XT or IBM PC/AT** 

Invoke the PICE software by entering the following command. (The prompt shown in the example assumes that you have set your PC prompt using the command PROMPT  $=$ \$P\$G. It is further assumed that the PICE software is installed on the hard disk in the directory ICEDIR, as recommended in the installation appendix for the IBM PC hosts.)

### **C:\ICEDIR>I2IC£**

If your system disk contains a file called I2ICE.CRT, the PICE system obtains the character definitions for the system console from this file. If your system disk does not contain a file called I2ICE.CRT, the PICE system assumes an Intel or IBM PC terminal.

If your system disk contains a macro file called I2ICE.MAC, the PICE system executes the PICE commands in that file upon invocation. (The PICE tutorial software includes an I2ICE.MAC file that controls tutorial file loading.) The following example is a typical I2ICE.MAC file:

**BASE** = 16T **DEFINE LITERALLY I = 'literally' DEFINE I def = 'define'**  $\det I \cdot q = q' \cdot q'$ **ctef I ten « "length'**

/\* set default number base \*/ /\* define LITERALLYs \*/

If this macro file is present when you invoke the PICE software, the default radix is set to hexadecimal, and some LITERALLYs are predefined.

If your system disk contains CRT and MAC files, but you do not want to use them, you must specifically exclude them in the invocation command, as follows (for a Series III standalone host):

#### **-RUN I2ICE NOCRT NOMACRO**

If you rename any of the PICE files and you want them to be used as the default files during invocation, you must rename them all. For example, if you want MYFILE for a name, you must change I2ICE.CRT to MYFILE.CRT, I2ICE.MAC to MYFILE.MAC, I2ICE.OVE to MYFILE.OVE, I2ICE.OVH to MYFILE.OVH, and the probe file I2ICE.086 (for the 86/88 probe) to MYFILE.086. Then you would invoke PICE software with the following command:

#### **-RUN MYFILE**

For more information on the I2ICE command, see the I2ICE entry in the *PICE™ System Reference Manual.*

# **Entering l**2**ICE™ System Commands**

The following subsections describe command entry.

# **Extending a Command to Another Line**

Commands that exceed 80 characters continue invisibly. The 80th character displays as an exclamation point (!). To extend a command to another line, enter an ampersand (&) followed by a carriage return and complete the command on the next line. Text that appears between the ampersand and the carriage return is interpreted as a comment.

The following example shows a command that extends over more than one line. Note that the ampersand causes the next line to have a double prompt  $(**)$ .

#### **\* DEFINE SYSREG atquarters « WRITE AT »;cmak6Lquarter\$ & \*\*CALLOUT1**

The ampersand is necessary in the previous example because CALL OUT1 is an optional clause.

You may omit the ampersand if the command needs more syntactic information to be complete. If you enter a carriage return and the command is incomplete, the PICE system prompts for more information. The following example shows an incomplete command and the PICE prompt for more information.

#### **\*GO FROM begirt TIL BOTH {icmakei; payment) AND (WRITE AT \* \*. :cmaker.quarters)**

# **Aborting Commands**

Abort a command by entering CTRL-C (for IBM PC hosts, use CTRL-Break). Note that the CTRL-C has no effect on emulation. Emulation continues until a breakpoint is reached or until you enter a HALT command.

# **Multiple Commands On a Line**

To enter more than one command on a line, separate each command with a semicolon (;). The following example shows two commands on the same line.

## *\* m ?* **0 LENGTH 32K HSjMAPIO 0 LENGTH S4T ICE**

## **Comments**

Enclose a comment within a slash-asterisk combination. The symbol /\* begins the comment, and the symbol  $\star$ / ends the comment. The following example illustrates a comment.

**\*GO USING qwrite** /\* Emulate until quarters is modified \*/

# **The Command Line Editor**

The command line editor controls various keys that enable you to edit command lines.

Use the right and left arrow keys to move the cursor to the desired location within the command line before entering the correction. Pressing the HOME key after pressing the left arrow key moves the cursor to the beginning of the line. Pressing the HOME key after pressing the right arrow key moves the cursor to the end of the line. The up arrow key restores the previous line from the history buffer for editing. The down arrow key moves to the next line in the history buffer.

Use the RUBOUT key to delete the character to the left of the cursor. (For the IBM PC hosts, use the left arrow key at the top of the keyboard--above the  $\lt$  Enter  $>$  key--to perform the rubout function.) To delete other characters on the command line, use the following control characters:

- CTRL-A Deletes the line to the right of the cursor, including the character at the cursor position.
- CTRL-F Deletes the character at the cursor position; adjusts line spacing.
- CTRL-X Deletes the line to the left of the cursor, including the character at the cursor position, and adjusts line spacing.
- CTRL-Z Deletes the entire line.

For more information on the command line editor, see the Editors entry in the *FICE™ System Reference Manual.* Note that you can also edit commands using the FICE screen editor.

# **The l2ICE™ System Syntax Menu**

The FICE syntax menu lists your options when you enter FICE commands. If you follow its choices, you cannot construct a syntactically incorrect FICE command, although it may be semantically incorrect.

When you invoke the PICE software, the first line of the menu appears on the bottom of the screen. Call up subsequent lines by pressing the TAB key. The menu is circular in one direction. Press TAB enough times, and you come back to where you started. You cannot reverse the menu.

Each line contains a list of choices. The keywords are shown in uppercase letters. The menu also contains lowercase entries enclosed in angle brackets. These represent user-defined names or a set of PICE keywords. For example,  $\lt$  variable  $\gt$  represents the name of a debug variable or a program variable;  $\langle m \rangle$  represents one of the keywords identifying an IPCE memory type, such as INTEGER or REAL.

Your choice need not appear on the screen when you enter it. If you enter a space after you enter your choice, the menu displays the next level. As shown in the following example, when you enter the keyword DEFINE and follow it with a space, the new menu displayed is

#### $---<sub>m</sub>$  more  $---<sub>n</sub>$ **GLOBAL BRKREG TRCREG EVTREG ARNREG SYSREG PROC LITERALLY**

Press the TAB key to see the rest of the menu.

 $---<sub>m</sub>$  more  $---<sub>n</sub>$  $<$ mtype $>$ 

Pressing the TAB key again returns you to the first line.

You can return to higher menu levels. If, after you entered the space, you press the RUBOUT key or the left-arrow key, the menu returns to the top level, the one from which you chose DEFINE.

The PICE menu recognizes LITERALLY definitions. If you have a LITERALLY name called def representing DEFINE, entering def followed by a space displays the DEFINE menu and also automatically expands the LITERALLY name.

You can disable the menu display with the MENU command. (Note that disabling the menu display also disables automatic LITERALLY expansion.) The following command turns off the menu display:

### **\*MENU » 0**

You can also switch the menu display (and the automatic LITERALLY expansion feature) on and off by entering CTRL-V.

The following command turns on the menu display:

#### *m m u* - 1

# **The PICE™ Command History Buffer**

The PICE system stores commands in a 400-character, last-in first-out buffer. Using the history buffer, you do not need to enter a previous command to re-execute it or change it. Scroll through the buffer by pressing the up arrow key until you reach the command you want, and use the line-editing functions to modify the command. Entering a carriage return (or, for IBM PC hosts, using the < Enter> key) executes that command. The new version becomes the latest entry in the command buffer. The old version is still in its original place in the buffer.

# **String Handling**

A string has memory type CHAR. Use the DEFINE command to define a string. For example, define the string called A as the character 5.

#### **\*DEFINE CHAR A »'5'**

To add 1 to the string A, use the string name in an expression. The following example assumes a hexadecimal number base.

 $*A + 1$ **3b**

The answer is 36 because the ASCII value of 5 is 35 (hexadecimal). This example illustrates memory type conversion. The string A is memory type CHAR, and the constant 1 is memory type DWORD. The answer (the constant 36) has memory type DWORD.

The CONCAT function concatenates strings. The following example defines a string called B and concatenates it with string A.



The NUMTOSTR function temporarily treats a number as a string. The following example concatenates the string B with the string derived from the debug variable four.

#### **\* DEFINE BYTE four=4 \* CONCAT(NUMTOSTR(f our),B) 412**

The SUBSTR function picks out a portion of a string. The following debug procedure steps through a user program and displays all the MOV instructions. When a memory location is disassembled, the opcode field is a four-character field starting at position 20H.

**\* REPEAT**  $\cdot$  \*IF SUBSTR(ASM \$,20,4) =  $=$  MOV  $\prime$  THEN **. • \*ASM\$ • • \*END • \*ISTEP . \* UNTIL \$ \* \* :cmaker#14 . \*END 0021:0045H BTOEOEOO mov :CMAKER#13 0021:004C)H flBCl MOV 0021:004CH BEL400 MOV 0021:0057H flllblDOO MOV UORD PTR 000EH-iCX MOV AX-CX SI-.00fc.4H i +100T UORD PTR 0010H-.DX** The INSTR function searches a string for a substring and returns the index on which the substring begins. As shown in the following example, the index is always in decimal.

### **\* INSTRf' abedefghijklmti V klro')** 1.1

For more information on string commands, see the string command entries in the *PICE™ System Reference Manual.*

# **Block Commands**

A block command begins with one of the following keywords:

COUNT DO IF REPEAT

A block command contains one or more FICE commands and terminates with END. All PICE commands except EDIT, INCLUDE, HELP, and LOAD can be included within a block command.

The DO block executes all commands. The IF, REPEAT, and COUNT blocks permit test conditions that determine which commands are executed. The IF block conditionally selects a group of commands. The REPEAT command executes a group of commands indefinitely or until an exit condition occurs. The COUNT command is similar to the REPEAT command but enables you to specify the maximum number of times the command group is executed.

A period (.) before the asterisk prompt indicates that the  $I<sup>2</sup>ICE$  system recognizes the beginning of a block command and has not yet detected the end. The following example shows a block command that steps through five assembly language instructions, beginning at the current execution point, and evaluates the source-code statement number for each instruction.



The FICE system executes a block command when you press the carriage return after the END of the outermost block.

# **Creating Debug Objects**

Debug objects are uniquely-named, user-created software constructs that the PICE system uses to manage the debugging environment. The four types of debug objects are debug procedures, LITERALLY definitions, debug registers, and debug variables.



# **Creating a Debug Procedure**

**The following example uses the DEFINE command to define a debug procedure. The PICE commands are enclosed within a DO-END block.**

```
* DEFINE PROC in-paid * DO
. *PORTDATA = 1O0T
. *END
```
**The keyword PROC identifies the definition as a debug procedure. The PICE commands that make up the debug procedure must be enclosed within a DO-END block. When you follow the DO with a carriage return, the PICE system returns a prompt that represents the command nesting level. The single period signifies that the PICE system is waiting for only one END.**

**The following example shows more than one nesting level.**

```
* DEFINE PROC money = DO
. *IF %0m =2 THEN
. • *PORTDATA = 100T
. • *ELSE IF %0 = = 4 THEN
. • • *PORTDATA = 75T
. . . *END
. . *END
. *END
\star
```
# **Creating a LITERALLY Definition**

The following example uses the DEFINE command to create a LITERALLY definition.

### **\*0EFJNE LITERALLYdef - DEFINE'**

Now def can be used in place of DEFINE. The character string to the right of the equal sign can be up to 254 characters long.

You can also use a LITERALLY definition to replace a command line as shown in the following example.

# \*def LITERALLY mp = 'MAP 0 LENGTH 32K HS;MAPIO 0 LENGTH 64T ICE;MAP;MAPIO'

When you enter mp followed by a carriage return, the PICE system executes all the commands in the character string. If you store this LITERALLY definition in the I2ICE.MAC file, it is executed immediately after invocation. Note that this LITERALLY definition takes advantage of the previous example by using def instead of DEFINE. In your I2ICE.MAC file, the LIT-ERALLY definition of def must precede that of mp. This example also shows that multiple commands on the same line must be separated by semicolons (;).

# **Creating a Debug Register**

Use the following syntax to define arm, break, event, system, and trace registers. The ARMREG, BRKREG, EVTREG, SYSREG, and TRCREG entries in the *PICE™ System Reference Manual* describe these registers in detail.



# **Creating a Debug Variable**

The syntax for defining a debug variable is as follows:

DEFINE *m type nam e [* = *value]*

An mtype is one of the PICE memory types. (See the memory types section in this chapter for more information on memory types and on creating debug variables.) If you do not set the debug variable equal to a value, the PICE system assumes zero.

# **The PICE™ Screen Editor**

The screen editor has all the features of the AEDIT VI .0 editor. It is menu-driven and, when invoked (with the EDIT command or the ESC key), displays the edit menu at the bottom of the screen. The main menu is displayed on three screens; press the TAB key to advance to the next screen. The following screens show the main menu prompt lines.



Choose a menu item by pressing the key representing its first letter. Several of the screeneditor commands prompt for additional information or display sub-menus. The following sections describe some of the PICE system screen editor commands. The AEDIT manual (order number 121756) describes all the screen editor commands in detail and gives examples.

# **Inserting Text**

To begin inserting text when you are in the screen editor, position the cursor, then press the I key. The menu prompts

### **CinsertH**

What you enter is inserted into the buffer at the cursor position. Return to the main menu by pressing the ESC key or by entering CTRL-C. (Note that CTRL-C deletes all the text you inserted.)

# **Deleting and Moving Text**

The PICE screen editor uses the same control characters as the line editor. To delete a character or line, use the CTRL-A, CTRL-F, CTRL-X, or CTRL-Z key.

To delete or move a block of text, use the screen editor temporary buffer. First delimit the text that you want loaded into the temporary buffer by moving the cursor to the start of the block and pressing the B key. Pressing the B key sets the first delimiter for the temporary buffer and displays the buffer menu as shown in the following example:

```
Buffer Delete Find -find Jump Put
```
The first delimited character appears as an at sign  $(Q)$ .

Pressing the D key deletes the delimited text from the screen and copies it into the temporary buffer. Pressing the B key copies the delimited text into the buffer without deleting it from the screen. The system editor then returns you to the main menu.

To move the deleted or copied text elsewhere in the edited text, first move the cursor to the desired position. Then press G (for Get) and either the ESC key or the RETURN (or, for IBM PC hosts, Enter) key.

### **Viewing Text**

The View command is useful when the file you are editing is longer than one screen. Pressing the V key rewrites the screen display with the line containing the cursor in the middle of the screen (unless the cursor is so near the beginning or end of the text that the line cannot be centered).

### **Overwriting Text**

To begin overwriting text, position the cursor and press the X key. The bottom line now reads as follows:

### **[exchange]**

When you enter a character, it replaces the character at the cursor position, and the cursor moves to the next position. Return to the main menu by pressing the ESC key or by entering CTRL-C. (Note that CTRL-C deletes all the changes you made.)

### **Editing External Files**

With the screen editor you can edit development system files without returning to the PICE command line. The Editors entry in the *PICE™ System Reference Manual* describes external file editing in detail.

# **Exiting the Screen Editor**

To exit the screen editor, return to the main menu and press the Q key. If you were editing a debug procedure, the bottom line displays the following quit menu:

Abort Execute Init Write

If you were editing an external file, the bottom line displays the following quit menu:

```
Abort Execute eXit Init Update Write
```
- The Abort sub-command returns to the PICE command line, and all changes (if any) are lost.
- The Execute sub-command returns to the PICE command line and executes the edited command or debug procedure.
- The eXit sub-command incorporates all changes and returns to the PICE command line.
- The Init sub-command enables you to start another editing session without returning to the PICE command line.
- The Update sub-command incorporates all changes without returning to the PICE command line.
- The Write sub-command prompts for an output file without returning to the PICE command line.

For an on-line demonstration of the command and screen editors, see the corresponding modules in the PICE tutorial.

# **File Handling**

The next three subsections describe list files, include files, and the LOAD and SAVE commands.

# **List Files**

List files record the console interactions of a debug session. The LIST command syntax is as follows:

#### LIST pathname

A typical *pathname* for a standalone Series III host is :F1:1st.001. This represents a file on disk drive 1 whose file name is 1st.001. (See the Pathname entry in the *PICE™ System Reference Manual* for more information on *pathname.)* After you enter the LIST command, all console activity is written to that file. You can stop recording in the list file by entering the NOLIST command. You can restart listing, but if you use the same pathname, you are prompted as follows: Overwrite existing file? (y or  $[n]$ ). If you do not want to overwrite the existing list file, answer "n" and re-enter the LIST command using another file name for the new list file.

# **Include Files: The INCLUDE, PUT, and APPEND Commands**

Include files are text files that contain PICE commands. You can construct them with a text editor, or you can use the PUT and APPEND commands.

The PUT command creates an include file. If the file already exists, you are prompted with the following message: Overwrite existing file? (y or [n]). The syntax for the PUT command is as follows:



The keyword DEBUG writes the definitions of all currently defined debug objects to the specified include file. You can also write all debug registers of the specified type, all debug procedures, all LITERALLY definitions, or all debug variables of the specified memory type. In addition, you can specify only the debug objects you want saved.

The following command saves the definitions of all debug variables of type BYTE, the debug objects named even and odd, and all debug procedures to the current directory on an IBM PC host.

### **\*PUT BYTE, even, odd, PROC**

When you enter the PUT command and if the file name already exists on the disk, you are asked by the PICE system whether you want to overwrite an existing file. If you do not want to overwrite the existing file, change the file name. You can add to the include file rather than writing over it by using the APPEND command. The syntax is the same as that for PUT.

To retrieve the debug object definitions stored in the include file, use the INCLUDE command. For example, to include the standalone Series III file :F1:deb.001:, enter the following:

#### **\* INCLUDE ;Ft:deb.001**

After you enter the INCLUDE command, the PICE system displays the contents of the specified include file on the console screen. You can suppress that display with the NOLIST option, as in the following standalone Series III example:

### **INCLUDE :F1:<Jeb.00t NGUST**

# **The LOAD and SAVE Commands**

Program files must contain absolute code. All memory references must be resolved. The PICE system will not accept load-time locatable files. Construct program files by compiling (or assembling) your source code (use the DEBUG option), linking the compiled (or assembled) file, and locating the linked file.

The following syntax is for the LOAD command:

### LOAD *pathname* [NOCODE] [NOSYMBOLS] [NOLINES] [APPEND]

For example, if you are using a Series III host system to load the program file called cmaker.86 from disk drive 1 into program memory, enter the following:

#### **\*LOA0 :Fl:cmaker»86**

There must be enough unguarded program memory to contain the program file. These memory locations must be mapped to the physical locations expected by the program file. (See the memory mapping section of this chapter for information on mapping.)

Because the PICE system does not clear memory before each load, you can load multiple files by issuing successive LOAD commands. The user program symbol table resides in host memory, and it is cleared by the LOAD command. After successive loads, the PICE system only retains the symbol table from the last load. If you use the APPEND option, however, the symbol table retains program symbols from any previous loads.

The LOAD command can also be used to load files into memory that were created with the SAVE command. The SAVE command saves the contents of a specified memory partition to the file specified by a pathname. The memory image is saved in 8086 OMF format.

Use SAVE to save assembly-level patches for future debugging sessions or to save modified data table values that improve performance of the software being debugged.

# **Memory Types**

A debug variable always has one of the following PICE memory types associated with it,



The PICE system does not distinguish between ADDRESS, SELECTOR, and WORD. For more information on PICE memory types, see the Mtype entry in the *PICE™ System Reference Manual.*

A program variable always has the type defined by the user program. Use PICE memory types to determine how you read the program variable from memory.

# **Debug Variables**

A debug variable is defined with an PICE command during a debugging session. With certain restrictions, you can assign debug variables of one type equal to debug variables of another type as shown in the following example:

#### **\* DEFINE WORD answer \* DEFINE BYTE ans \* 4FH \* answer 2\* ans**

In this example, the PICE system pads the value in ans with leading zeros to complete the word occupied by answer.

The following example uses signed integers. The debug variable small is an 8-bit signed integer; its type is SHORTINT. The debug variable large is a 16-bit signed integer; its type is INTEGER.

#### **\* DEFINE INTEGER large**  $*$  DEFINE SHORTINT small  $= -4$  $*$  large  $=$  small

The PICE system sign-extends the value of small to complete the word occupied by large.

Some conversions are illegal. For example, you cannot set a debug variable of type CHAR (an 8-bit ASCII value) equal to any of the signed types.

```
* DEFINE CHAR yes
* DEFINE SHORTINT smalt« ~4
* yes « small
ERROR #bR
Invalid type conversion
```
# **Program Variables and Symbolic Debugging**

When you first load a program, the execution point is at the beginning of the main module's prologue. The prologue clears interrupts, loads the stack segment register, the stack pointer, and the data segment register, then jumps to the beginning of your program. The first instruction of your program begins statement #1. The locater puts this prologue at the beginning of your code. Before you can access a program variable symbolically, you must execute the prologue and enter your program.

You can take a look at the prologue by applying the ASM memory template, as shown in the following example:

**\* LOAD ?F1 :cmaker\*S6 \* ASM \$ LENGTH 7T □ □2D: OODbH FA CLI /\*ISTEP\*/ MOV SS-CS: WORD PTR DOODH** 



You can execute the next instruction (using the ISTEP command) as well as display it. Apply the ASM memory template to the execution point and enter the command ISTEP.

#### **\*ASM \$; ISTEP OOPS** OUT

You can then re-execute this command by entering a CTRL-E (hold down the CTRL key and press the E key). The screen displays the command again.

**\*ASM \$■ ISTEP □ □ED : □□□7H EEflElbDDDD MOV SS i CS : WORD PTR □□□OH**

If you enter CTRL-E again, the screen displays the next instruction.

#### **\* ASM \$; ISTEP □ □ED : DDDFH EEflElEDEDD MOV DS CS : WORD PTR D003H**

The second and third ISTEP commands each executed two instructions. The next instruction to be executed is MOV BP,SP because the 8086 architecture excutes two instructions if you single-step through an instruction that is a move into a segment register. No interrupt, not even a non-maskable interrupt, can occur between these two instructions. After you entered CTRL-E, you would see the next instruction.

**\*ASM \$;ISTEP :CMAKER#! □ □ E l : OODAH flBEC M0VBP-.SP**

Now your program has begun execution. To display a program variable named coinrelease, enter its name:

#### **\* :cmaker.coinrelease** <sup>+</sup>**1**

To modify *coinrelease,* set it to another value as in the following example:



Note that cmaker.coinrelease is the fully-qualified reference to coinrelease. A fully-qualified reference to a symbol includes the module name and the names of all procedures that enclose the symbol from outer-most to inner-most. Because a fully-qualified reference completely identifies the symbol, such a reference is always valid. A partially-qualified reference omits the module name and one or more of the outer procedure names. A partially-qualified reference is valid only if the current execution point is inside the outer-most procedure referenced.

# **Program Variables and the I<sup>2</sup>ICE™ Memory Types**

The PICE memory types are templates for reading and writing program memory. You can read and write program memory by specifying just the program variable's symbolic name, which reads the program variable as its program-defined type.

If coinrelease is defined by the user program as a WORD, you can nevertheless read coinrelease as an integer. Apply the PICE memory template over program memory, as shown in the following example:

\***INTEGER coinrelease**<br>003E : 0004H +1 0D3E:0004H +1

The user program type for coinrelease would remain WORD.

You can also assign values with a memory template. The following example sets coinrelease to 0:

### $x$ **INTEGER** .coinrelease  $= 0$

You can use a debug variable without the period. The debug variable is a value, and the PICE memory template command uses that value as the address. The debug variable's value rather than its address becomes the operand. The value of a POINTER variable named begin (which, it is assumed, has been set to the beginning program address) is 0020;0006H. Applying the WORD template to begin tells you that memory location 0020:0006H contains FA, and 0020: 0007H contains 2E.

**\* WORD begin** OO2O:00ÕLH 2EFA

# **Managing the Memory and I/O Spaces**

This section explains how to set up the memory map and the I/O map and how to read and write memory locations.

# **The l2ICE™ Memory Map**

The user program must be absolute code, and every memory reference must have a unique physical address. The PICE memory map determines where this memory space physically resides. You can split up the memory space among the following:

- USER The prototype hardware contains the memory.
- HS The PICE system contains the memory. It resides on the map-I/O board in the PICE instrumentation chassis. There are 32K bytes of high-speed (HS) memory available on the map-I/O board.
- OHS The PICE system contains the memory. It resides in optional high-speed (OHS) memory. Each OHS board provides 128K bytes of high-speed memory. You can install one or two OHS boards.
- MB The host development system contains the memory. It resides on memory boards within the host chassis. The MB stands for the MULTIBUS bus. [IBM PC hosts cannot use the MB option.]
- GUARDED The memory does not reside anywhere. An attempt to access guarded memory results in an error.

In addition to providing access to as much as 32K bytes of HS memory, 256K bytes of OHS memory, and all MB memory not used by the PICE system in the host development system, the PICE system also allows mapping I/O to the development system console or to an PICE debug procedure. The MB memory can be mapped in named or unnamed blocks. When named blocks are used, the same physical MB memory can be accessed as dual port memory by multiple probes in a multiprobe enivronment. (LOCK is supported.) In a single probe environment, the same memory can be mapped to multiple addresses in the same probe.

Both HS and OHS memory are zero-wait-state memory. This means that a user program does not take longer to access either HS or OHS memory than it does to access user memory. The PICE emulation is real-time. However, with the WAITSTATE command you can insert up to 15 wait-states into memory accesses. In this way, you can emulate slow memories.

In most designs today, hardware and software development take place in parallel. For example, if your software is ready for prototype memory, but the hardware is not yet available, use HS or OHS memory.

Running your prototype software completely within PICE memory may also help you distinguish between hardware and software problems. Later in the design, after you have verified your code and prototype memory becomes available, you can map your software to prototype memory, memory block by memory block.

You can view or set the memory map using the MAP command. All program memory is initially guarded, as shown in the following example.

**\*MAP MAP OK LENGTH 1D24K GUARDED** To change the memory map, specify a memory partition and a physical location for program memory. For example, to map the first 32K bytes of program memory to HS memory, enter the following command:

#### **\*MAP OK LENGTH 32K HS**

A partition is a range of addresses. The partition OK LENGTH 32K represents a starting address of 0 and a range of blocks 32K bytes long. You can also represent a partition with starting and ending addresses, using the keyword TO instead of LENGTH. For example, you could map the first 32K bytes of program memory to HS memory by entering the following command:

#### **\*MAP OK TO 32K -1 HS**

The MAP command shows the result.

#### **\*\$IAP '**

### **MAP OK LENGTH** *BEK* **HS MAP BEK LENGTH 99EK GUARDED**

The MAP command also enables you to assign the two attributes READ and WRITE to memory partitions.

- READ designates the partition as read-only. If you are simulating prototype ROM in HS RAM, you may want to designate that partition as read-only.
- WRITE suppresses read-after-write verification. Read-after-write verification means that the PICE system follows a write to memory with a read from the same location and verifies the result. Normally, the I<sup>2</sup>ICE system performs a readafter-write verification when you load a user program and when you write memory from the console. You would not want a read-after-write verification if it would change the state of the I/O device.

#### **NOTE**

In one instance the PICE system reads after a write even when the partition is designated as WRITE. With the memory template commands (described later in this chapter) you can read and write program memory and interpret the data as one of the PICE memory types. When writing iterative data, the command repeats a data pattern over a memory partition. For example, when you enter the following command:

#### $*$ **BYTE .start LENGTH**  $7 = 1.2$

After the command is executed, program memory values are the following:



The algorithmn used by the PICE system reads from program memory, even though you designated the partition as WRITE with the MAP command.

Regardless of the memory or I/O maps, if the BTHRDY pseudo-variable equals TRUE the target system must return a valid READY signal for each bus cycle (except HALT and SHUT-DOWN) that the processor initiates. Otherwise, a time-out will occur if one or more of the time-out pseudo-variables are enabled (time-outs are enabled by default). The time-out pseudo-variables are the following:

- BUS ACT allows a system time-out when the processor bus is inactive for more than one second.
- IORDY allows a system time-out when an I/O access takes more than one second.
- MEMRDY allows a system time-out when memory access time is longer than one second.
- PHANG allows a system time-out when coprocessor memory accesses exceed one second (8086/8088 and 80186/80188 probes only).

Erratic operation can occur if READY violates the setup or hold requirements or is asserted at the wrong time during a bus cycle. If the time-out pseudo-variables are disabled and the target system does not provide READY, the PICE HALT command will not return the probe to interrogation mode; return to interrogation mode by entering the RESET UNIT command.

# **Mapping Input/Output**

The MAPIO command displays or changes the PICE I/O map. If you display the I/O map right after invoking PICE software, you will see all I/O ports mapped to USER, as shown in the following example:

### *m m o* MAPIO 0 LENGTH 1D000H USER

The I/O map determines the source of input data and the destination of output data. You can map I/O ports to USER or ICE. The prototype hardware reads or writes I/O ports mapped to USER.

All bus cycles (memory reads and writes, interrupt acknowledges, I/O reads and writes, and halt cycles) initiated by the processor in the PICE system are active in the target system

regardless of where memory or I/O is mapped. When memory or I/O is mapped to MB, OHS, or HS memory or ICE I/O, the data is written to both MB, OHS, or HS memory or ICE I/O and the target system. The data is read from both the target system and MB, OHS, or HS memory or ICE I/O. However, the data from MB, OHS, or HS memory or ICE I/O is used, and the data from the target system is ignored. This feature enables you to use the PICE system as a signal generator to debug hardware problems in target systems without relying on the data integrity of the hardware system.

The PICE system has 64K byte-wide ports or 32K word-wide ports available. You can only map I/O ports in blocks of 64 bytes. If you specify a partition that does not fall on a 64-byte boundary, the PICE system expands the partition to the next higher boundary.

For example, to map the first 64 ports to ICE, enter the following:

#### **\*MAPIO 0 LENGTH 64T ICE**

The T specifies 64 as a decimal number (64T has the same value as 40H). Now look at the I/O map.

#### **\*MAP10**

#### **MAPIO 0000DH LENGTH 0004DH ICE MAPIO D004DH LENGTH OFFCDH**

You could also have specified the I/O partition with a starting and an ending address. The following example produces the same result:

#### **\*MAPIO0TO64T~1ICE**

#### **Simulating I/O from the Console**

To simulate I/O from the console, map one or more I/O partitions to ICE. When the user program requests input, the console displays a message requesting an input. Respond by entering the input value at the console keyboard. For example, if the first I/O partition is mapped to ICE and the user program requests a word from port 2, then the console displays the following message:

#### **fUNIT □ PORT EH REQUESTS WORD INPUT (ENTER VALUE) :**

Enter the desired value in the space provided and follow it with a carriage return (or, for IBM PC hosts, < Enter> ). The PICE system reads the value in the current number base.

When the user program writes an I/O port, the console displays the result. For example, if the first I/O partition is mapped to ICE and the user program writes port 2 with the value 1 expressed as a word, the console displays the following:

#### *f* **UNIT □ PORT 000EH OUTPUT WORD OOOIH**

The PICE system displays output in hexadecimal regardless of the current number base.

#### **Simulating I/O with a Debug Procedure**

A debug procedure is a named group of PICE commands. To simulate I/O using a debug procedure, map one or more I/O partitions to ICE and follow the keyword ICE with the name of a previously-defined debug procedure, as follows:

#### **\*MAPIO 0 LENGTH 64T ICE(money)**

#### **Input**

When the user program requests input, the PICE system calls the specified debug procedure, and that procedure supplies the value. Use the following commands to define a debug procedure called money that supplies 100 when the program reads port 2 and 65 when the program reads port 4:



The percent sign *(%)* identifies a system parameter passed to the debug procedure. Table 3-1 lists the system parameters used with I/O debug procedures.





To map the first I/O partition to ICE(money), enter the following:

#### **\*MAF(0 0 LENGTH 64T ICE(rooney) \*MAP!0 64T LENGTH 64T USER \*MAPIO** HAPIO ODDDDH LENGTH D0040H ICE MONEY MAPIO 00040H LENGTH 00080H USER

If you run the example program cmaker.86 in Chapter 2, the console does not prompt for input. Instead, the input is supplied by the debug procedure money.

**Output** 

When the user program writes an I/O port which belongs to an I/O partition mapped to ICE- (money), the debug procedure money handles the output. The program cmaker.86 writes to port 64. To change the I/O map so that port 64 is mapped to money, enter the following command:

#### **\*** *MAPiO* **0 LENGTH 128T ICE<money)**

The debug procedure must write the output value to the console or store the output value in a debug variable.

The following example is a modification of money that reads 100 from port 2, reads 65 from port 4, and writes to the console.

**\* DEFINE PROC money ~ DO . \*IF %1 THEN**  $. 1 \times 1F$  % $0 = 2$  THEN **... \* PORTDATA = 100T**  $\ldots$  **\*ELSE IF %0 = = 4 THEN**  $\cdots$  \* PORTDATA  $=$  65T **------\*END . . . \*END . . \*£LSE WRITE PORTDATA . . \*END . \*END**

To store the output in the previously-defined debug variable answer instead of writing it to the console, replace WRITE PORTDATA with answer = PORTDATA.

If the user program is writing a word-wide port, then answer should be of type WORD. A debug variable of type WORD is treated as a 16-bit unsigned integer. Define the type WORD debug variable answer as follows:

#### **^DEFINE WORD answer**

If the user program is writing a byte-wide port, then the debug variable should be of type BYTE. A debug variable of type BYTE is treated as an 8-bit unsigned integer. Define the type BYTE debug variable ans as follows:

#### **\* DEFINE BYTE an\$**

The next example is a modification of the debug procedure money that stores the output value in answer if the write is to a word-wide port and in ans if the write is to a byte-wide port.

**^DEFINE PROC money - DO . \*IF%f THEN . . \*IF** *%Q* **~ 2 THEN . - -\* PORTDATA = 100T**

- **. . . \*ELSE IF %0 = = 4 THEN**
- **------ \*PORTDATA = 65T**
- **------\*END**
- 
- ...\*END<br>..\*Else if %2 Then
- **. . . \*ans=PORTDATA**
- **. . . \* ELSE answer = PORTDATA**
- **. . . \*END**
- **• \*END**
- **. \*END**

# **The Emulation Clips**

The emulation clips pod has eight input signals and four output signals. Note that these lines are TTL inputs and outputs.

# **The Clipsin Lines**

Applications for the clipsin lines are setting up the PICE system to trigger on a hardware event (the assertion of a signal or signals by the prototype) and using the PICE system to inspect the state of user signals. For example, to break emulation if a prototype signal goes high (becomes 1) when an over temperature condition exists, connect that signal to clipsin 0. Then, enter the following PICE command:

#### **\*GO TIL CLIPS OXXXXXXXf V**

The following example displays the current setting of the clipsin lines:

#### $*$  CLIPSIN **1EH**

Interpret the result in the following way:



When a clipsin line is disconnected, it returns zero.

# **The Clipsout Lines**

You can set and read the last value written to the two clipsout lines with the CLIPSOUT command. The following example sets clipsout1 to 0 and clipsout0 to 1:

**\*BASE** *m* **BINARY \*BASE BINARY**

#### $*$  **CLIPSOUT** = 01Y **\* c u pso u t** D1Y

The two clipsout lines that can be set by users with the CLIPSOUT command are zero by default. The other two clipsout lines are the system break and trace lines. An armed PICE system asserts the system break line when it encounters a breakpoint. An PICE system, armed or not, always asserts the system trace line when it collects trace data.

The SYS BREAK/ and SYS TRACE/ clips output lines are provided to enable users to connect to devices that are not part of your I<sup>2</sup>ICE system.

# **Emulating a Program**

This section contains a sample Pascal program that illustrates how to get the PICE system up and running. The sample program is a procedure in a larger program that controls an automatic change making and coin release mechanism.

The steps shown are compiling, linking, and locating the program, invoking the PICE system, loading the located program for emulation, setting a breakpoint, and resuming emulation.

# **Preparing a Pascal Program**

The program reads in the amount tendered (the variable paid) and the amount of the purchase (the variable purchase). It determines whether the resulting change contains any coins. If so, the program sets the variable coinrelease to 1. Then, the program writes coinrelease to I/O port 64T (40H).

Use a text editor to construct a file containing the following Pascal source code.

PROGRAM cmaker;



Call the file cmaker.SRC and write it on the disk mounted on drive 0. The file's pathname is :FO:cmaker.SRC.

#### **Compiling the Source File**

This example assumes that the Pascal compiler is on disk drive 1 of a Series III development system and that the source file is on disk drive 0. The resulting object file is on disk drive 0.

#### -RUN :F1 :PASC86 cmaker.SRC DEBUG XREF

#### **SERIES-III Pascal-fib-. Vx-y PARSE (0) -, ANALYZE (□) •, XREF -, OBJECT**

#### **COMPILATION OF cmaker COMPLETED-, 0 ERRORS DETECTED** END OF PASCAL-86 COMPILATION

## **Linking the Object File**

This example assumes that the linker, library files, and resulting link file are on disk drive 1.

#### -RUN :F1 :LINK86 cmaker.OBJ, :F1:P86RN0.LIB, :F1:P86RN1.LIB, &  $>$   $>$ :F1:EH87.LIB, :F1:E8087.LIB, :F1:E8087, :F1:RTNULL.LIB &  $>$  > to cmaker.LNK SERIES III **a** DALLINKER, Vx. V

#### **Locating the Link File**

This example assumes that the locater, linker, run-time library, and source file are on disk drive 1. Note that the PICE system does not accept load-time-locatable code.

#### -RUN :F1:LOC86 cmaker.LNK TO emaker.86 **SERIES III LOCATER-, Vx-y**

#### **Creating a SUBMIT File**

The following submit file named lnkloc links and locates an object file and assumes that the linker, the run-time library files, and the locater are on disk drive 1 and that the object file is on disk drive 0. Execute the submit file by entering the SUBMIT command. Note that the %0 parameter passes the root name of the object file named cmaker.

```
RUN
:F I :L I N K 6 L 70.OBJ-,&
                 : F I : PflLRNO • L I B -> : F I : PflLRNl • LIB-, &
                 : F I : EHfi? • LIB -> : F I : EflOfl? . L I B , : F I : EflOfl?-, &
                 : F I : RTNULL • LIB TO 7.0-LNK
: F I : LOCAL 7.0 . LNK TO 7.0-T01
EXIT
```

```
-SUBMIT :F1:lnkloc(cmaker)
-RUN
ISIS-II RUN flDflb-, Vx.y
> : F I : LINKflb cmaker • OB J &
>> : F I : PflbRNO • LIB i : F I : PflbRNl. LIB -, &
>> :Fl:EH87-LIB,:Fl:E8O87-LIB,:Fl:E8O87-&<br>>> :Fi:FiFiNULLLOFO.cmakerLNK
                > > :F1 :RTNULL.LIB TO cmaker.LNK
SERIES-III fiDfib LINKER-, Vx.y
COPYRIGHTllxxi INTEL CORPORATION
>:F1 :LOC86 cmaker.LNK TO cmaker.TOI
SERIES-III fiOflb LINKER-, Vx.y
COPYRIGHT 19xx, INTEL CORPORATION
>EXJT
-:FO:SUBMIT RESTORE :F1:lnkloc.CS(:VI:)
```
# **Getting Ready to Emulate**

Before starting emulation, you must invoke the PICE software, set up the memory and I/O maps, and load the program file.

Invoke the PICE software on the Series III by entering the following command:

#### **-RUN 12ICE**

This example assumes that you have a Series III with a system disk in drive 0 that contains host code, probe code, the error file, the help file, and the RUN program. For information on how to install and invoke software on your host system, see the appendix in this manual that explains software installation for your host. For more information on the use of the I2ICE command, see the I2ICE entry in the *PICE™ System Reference Manual.*

The host development system's console responds with the following sign-on message:

```
SERIES III I2ICE Vx-y
Copyright nfift-, llfiS INTEL CORPORATION
fib Probe Version Vx.y
*
```
The asterisk  $(*)$  is the PICE prompt.

The FICE software provides a menu at the bottom of the screen that shows all the commands and parameters you can enter at a particular command level. The following menu is the first menu you see after invoking the I<sup>2</sup>ICE software:

---- more ---- Us<mark>e [TAB]</mark> to cycle through prompts when <sup>m</sup>more" appears.<br>APPEND ARMREG BASE BRKREG CALLSTACK CAUSE CLEAREOL CLEAREOS APPEND ARMREG BASE

In most cases, the complete menu will not fit on one line. To see more of the menu, press the TAB key,

 $---$  more  $---$ CLIPSIN CLIPSOUT COUNT CURHOME DEFINE DIR DISABLE EDIT ENABLE

The FICE menu is circular. Press TAB enough times, and you will return to the first line of the menu.

Use the MENU command to suppress the menu display. Enter  $MENU = 0$  to suppress menu display and MENU  $= 1$  to display the menu. CTRL-V also changes the menu display mode. (Note that the MENU and CTRL-V commands also control automatic expansion of LITER-ALLY definitions; thus, the menu display and the automatic expansion are both on together or off together.)

Now look at the FICE memory map.

#### **\*МАР MAP OK LENGTH 1024K GUARDED**

Use the MAP command to direct memory references to high-speed memory (HS). Use the MAPIO command to transfer I/O data values between the first 128 I/O ports to the host development system's console and the FICE probe.

#### \*NIAP 0 LENGTH 32K HS **\* MAPIO 0 LENGTH 128T ICE**

Confirm this by looking at the map again (note that 80 hexadecimal is 128 decimal).

#### $xMAP$

**MAP OK LENGTH 32K HS MAP 32K LENGTH 992K GUARDED** *m m m* **MAPIO OOOOOH LENGTH OOO&OH ICE** MAPIO OOO AOH LENGTH OFF AOH USER

Load the program file by entering the following command (the example assumes that the program file is located in drive 1):

#### **\*LOAD :F1 :cmaker.86**

**Introduction to Using the FICE™ System 3-29**

# **Emulating Your Program**

First display the PICE pseudo-variable \$, which represents the current execution point.

#### \*\$ □ 020:000LH

The address 20:6 is where LOC86 placed the beginning of your program. This address is easier to remember if you give it a name (such as begin) by defining a debug variable, as follows.

 $\frac{1}{2} \left( \frac{1}{2} \right)^{2} \left( \frac{1}{2} \right)^{2}$ 

#### **\*define painter begin ® \$**

To begin emulation, enter the GO command.

#### \*GO ' ' ' '

The console requests a value for paid, then a value for purchase. Enter 75 for each. Note that the PICE system default radix is decimal.

#### PUNIT O PORT DOOZH REQUESTS WORD INPUT (ENTER VALUE) : 75 fUNIT □ PORT D002H REQUESTS WORD INPUT (ENTER VALUE) :75

The console displays the output written by the program to I/O port 40H (64T), in this case a 0 because you paid the exact amount of your purchase.

#### **PUNIT O PORT DO4OH OUTPUT WORD O**

Finally, emulation halts because of bus inactivity.

#### fProbe D stopped at location 0027:01LEH because of bus not active Bus address = 0203DE Trace Buffer Overflow

To resume emulation, you must return the execution point to the beginning of the program.

#### **\*\$« begin**

For the next emulation, create a debug register that enables you to break when the program writes coinrelease. To instruct the PICE system to break at coinrelease, you must give the fully qualified reference to the address of coinrelease (.:cmaker.coinrelease). Define the debug register (called cwrite) and begin emulation as follows:

#### **\*DEF1NE SYSREG cwrite « WRITE AT . xmaker.coinrelease \*GO USING cwrite**

The console displays a request for the value of paid and purchase. Enter 80 for paid and 75 for purchase.

fUNIT D PORT D002H REQUESTS WORD INPUT (ENTER VALUE) :80 fUNIT 0 PORT 00D2H REQUESTS WORD INPUT (ENTER VALUE) :75 \*Probe0stoppedat : CM AKER#11 because of bus break Break register is CURITE Trace Buffer Overflow

The break occurs. The program has not yet completed execution. It has already set coinrelease (presumably to 1 because this time you have a nickel coming), but it has not yet written coinrelease to the output port. You can display the value stored in coinrelease symbolically.

**\*:cmaker.coinrelease**  $+1$ 

You can also display both the value and address of coinrelease by applying the WORD memory template.

#### **\*WORD .:cmaker.coinrelease □D3E***•* **D004H 1**

Now use the disassembly command ASM to find the current execution point and the instruction stored there.



#### **QD21** *•* **0DS4H A10400 MOV AX .WORD PTR D004H**

The closest source code line to the current execution point (the address of the next instruction to be executed) is statement #11 in the module called cmaker. The current execution point is 0021:0054H. The hexadecimal content of this memory location is A 10400, which represents the following instruction:

#### **MOV AXiWORD PTR DD04H**

This instruction loads the 16-bit accumulator AX with the contents of memory location 0004H.

Now resume emulation with the GO command.

#### $*$ CO PUNIT O PORT OO4OH OUTPUT WORD OOO1H fProbeDstoppedatlocationDD27:01bEHbecauseofbusnotactive Bus address = D203DE

During this session you defined two debug objects: a debug variable named begin and a debug register named cwrite. Look at the debug objects with the DIR command.

#### **\* DIB DEBUG**



To save the definitions of the debug objects for future use, write them to a file named deb.001 with the PUT command. (This example assumes that you will be writing to drive :F1:. For information on how to specify directories and drives on the Series IV or on an IBM PC host, see the Pathname entry in the *PICE™ System Reference Manual.)*

#### \*PUT :F1:deb.001 begin,cwrite

Enter the EXIT command to return to the host development operating system.

#### \*EXIT

You cannot use the EXIT command in two cases:

- If any probe has any memory mapped to MULTIBUS (MB) memory (reset MAP by entering RESET MAP before exiting).
- If any of I/O memory is mapped to ICE while any probe is emulating (reset MAPIO by entering RESET MAPIO before exiting).

The following example shows how to put your prototype into emulation, exit FICE software, and then return without losing the program.

#### **\*G 0 fEXIT** I2ICE terminated -RUN J2JCE RESTART

Although you exited and re-invoked the FICE software without interrupting the emulation of the user program, you did lose your program's symbol table. The following example shows reloading just the symbol table and line numbers by issuing the LOAD command with the NOCODE option.

 $\mathcal{A}$ 

#### **\*LQAD ;F1:cmaker\*86 NOCODE**

**College**
# **Breaking, Tracing, and Arming**

This section explains how to set breakpoints and how to control and interpret the trace buffer.

# **The Example**

The sample program used in this section is an expansion of the program used in previous section. This version first reads the amount tendered (paid) and the amount of the purchase (purchase). The program then calculates the number of quarters, dimes, nickels, and pennies needed and sends each result to a different I/O port. The list file produced by the PLM86 compiler is as follows:

Source File: CMAKER.SRC Object File: CMAKER.OBJ Controls Specified: XREF, DEBUG.



# **Emulating a User Program**

The previous section explained that you begin emulation by using the command GO. By default, GO starts emulation from the current execution point and with the last specifications that were given with the GO command.

GO FOREVER is the default condition. The GO FOREVER command causes emulation to proceed without any breakpoint, trace, or arm specifications. Unless the following time-out pseudo-variables are enabled (which is their default condition), GO FOREVER causes emulation to continue until you enter the HALT command.

- BUS ACT allows a system time-out when the processor bus is inactive for more than one second.
- IORDY allows a system time-out when an I/O access takes more than one second.
- MEMRDY allows a system time-out when memory access time is longer than one second.
- PHANG allows a system time-out when coprocessor memory accesses exceed one second (8086/8088 and 80186/80188 probes only).

These and the other pseudo-variables displayed by the STATUS command control the emulation environment. Refer to the STATUS entry in the *PICE™ System Reference Manual* for information on the STATUS command and the pseudo-variables.

The GO specifications include breakpoint, trace, and arm specifications. You can include these specifications within the GO command itself, or you can store them in debug registers for use in later emulations.

A breakpoint specification specifies a condition that causes a break to occur. (For more information on what kinds of break specification conditions can be selected, see the GO entry in the *PICE™ System Reference Manual.)* For example, the following command specifies a breakpoint when statement #11 of the user program cmaker.86 is executed.

#### **\*6 0 TIL :cmaker#11**

A trace specification specifies a combination of one or more events that activate trace collection. (For more information on what kinds of trace specification conditions can be selected, see the GO entry in the *PICE™ System Reference Manual.)* Normally the PICE system collects trace data during emulation. However, when you include a trace specification, tracing only occurs when the trace specification is satisfied. For example, the following command activates tracing whenever the procedure payment is executed.

#### **\* 6 0 TRACE :cmaker.payment**

An arm specification specifies both a breakpoint and an arm window. The arm window determines when the PICE system can recognize the breakpoint. (For more information on what kinds of arm specification conditions can be selected, see the GO entry in the *PICE™ System Reference Manual.)* For example, the following command opens the arm window only when the procedure payment is executing. If the program variable quarters is read and the arm window is open, a break occurs.

#### **\*GO TIL ARM :ctnakenpayinent \* \*DISARM OUTSIDE icirtaker.paymeni \* \*TRKS READ AT ,:cmakenquarter\$**

#### **The Event Machines**

The PICE system contains two event machines: the execution event machine (XEM) and the system event machine (SEM). When you set breakpoint, trace, and arm specifications, you are programming one or both of these event machines.

An execution event is the execution of an instruction. You specify an execution event as an address or range of addresses. The execution event occurs when the microprocessor is ready to execute the instruction that came from the address or address range. Execution begins when the first byte of the instruction is taken from the instruction queue.

A system event describes activity on the microprocessor address lines, the microprocessor data lines, the microprocessor status lines, or the clips input lines. The PICE system can read the state of the clips input lines and break, trace, or arm on their values.

You can program the event machines directly if you need to specify a complex event. Each event machine has four states (SO through S3). Each state represents a control branch that can detect match conditions (e.g., break or trace), initiate actions, or branch to a new state. State S3 sets up a communication link between the two event machines so that decisions can be made in one machine based on the condition of the other.

In addition, each event machine has a counter that you can set and conditionally increment. Then, you can change the event machine's state if the counter is equal to the set value. (For more information on the event machines, see the Event machines entry in the *PICE™ System Reference Manual.)*

# **The Debug Registers**

A debug register is a software register that you create and name with an PICE command. The five types of debug registers are arm (ARMREG), break (BRKREG), system (SYSREG), trace (TRCREG), and event (EVTREG). You can define any number of each type, edit them, emulate with them, and write them to a disk file for later debug sessions. (Detailed information on each register type is given in the corresponding entry in the *PICE™ System Reference Manual.)*

#### **Arm Registers**

Arm registers set conditional breakpoints that enable breaking within windows. A break window is opened when an arm condition is encountered and closed when a disarm condition is encountered. For example, you can define an arm register to open the arm window when your program is executing the procedure payment. If your program reads the variable quarters while the arm window is open, a break occurs. The following example defines an arm register called arml.

**\*DEFINEARMREGarm! « \*\*ARM .cmaker.payment**  $*$  **\* DISARM OUTSIDE : cmaker.payment \*\*TRfG READ AT ,;emaker,qiiarter\$ \* \*END**

To emulate with this arm register, enter the following GO command:

#### **\*GO USING arml**

#### **Break Registers**

Break registers stop emulation when the target line of code is executed. For example, define a break register called break 1 that breaks when your program begins to execute either statement #15 or statement #19.

#### **\* DEFINE BRKREG break! « ;cmaker#15, :emaker#19**

To emulate with this break register, enter the following GO command:

#### **\*QO USING break!**

#### **System Registers**

System registers define breaks on operand access, operand data, logic clips, system breaks, and coprocessor cycles. For example, define a system register called sysl that breaks when your program reads the variable quarters.

#### **\* DEFINE SYSREG sys! « READ AT «;cmaker,quarters**

To emulate with this system register, enter the following GO command:

#### **\*G 0 USING sys!**

#### **Trace Registers**

Trace registers specify under what conditions trace information is collected. For example, define a trace register called trace  $1$  that causes the FICE system to begin collecting trace information when your program begins executing statement #12 and to stop collecting trace information at statement #13.

#### **\* DEFINE TRCHEG tracel » :cmaker#12 TO comaker#13**

To emulate with this trace register, enter the GO command:

#### **\*GO TRACE traoel**

Note that with a trace register, you must use the TRACE option of the GO command and not the USING option of the GO command.

#### **Event Registers**

Event registers control the event machines directly. For example, define an event register called qwriteinpay.



To emulate with this event register, enter the following GO command:

#### **\*GO USING gwriteinpay**

#### **Debug Registers Calling Debug Procedures**

One advantage to using debug registers is that you can store them in a file for use in later debug sessions. Another advantage is the ability to automatically execute a debug procedure when the specification in the debug register is satisfied. For example, the debug register qwriteinpay executes the debug procedure query when the event specification is satisfied. This debug procedure must return a TRUE or FALSE value. If the value is TRUE, a break occurs, and the FICE system enters interrogation mode. If the value is FALSE, a break occurs, but the FICE system restarts emulation and does not enter interrogation mode.

**\* DEFINE EVTREG qwriteinpay « DQ \* \* SEM SO IF READ AT .: cmaker.quarters IS 2 THEN GOTO S1**<br>\* \* S1 IF XLINK THEN BREAK ELSE GOTO S0 **\* \* S1 IFXUNKTHEN BREAK ELSE GOTO SO \* \*XEM SO IF :cmaker.payment THEN GOTO S3 \* \* S3 ALWAYS GOTO S3 \* \* CALL query \*\*END**

# **Interpreting the Trace Buffer**

The trace buffer contains trace information and consists of 1023 48-bit frames. Using the PRINT command, you can display the trace buffer as either disassembled instructions (IN-STRUCTIONS mode) or as execution and bus cycles (CYCLES mode).

This section contains an example of a trace display. To obtain the trace display, compile, link, and locate the Pascal program listed in the Example section in this chapter. Call the resulting program file cmaker.86.

The following commands load the example program, set the debug variable begin to \$, and start emulation. A break occurs when statement #6 begins executing. Tracing starts when statement #12 begins executing and ends when statement #15 begins executing. The example shows that the user entered 80 and 75 when prompted for input.

**\*MAP 0 LENGTH 32K HS \* MARIO 0 LENGTH 128T ICE \*LQAD cmaker.86 \* DEFINE POINTER begin « \$ \*GO FROM begin TIL :cmaker#8 TRACE :cmaker#12 TO :cmaker#15 fUNIT 0 PORT EH REQUESTS WORD INPUT (ENTER VALUE) =80 fUNIT 0 PORT 4H REQUESTS WORD INPUT (ENTER VALUE) :7S \*Probe D stopped at :Cf1AKER#Li + 3 because of execute break**

The INSTRUCTIONS trace display shown in Figure 3-1 assumes that the PICE system is running the 8086/8088 probe.

The Pascal statement #12 is the following:

 $change := paid-purchase;$ 

This high-level-language statement consists of three assembly language instructions. The first instruction reads a word from memory and places that word in the CX register. This is the access of the program variable paid. The second instruction subtracts the contents of the register  $AX$  from the contents of  $\overline{CX}$  and places the answer in  $\overline{CX}$ .  $\overline{CX}$  now contains the program variable change. The third instruction writes change to memory.

Note that the data write belonging to statement #12 occurs during the execution of statement # 13. The 8086 architecture provides for an execution unit and a bus interface unit. These two units operate independently of each other. The 8086 microprocessor realizes that the MOV instruction is finished except for a memory access. The execution unit takes the next instruction off the queue while the bus interface unit writes to memory.

Figure 3-2 displays the trace buffer in CYCLES mode. The trace buffer contains the same trace data as the previous example. The only difference is that the data is now displayed in CYCLES mode rather than INSTRUCTIONS mode.

The first frame (f 000) is an execution cycle. The execution address is 00024F. This frame shows the execution of the following instruction:

MOV CX,WORD PTR 0012H

| <b>ADR</b><br><b>FRAME</b> | <b>BYTE</b>                                                                                                                                                                                        |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    | UNIT O                                                                                                                                                                                                                                                                                                             |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| :CMAKER#12                 |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
| :CMAKER#13                 |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
| <b>:CMAKER#14</b>          |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            | A30E00                                                                                                                                                                                             |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
| :CMAKER#15                 |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            |                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                 |                                                                            |                                                                                                                                    |                                                                                                                                                                                                                                                                                                                    |
|                            | 000 0021:003FH<br>004 0021:0043H<br>OO6 0021:0045H<br>OOA 0021:0049H<br>OOC 0021:004BH<br>OOE 0021:004CH<br>010 0021:004FH<br>013 0021:0051H<br>014 0021:0053H<br>O1D 0021:005BH<br>OLF 0021:005DH | <b>*PRINT INSTRUCTIONS ALL</b><br>M 2BCB<br>8BCl<br>99<br>BEL400<br>F7FE<br>OBD2<br>7DO2<br>O18 OO21:0057H<br>8BC2 -<br>000446H-DW-0005H<br>99 -<br>021 0021:005EH B91900<br>023 0021:0061H F7F9<br>026 0021:0063H<br>028 0021:0066H A10600<br>00044EH-DW-0000H | M ABOE1200<br>890E0400<br>$0004444 - D0 - 0005H$ $\rightarrow$<br>֎ግ]բՕԲՆԲ | MOV -<br><b>SUB</b><br><b>MOV</b><br><b>CUD</b><br><b>MOV</b><br><b>IDIV</b><br>JGE<br>mov.<br>CWD.<br>MOV .<br><b>IDIV</b><br>mov | MNEMONICS OPERANDS<br>CX-WORD PTR OO12H<br>$CX - AX$<br>$WORD$ PTR $DD$ PH $\sim$ CX<br>MOV AX-CX<br>$S1,0064H$ ; +100T<br><b>SI</b><br>OR DX-DX<br>$#+0004H$ ; A=0057H<br>MOV UORD PTR ODLOLH, DX<br>$AX - DX$<br>$CX - 0019H : +2ST$<br>- CX<br>WORD PTR OOOEH, AX<br>MOV AX, WORD PTR OOOLH<br>000446H-DR-0005H |

**Figure 3-1 Sample Trace Buffer INSTRUCTIONS Display Showing the Data Write for Instruction #12**

When displayed in INSTRUCTIONS mode, the trace buffer shows this instruction's address as a selector:offset pair, 0021:003F. The 8086 microprocessor calculates the 20-bit address by shifting the selector left four bits and adding the offset as shown in the following example:

00210 + 003F 0024F

Figure 3-2 shows this calculation in the margin.

The next frame (f 001) is a bus cycle. The symbol DW identifies it as a write to the data segment. (DW is an access code. The access codes are probe-specific and are defined in the entry entitled Trace buffer display in the *FICE™ System Reference Manual.)* The data is 004B (75 in decimal). This is the write of the program variable purchase. It is the write associated with the previous Pascal statement: INWRD(4, purchase).



#### **Figure 3-2 Sample Trace Buffer Display in CYCLES Mode Showing Frames f 006-008 and f 00B**

The next frame (f 002) is a fetch from the code segment. The data is 89C8. The C8 belongs to statement #12's second instruction, SUB CX,AX. The 89 begins statement #12's third instruction, MOV WORD PTR 0004H,CX.

The next frame (f 003) is a data read. The data is 0050 (80 in decimal). This is the read of the program variable *paid.* Note that this read does not appear in the trace buffer when the buffer is displayed in INSTRUCTIONS mode because the first entry in the trace buffer is an execution cycle. The trace buffer was not active when the probe fetched that instruction. Hence, the PICE system must go to memory to disassemble the instruction (which is what the M signifies in INSTRUCTIONS mode). When the PICE system goes to memory, it does not use any of the trace buffer for disassembly until the next execution cycle. The read would be visible if the trace were started early enough to allow the trace buffer to record the fetch of the instruction that does the read.

The next frame (f 004) is an execution cycle. This is the execution of the instruction SUB CX,AX

Frame 00B (underlined in Figure 3-2) is the data write focused on in Figure 3-1. This frame is the data write performed by the instruction MOV WORD PTR 000EH, CX. Its execution frame is f 006 (also underlined in Figure 3-2). The previous trace display listed the instruction's logical execution address as 0021:0049. This trace display shows 259, the corresponding physical address.

Notice the two code fetches occurring in frames 007 and 008. (In Figure 3-2, the bus address and data for these two frames are high-lighted.) In f 007 the microprocessor reads 8B00 from memory. In f 008 the microprocessor reads 99C1. iAPX microprocessors store the least significant byte of a word in the lower address. To see how memory looks, use the following BYTE command.



When the iAPX microprocessor reads a word from memory, the byte at the even address travels on the lower half of the data bus, and the byte at the odd address travels on the upper half. When the iAPX microprocessor reads the word at 258, the data bus looks like the following:



When the iAPX microprocessor reads the word at 25A, the data bus looks like the following:



The lower byte on the data bus  $\langle D7-D0 \rangle$  enters the instruction queue before the upper byte  $\langle$  D15-D8 $\rangle$ . The following example illustrates the queue:



The word 8BC1 represents the instruction MOV AX,CX, the first instruction of statement :cmaker#13. The byte 99 represents the instruction CWD, the second instruction of statement :cmaker#13.

The trace buffer normally collects both execution cycles and bus cycles. It overflows after 1023 frames have been collected. When the trace buffer overflows, it shifts all the frames toward frame 0. The old frame 0 is lost. The 1023rd frame is always the latest frame.

# **The Timetag**

In the CYLES mode display, the column labeled TIME shows the execution time. Frame 0 always begins at time 0.

The PICE system contains a free-running counter that returns to zero after 2K (2048) counts. The time increment for each count is set by the TIMEBASE pseudo-variable. Its default is 200 nanoseconds. The largest value you can set TIMEBASE to is 6 milliseconds. TIMEBASE must be a multiple of 100 nanoseconds.

When the PICE system begins tracing, the value of this free-running counter goes directly into the trace buffer. The PICE system, however, offsets the value so that frame 0 always begins at time 0.

If you interrupt the trace, the PICE system starts another clock that runs until tracing resumes. If a wrap-around occurs (i.e., the counter reaches 2048), the PICE system sets the level flag. When you resume tracing, the LEVEL column is incremented by one (regardless of how many wrap-arounds occurred), and the TIME column is reset to 0.0. You will have lost time calibration because you do not know how many wrap-arounds occurred while the trace was interrupted. Note that these difficulties caused by wrap-around can be avoided by setting TIMEBASE to a higher value.

# **The Pseudo-Variable TRCBUS**

If you are not interested in bus activity and you want to collect more execution cycles before overflowing, set the PICE pseudo-variable TRCBUS to FALSE. Its default is TRUE.

#### **Trace Buffer Information**

For more information on the trace buffer, see the entries PRINT and Trace buffer display in the *FICE™ System Reference Manual.*

# **Hardware Slipping On a Breakpoint**

Because emulation is in real time, for the 8086/8088 and 80186/80188 probes you cannot break exactly where you specified. To break on the execution of an instruction, the FICE system must first recognize that the instruction is executing. (The 80286 probe has a special feature that prevents hardware slipping.)

The following example illustrates hardware slipping.

#### **\*GO FROM begin Tit :cmeker#13 TRACE :anaker#12to :ctneker#13 fUNIT D PORT SH REQUESTS WORD INPUT (ENTER VALUE) =80 fUNIT □ PORT 4H REQUESTS U0RD INPUT (ENTER VALUE) =75 Probe □ stopped at :CNAKER#13 + 3 because of execute break**

The FICE system is designed to break right after the execution of the specified instruction, and specifying statement #13 specifies the first assembly language instruction making up statement #13. The FICE system informs you that the probe stopped three bytes past the beginning of statement #13. The trace buffer gives you more information.

#### \* PRINT INSTRUCTIONS ALL



The FICE system slipped three bytes. The first two bytes make up the instruction MOV AX, CX. These are bytes : CMAKER#13 + 0 and : CMAKER#13 + 1. The next byte  $(\cdot$ CMAKER#13 + 2) is the instruction CWD. Execution will resume at :CMAKER#13 + 3.

# **Even Addresses, Odd Addresses, and Breaking**

The iAPX architecture causes a word written to an even address to appear on the data bus once in the normal order (high byte, low byte). A word written to an odd address appears on the data bus twice in reversed order (low byte, high byte) because of the standard 86 architecture. Note this when you specify a breakpoint to occur when the data bus contains a certain value.

When you write a byte to an even address, the byte appears on the lower eight bits of the data bus. When you write a byte to an odd address, the byte appears on the upper eight bits of the data bus.

The examples in this section assume the 8086/8088 probe.

#### **Word Writes to Even and Odd Addresses**

First verify that the base is hexadecimal and load the register AX with AB12H, as follows.

```
* BASE » DECIMAL;BASE
HEX
*AX = 0AB12H
*AX
ABIE
```
The next example fills a section of memory with a number of NOPs and a MOV instruction. The first BYTE command loads the NOPs. The second BYTE command loads the MOV instruction. This MOV instruction moves the value from AX to the even address, OFCOO.



The next example starts emulation and breaks when a word is written on the data bus whose upper byte is AB.

#### **\* DEFINE SYSREG even = WRITE 1\$ OABXX \* GO PROM 32K USING even Probe D stopped at location 0A00:0405H because of bus break Break register is EVEN Trace Buffer Overflow**

The following example looks at the last five instructions in the trace buffer (see Figure 3-3). Notice the MOV instruction and the data write of AB12 (the data write is underlined in Figure 3-3).



**Figure 3-3 Sample Trace Buffer Display in INSTRUCTIONS Mode for Emulation with the System Register EVEN**

The next example looks at the last 16 cycles in the trace buffer (see Figure 3-4).

The following example modifies the MOV instruction so that the write is to the odd address 0FC01H.



The following example defines a system register called *odd.* This register specifies a break when the data bus contains the value 12ABH.

#### **\* DEFINE SYSREG odd \* WRITE IS 12AB \*GG FROM 32K USING odd**

**Probe □ stopped at location DfiDD:04D4H because of bus break Break register is ODD Trace Buffer Overflow**

The following example looks at the trace buffer in INSTRUCTIONS mode and then in CY-CLES mode (see Figure 3-5). Note that because you have written to an odd address, two write cycles occurred and the bytes on the bus are reversed.



#### **Figure 3-4 Sample Trace Buffer Display in CYCLES Mode for Emulation with the System Register EVEN**

 $\overline{a}$ 

The following list summarizes how to handle breaks on word writes to even and odd addresses.

 $\sqrt{2}$ 



| <b>*PRINT INSTRUCTIONS NEWEST 5</b><br><b>BYTE</b><br><b>FRAME</b><br><b>ADR</b><br>90<br>3F3.<br><b>OO83FDH</b><br>90<br>3F.S.I<br><b>OO&amp;3FEH</b><br>3FL OO&3FFH<br>90<br>3F8 008400H<br><b>ABOLFC</b><br>OOFCO1H-DW-12ABH |                 |         |                                 |    |          |              | MNEMONICS OPERANDS<br><b>NOP</b><br><b>NOP</b><br><b>NOP</b><br><b>MOV</b><br><b>WORD PTR OF COLH, AX</b><br>$\rightarrow$ 8086 writes the 12. |      |                 |             |            |                                   |       | UNIT <sub>D</sub> |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------|---------------------------------|----|----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------|-------------|------------|-----------------------------------|-------|-------------------|
|                                                                                                                                                                                                                                 | 3FB 008403H     |         | $\overline{00}$ FCO2H-DW-12ABH· | 90 |          |              |                                                                                                                                                |      |                 | <b>NOP</b>  |            | $\rightarrow$ 8086 writes the AB. |       |                   |
| *                                                                                                                                                                                                                               |                 |         | <b>*PRINT CYCLES NEWEST 10</b>  |    |          |              |                                                                                                                                                |      |                 |             |            |                                   |       |                   |
|                                                                                                                                                                                                                                 | <b>FXEC ADR</b> |         | <b>BUS ADR</b>                  |    | DATA     |              | <b>ZUTATZ</b>                                                                                                                                  |      |                 | CLIPS FRAME |            | <b>TIME</b>                       | LEVEL | UNIT O            |
|                                                                                                                                                                                                                                 | x 0083FA b      |         |                                 | đ  |          | s            |                                                                                                                                                |      | c               |             | f 3EF      | 402.4 microsecs                   | o     |                   |
| ×                                                                                                                                                                                                                               |                 | b.      | 0083FE d 9090 s 0054 CF c       |    |          |              |                                                                                                                                                |      |                 |             | f 3FO      |                                   |       |                   |
|                                                                                                                                                                                                                                 | x OD&3FB b      |         |                                 | d  |          | s            |                                                                                                                                                |      | c               | f           | 3Fl        | 403.0microsecs                    | Ω     |                   |
|                                                                                                                                                                                                                                 | x 0083FC b      |         |                                 | đ  |          | s            |                                                                                                                                                |      | c               | f           | 3F2        | 403.6 microsecs                   | о     |                   |
| x                                                                                                                                                                                                                               | x OO&3FD        | b<br>b. | 008400 d 01A3 s                 |    |          | s            | 00S4 CF                                                                                                                                        |      | c<br>$\epsilon$ | f<br>f      | 3F3<br>3F4 | 404.2microsecs                    | п     |                   |
|                                                                                                                                                                                                                                 | x OO&3FE b      |         |                                 | d  |          | s            |                                                                                                                                                |      | C               |             | 3F 5       | 404.Amicrosecs                    | 0     |                   |
|                                                                                                                                                                                                                                 | x OO&3FF b      |         |                                 |    |          | s            |                                                                                                                                                |      | c               | f           | 3FL        | 405.4 microsecs                   | п     |                   |
| ×                                                                                                                                                                                                                               |                 | b.      | 008402 d                        |    |          |              | <b>AOFC S 0054 CF</b>                                                                                                                          |      | с               | f.          | 3F 7       |                                   |       |                   |
|                                                                                                                                                                                                                                 | x 008400 b      |         |                                 | đ  |          | s            |                                                                                                                                                |      | c               | f           | 3F8        | 406.0microsecs                    | o     |                   |
| ×                                                                                                                                                                                                                               |                 | b       | 008404 d                        |    | 9090 s   |              | 0054                                                                                                                                           | CF.  | с               |             | 3F9        |                                   |       |                   |
| ×                                                                                                                                                                                                                               |                 | b.      | OOFCOL d L2AB s OOSE DW c       |    |          |              |                                                                                                                                                |      |                 |             | <b>JFA</b> |                                   |       |                   |
|                                                                                                                                                                                                                                 | EDPADO x        | b       |                                 | d  |          | s            |                                                                                                                                                |      | c               |             | f 3FB      | 409.0 microsecs                   | Ð.    |                   |
| x                                                                                                                                                                                                                               |                 |         | b OOFCO2                        |    | d 12AB s |              | 00 S E                                                                                                                                         | DW ⊂ |                 |             | f 3FC      |                                   |       |                   |
| ×                                                                                                                                                                                                                               |                 |         | b 008406 d                      |    | 9090     |              | s 0054                                                                                                                                         | CF   | $\epsilon$      |             | f 3FD      |                                   |       |                   |
| x                                                                                                                                                                                                                               |                 | b.      | 008408 d                        |    | 9090     | $\mathbf{s}$ | 0054                                                                                                                                           | CF c |                 |             | - 3FE      |                                   |       |                   |
|                                                                                                                                                                                                                                 |                 |         |                                 |    |          |              |                                                                                                                                                |      |                 |             |            |                                   |       |                   |

**Figure 3-5 Sample Trace Buffer Displays in Both Modes for Emulation with the System Register ODD**

# **Byte Writes to Even and Odd Addresses**

The following example uses a BYTE PTR instead of a WORD PTR in the MOV instruction, puts AB12 into AX, and writes AL (which contains 12) to memory instead of AX.



When you write to an even address, the data bus contains AB12. When you write to an odd address, the data bus contains 12AB.

The following list summarizes how to handle breaks on byte writes to even and odd addresses.



# **Word Reads From Even and Odd Addresses**

Assume that you want to break when the user program reads a particular word from memory and that the word AB12 is stored at an even address. The word AB12 appears once on the data lines. Assume that the even address is FCOO and that memory looks as follows:

FCOO 12 FC01 AB FC02 34 FC03 56

The following example fills HS memory with NOPs.

**\*BASE HEX \*MA***P* **32K LENGTH 32K HS \*BYTE 32K LENGTH 32K-90H \*BYTE 0FC00 «12,0AB,34,56 \*BYTE 0FCO0 LENGTH 4 □0FC00H 1EAB 34 5L '--4V'**

The following example uses the single-line assembler to put the MOV instruction in memory offset 33K. The MOV instruction reads the word at FCOO into AX.

**\*SASM 33K= MOV AX,WORD 0FCO0' OOflMOOH fiBOLDOFC**

Note that the 8086 assembler (ASM-86) reads the instruction as MOV AX, WORD PTR 0FC00. The PICE single-line assembler does not recognize the assembler operator PTR. In this case, what is a correct form for the PICE single-line assembler is an incorrect form for ASM-86. The following example checks the entry using the ASM memory template.

#### **\*ASM 33K BROLOGIC MOV AX-WORD PTR DECODH**

Notice that the PTR operator appears when the instruction is disassembled.

The following example sets the accumulator to 0 and displays its value.

#### $*AX = 0$ : $AX$ □ 0 0 0

The following example defines a system register that causes a break when the program reads the word AB12 from FC00.

#### **\* DEFINE SYSREG evenword « \* \*READ AT 0FCOQ IS 0AB12**

The following example shows emulation starting from 32K using the system register *evenword.*

#### **\*GO FROM 32K USING evenword**

**\*Probe 0 stopped at location 0A00:0405H because of bus break Break register is EVENUORD Trace Buffer Overflow**

The following example checks AX to see whether it received the word.

#### **XAX ABIE**

The following example looks at the trace buffer in INSTRUCTIONS mode and then in CYLES mode (see Figure 3-6). Note that the word AB12 appears on the data bus once.

Memory remains the same after the last example. The following example uses the single-line assembler to modify the MOV instruction to read a word from the address FC01. This word is 34AB. The most significant byte, 34, is at FC02, and the least significant byte, AB, is at FC01.

**\*SASM 33K« MOV AX,WORD 0FC01' 0DA400H BBObDlFC \* ASM 33K BBOLOLFC MOV AXINORD PTR OFCOLH** 



**Figure 3-6 Sample Trace Buffer Displays in Both Modes for Emulation with the System Register EVENWORD**

Because the word is at an odd address, there are two memory accesses. In the first access, the least significant byte, AB, appears on the upper data lines. In the second access, the most significant byte, 34, appears on the lower data lines. The following example defines an event register that causes a break when those two conditions occur.

```
* DEFINE EVTREG ODDWORD * DO
* *SEM SO IF READ AT 0FC01 IS OABxx
** THEN GOTO S1
** SI IF READ AT 0FC02 IS 0xx34
** THEN BREAK
        ELSE GOTO S0
**END
```
The following example sets AX to 0.

**\*AX«0;AX** □ □ 0 0

**The following example starts emulation from 32K using the event register.**

#### **\*GO FROM 32K USING oddworrf**

#### **Probe 0 stopped at location DADD :0405H because of bus break Break register is ODDUORD Trace Buffer Overflow**

The following example checks AX to see whether the register received the word and then prints the trace buffer in INSTRUCTIONS and CYCLES modes (see Figure 3-7).

The following list summarizes how to handle breaks on word reads from even and odd addresses.



### **Byte Reads From Even and Odd Addresses**

Memory remained unchanged after the last example. The following example modifies the MOV instruction so that it reads a byte from FCOO into AL. The memory offset FCOO contains 12. It appears once on the lower data lines.





#### **Figure 3-7 Sample Trace Buffer Displays in Both Modes for Emulation Using the Even Register ODDWORD**

The following example sets AX to 0 and then defines a system register that causes a break when the data bus contains 12 on the lower lines. The X's represent don't-care bits.

 $*AX = 0$ **\* DEFINE SYSNEG evenbyte « \* \*READ AT 0FCO0 IS 0XX12**

The following example starts emulation with this system register, displays AX, and displays the trace buffer in both INSTRUCTIONS and CYCLES mode (see Figure 3-8). Note that AX's least significant byte has the correct value.

The following example modifies the MOV instruction to read the byte from the odd address 0FC01. That byte is AB.





**Figure 3-8 Sample Trace Buffer Displays in Both Modes for Emulation with the System Register EVENBYTE**

There is one memory access. The byte appears on the upper data lines. The following example defines a system register that causes a break when that condition occurs, sets AX to 0, begins emulation, and displays the trace buffer in both INSTRUCTIONS and CYCLES mode (see Figure 3-9).

The following list summarizes how to handle breaks on byte reads from even and odd addresses.



# **Moving the User Cable**

If you remove the user cable while the FICE system is running, the probe's microprocessor loses its system clock. This may require reloading the FICE software. At times, however, you may need to remove the user cable, such as when you transfer the user cable from the prototype system to the buffer box.

Use the UNITHOLD command before removing the user cable. Once the user cable is in place, enter any character to continue operation, as shown in the following example:

```
*UNJTHOLD
Enter any character to release probes -
```
The UNITHOLD command's effect on the probe hardware is probe-specific as follows:





**Figure 3-9 Sample Trace Buffer Displays in Both Modes for Emulation with the System Register ODDBYTE**

# **THE l**2**ICE™ SYSTEM PERSONALITY MODULES (PROBES)**

This chapter introduces the three PICE personality modules. (The personality modules are also referred to as probes). The 8086/8088 probe emulates the 8086 and the 8088 microprocessors. The 80186/80188 probe emulates the 80186 and the 80188 microprocessors. The 80286 probe emulates the 80286 microprocessor.

In this chapter, a separate main section is devoted to each of the probes. Within each main section, there is a subsection that explains special considerations that apply to the probe.

# **The 8086/8088 Probe**

The 8086 and 8088 microprocessors feature a large segmented memory space, a versatile instruction set, and instruction pipelining. The iAPX family includes the 8087 coprocessor, which optimizes numeric processing.

With the PICE pseudo-variables you can display and modify 8086/8088 registers symbolically. The following example loads the word AB12 into the AX register.

```
*AX~0AB12
*AX
ABIE
```
The following example displays the high and low bytes of the AX register.

*\* m* **AB** ♦Mi **IE**

You can use the Boolean operators AND, OR, and XOR with these registers. The following example sets the trap flag in the FLAGS register while retaining the setting of any previous flags.

#### **♦FLAGS m FLAGS OR 100H**

Alternatively, the following example sets the Boolean pseudo-variable representing the trap flag to TRUE.

#### **\*TFL«TRUi**

The PICE system also provides pseudo-variables to display and modify 8087 registers. Refer to Chapter 5 for more information about manipulating 8087 registers.

■ intai™ ■

# **Hardware and Software Considerations for the 8086/8088 Probe**

This section describes the unique characteristics of the 8086/8088 probe. You should be aware of these characteristics when designing prototype hardware and software and when emulating your prototype.

Separate subsections are provided on the following topics:

- Address Wrap-around
- Break Information
	- Slipping Past Instruction Breakpoints
	- Slipping Past Breakpoints on Combined Instructions
	- Breaking in the Middle of an Instruction
- READY Signal Set-Up Time
- Request/Grant Line
- Non-Maskable Interrupt Line and Interrupt Line
- Non-Maskable Interrupts and Program Stepping
- Synchronization between the Prototype and the Probe
- User-Accessible Test Points
	- The SYNC START/ Test Point
	- The 87 INT Test Point
- Coprocessor Considerations
- Inability to Break When RESET Is Asserted
- Getting a User NMI While in Emulation Mode
- Using the FICE™ System as a Signal Generator
- 10-MHz 8086 Probe MAX Mode Operation
- Probe MIN Mode Operation
- Address/Data Bus Float

#### **Address Wrap-Around**

The 8086/8088 microprocessor represents a virtual memory address as a selector:offset pair. The selector and the offset are each 16 bits long. The 8086/8088 microprocessor then trans . lates that virtual address into a 20-bit physical address. A memory address in the break/trace board is 20 bits long.

As shown in Table 4-1, the difference between the way the 8086/8088 microprocessor and the break/trace board handle memory addresses causes discrepancies when wrap-arounds occur.



#### **Table 4-1 8086/8088 Segment Boundary Increments**

Wrap-arounds do not affect bus information, but they can make break and trace information hard to follow. Address wrap-arounds can occur only when the offset is incremented past FFFF. This is not a recommended practice for any 8086/8088 application.

#### **Break Inform ation**

A break normally occurs immediately after the target instruction executes. The following sections describe the three cases when a break is not recognized until one or more instructions after the breakpoint.

#### **Slipping Past Instruction Breakpoints**

A break sometimes slips past the specified breakpoint because the probe emulates at full processor speed and PICE probe hardware cannot always break on the exact instruction specified. In general, the greater the number of cycles required to execute an instruction, the lower the chances of slipping. The newest trace frame contains the last instruction executed. The break message contains the address of the next instruction to be executed.

#### **Slipping Past Breakpoints on Combined Instructions**

Although you can specify a breakpoint between parts of combined instructions, the PICE hardware never sees it. The following combined instructions cause slipping:

- Repeat prefixes
- LOCK prefixes
- Segment override prefixes
- MOV to a segment register
- POP a segment register
- FWAIT prefix on an 8087 instruction

#### **Breaking in the Middle of an Instruction**

In two cases the PICE probe can break in the middle of an instruction: WAIT and repeated string instructions. These instructions contain primitive operations or wait test cycles which can be recognized, incorrectly, as a breakpoint.

#### **READY Signal Set-Up Time**

The BTHRDY (both READY) pseudo-variable ANDs the user's processor READY signal with the 8086/8088 probe's ready signal. When BTHRDY is TRUE, the 8086/8088 probe's READY signal must be set up .3 nanoseconds before the rising edge of T2, as shown in Figure 4-1.

If the probe processor's READY signal is not set up .3 nanoseconds before the rising edge of T2, the signal is missed and the result of the logical AND is false. This causes an additional wait-state in a normally not-READY system and no wait-states in a normally READY system. Set-up time is normal when BTHRDY is FALSE.

#### **Request/Grant Line**

The internal 8087 coprocessor uses the request/grant (RQ/GT1) line. You cannot connect bus masters in a daisy chain on the RQ/GT1 line when you use an internal 8087.

#### **Non-M askable Interrupt Line and Interrupt Line**

If a non-maskable interrupt (NMI) and an interrupt (INTR) are asserted at the same time, the PICE system starts to service the INTR first. This results in additional latency while the stack operations and interrupt acknowledge cycles occur. The NMI is serviced after the INTR vector and initial stack activity are complete. The INTR service is completed after the NMI is serviced.

#### **Non-M askable Interrupts and Program Stepping**

The 8086/8088 probe ignores NMIs when stepping through a user program with the ISTEP command. The following GO command, which steps through 10 consecutive break locations, enables you to step through programs while recognizing NMIs.

COUNT 10 **GO Tit 0XXXX ENO**

#### **Synchronization between the Prototype and the Probe**

When the probe is executing code from high-speed (HS) memory but the user prototype expects memory with a different access time in the same address space, the user's bus control logic can get out of synchronization with the probe. A solution is to set the BTHRDY pseudovariable to TRUE.

If the user prototype expects slow memory, another solution is to insert an appropriate number of wait-states into the HS memory accesses.

#### **User-Accessible Test Points**

The top of the buffer box has two user-accessible user test points. They are labeled SYNC START/ and 87 INT.



**Figure 4-1 Ready Signal Set-Up Time**

#### **The SYNC START/ Test Point**

The SYNC START/ test point is a TTL input that is normally high. When SYNC START/ is low and the probe enters emulation, READY is held low, and the probe undergoes a READY hang after the first instruction fetch. You can cause this hang by holding SYNC START/ low.

To synchronize the probes in a multi-probe system, first set MEMRDY to FALSE in each probe. This prevents a memory time-out from occurring during the first instruction fetch. Then, keep SYNC START/ on each probe low. Ensure that SYNC START/ for each probe goes high at the same time. This raises READY, gets rid of the READY hang, and ensures that each probe enters emulation at the same time.

A typical application is to connect all the SYNC START/ test points to one of the clipsout lines. This allows you to control the state of the SYNC START/ signal from the PICE console with the CLIPSOUT command.

#### **NOTE**

If, while SYNC START/ is low, a coprocessor requests the address and data buses, the probe's microprocessor will not acknowledge that request until you raise SYNC START/. This is important if the coprocessor is performing a time-critical operation.

You may also find SYNC START/ useful in a single probe system because it gives you hardware control over when the probe enters emulation. SYNC START/ must be high for emulation to begin.

#### **The 87 INT Test Point**

The 87 INT test point is a TTL output. An internal 8087 coprocessor asserts this signal. When high, this signal indicates that an unmasked exception has occurred during internal 8087 instruction execution when 8087 interrupts are enabled.

#### **Coprocessor Considerations**

When using a coprocessor with the 8086/8088 probe, be aware of the following:

- During emulation, a two-clock delay precedes each RQ, GT, and release pulse in MAX mode and each HOLD and HLDA assertion in MIN mode. During emulation, a user's RO and release pulse will not be seen by the probe processor until two clock cycles after they have occurred.
- Normal MIN mode coprocessor protocol requires that HLDA become inactive before asserting the next hold.
- You can choose to run the external coprocessor only during emulation or during both emulation and interrogation. (The CPMODE pseudo-variable selects coprocessor mode.) When the coprocessor runs during interrogation mode, it may have as much as a onemicrosecond delay in addition to the two-clock delay.
- The PICE system ignores a coprocessor when the probe is in the reset state. If a coprocessor asserts  $\overline{RO}$  during this time, the  $\overline{RO}/\overline{GT}$  sequence may get out of synchronization. The probe is reset while the PICE host software loads PICE probe software.
- When the CPMODE pseudo-variable is 1 (coprocessor activity in emulation mode only) and the PICE system is in interrogation mode, the 8086/8088 probe latches any pending coprocessor requests. If you do not want these pending requests honored, you must reset the external coprocessor and then the 8086/8088 probe (with the RESET UNIT command).
- Coprocessor activity is not traced when the 8086/8088 probe is in MIN mode.

#### **Inability to Break When RESET Is Asserted**

If a break occurs while RESET is high, the PICE system does not recognize the break. The break does not occur even after RESET goes low. You must reset the PICE system with the RESET UNIT command to exit this condition.

#### **Getting a User NMI while in Emulation Mode**

If a user NMI arrives while the PICE system is in interrogation mode, that user NMI is not serviced. Rather, it is latched by the PICE system and will be serviced when emulation is resumed. If you do not wish to service these latched NMIs, they can be cleared with a RESET UNIT or a UNITHOLD command before resuming emulation with the GO command.

#### **Using the PICE™ System as a Signal Generator**

You can use the 8086/8088 probe as a signal generator by connecting it to prototype hardware and mapping both memory and I/O to the emulator's internal resources. In this mode, all the control signals, status lines, address lines, and write data lines are valid even though the prototype hardware may not function correctly. The emulator runs by accessing correct data from the emulator resources and ignoring data from the prototype system. This enables you to perform microprocessor functions that the current prototype hardware does not support.

#### **10-MHz 8086 Probe MAX Mode Operation**

For the 8086 probe running at 10 MHz and in MAX mode, the user must supply a clock with a minimum low time of 60 nanoseconds. Less clock low time may cause a wrong address to be latched by ALE. If you wish to use less clock low time, delay ALE in the user system by an amount of time greater than or equal to the difference between 60 nanoseconds and the reduced clock low time that you are using. This can be done by adding a buffer to ALE in the user system.

#### **Probe MIN Mode Operation**

When performing consecutive reads to program memory, the  $DT/\overline{R}$  line of the probe microprocessor (at the end of the user cable) goes high for a short time between reads. The 8086/8088 microprocessors keep  $DT/\overline{R}$  low between consecutive reads. When performing consecutive I/O cycles (i.e., word I/O to an odd address), the M/IO line goes high for a short time during T4. The 8086/8088 microprocessors keep M/IO low between consecutive I/O cycles.

#### **Address/Data Bus Float**

The address/data (AD) bus is floated during T4 as follows:



#### NOTE

Proper use of the DEN and  $DT/\overline{R}$  signals result in the normal operation (i.e., no bus contention) of both the emulator and the prototype hardware.

# **The 80186/80188 Probe**

The 80186 and 80188 microprocessors extend the capabilities of the 8086 and 8088 microprocessors and are upwardly compatible with iAPX 86 and 88 software. They add instructions for fast index calculation, subroutine linkage, I/O data transfers, and program error detection.

The 80186 integrates a number of the most common iAPX 86 components onto a single chip. These include two independent high-speed DMA channels, a programmable interrupt controller, three programmable 16-bit timers, chip selects, peripheral chip-select logic, a programmable wait-state generator, a clock generator, and a local bus controller.

The 80186/80188 contains four interrupt pins. The PICE system assumes that these pins are configured either as all inputs (for fully nested mode) or as two inputs and two outputs (for cascade mode and special fully-nested mode). The outputs are interrupt-acknowledge signals, one for each of the remaining interrupt input lines.

The 80186/80188 has another alternate signal set. During reset, the 80186/80188 samples  $\overline{RD}$ / QSMD to determine whether it will run in standard or queue status mode. In queue status mode, the 80186/80188 provides queue status signals in place of ALE and WR.

The PICE pseudo-variable QSTAT determines whether the 80186 probe runs in standard or queue status mode. The default is FALSE.

 $OSTAT = TRUE$  The 80186 probe runs in queue status mode.

 $OSTAT = FALSE$  The 80186 probe runs in standard mode.

With the PICE pseudo-variables you can display and modify 80186/80188 registers and flags. The following example displays the DX register.

#### **\*DX** ABIE

Some 80186/80188 registers are represented as offsets into an internal register map. The following example displays the lower memory chip select (LMCS) register.

# \*CSCTRL(2)<br>3A

The 80186/80188 probe provides debugging support for the 8087 coprocessor. The 8087 must be an external coprocessor, and the prototype must contain the 82188 coprocessor interface chip. Refer to Chapter 5 for more information about manipulating 8087 registers.

A coprocessor memory violation can occur if a HOLD/HLDA sequence occurs and the S0-S2 lines present a non-idle state with a non-USER mapped address on the bus. To prevent the coprocessor memory violation, all memory should be mapped to USER.

# **Hardware and Software Considerations for the 80186/80188 Probe**

This section describes the unique characteristics of the 80186/80188 probe. You should be aware of these characteristics when you design prototype hardware and software and when you emulate your prototype.

Separate subsections are provided on the following topics:

- Address Wrap-around
- Break Information
	- Slipping Past Instruction Breakpoints
	- Slipping Past Breakpoints on Combined Instructions
	- Breaking in the Middle of an Instruction
- Mapping Considerations for the 80186/80188 Probe
- Synchronization between the Prototype and the Probe
- User-accessible Test Points
- User Socket
- ALE Pulse Stretching

#### **Address Wrap-Around**

The 80186/80188 microprocessor represents a memory address as a selector:offset pair. The selector and the offset are each 16 bits long. A memory address in the break/trace board is a 20-bit address.

As shown in Table 4-2, the difference in memory address lengths causes discrepancies when wrap-arounds occur.

Wrap-arounds do not affect bus information, but they can make break and trace information hard to follow. Avoid wrap-arounds by not executing instructions near segment boundaries.

#### **Break Information**

A break normally occurs immediately after the target instruction executes. The following sections describe the three cases where a break is not recognized until one or more instructions after the breakpoint.

#### **Slipping Past Instruction Breakpoints**

A break sometimes slips past the specified breakpoint because the probe emulates at full processor speed and PICE probe hardware cannot always break on the exact instruction specified.

An extra instruction is executed when the number of bytes in the target instruction and the number of cycles required to execute that instruction match. For instance, a two-byte instruction that executes in two bus cycles causes the PICE probe to slip. Other combinations of instruction bytes and bus cycles can also cause a breakpoint to slip. In general, the greater the number of cycles required to execute an instruction, the lower the chances of slipping.

The newest trace frame contains the last instruction executed. The break message contains the address of the next instruction to be executed.

#### **Slipping Past Breakpoints on Combined Instructions**

Although you can specify a breakpoint between parts of combined instructions, the PICE hardware never detects it. The following combined instructions cause slipping:

- Repeat prefixes
- LOCK prefixes
- Segment override prefixes
- MOV to a segment register
- POP a segment register

#### **Breaking in the Middle of an Instruction**

In two cases the PICE probe can break in the middle of an instruction: with the WAIT command and with repeated string command instructions. These commands contain wait test cycles or primitive operations that can be recognized, incorrectly, as a breakpoint.

|                                                       | 80186/80188<br><b>Microprocessor</b> | <b>Break/Trace</b><br><b>Board</b> |
|-------------------------------------------------------|--------------------------------------|------------------------------------|
| Starting address                                      | $0:$ FFFFH                           | OFFFFH                             |
| Address incremented by 1<br>(next sequential address) | 0:0000H<br>(wrap-around)             | 10000H<br>(no wrap-around)         |

**Table 4-2 80186/80188 Segment Boundary Increments**

#### **Mapping Considerations for the 80186/80188 Probe**

The PICE system can get out of synchronization with the 80186/80188 probe when the prototype system borrows slow memory or I/O from the PICE system and the user program directs the 80186/80188 microprocessor (through the probe) to ignore external READY (refer to the Chip Select/Ready Generation Logic specification in the chip literature). Consequently, data presented at the wrong time is incorrect.



Use extreme caution when mapping memory and I/O locations to any PICE system resource if your program ignores external READYs.

Take the following precautions if the 80186/80188 microprocessor has been programmed to ignore external READYs:

- Do not map I/O addresses programmed to ignore external READYs to ICE.
- Do not map memory ranges programmed to ignore external READYs to MULTIBUS (MB) memory.
- Use high-speed (HS) or optional high-speed (OHS) memory in a memory range that ignores external READYs only if WAITSTATE  $= 0$ .

# CAUTION

User program references to an 80186/80188 internal peripheral control register cause the 80186/80188 PICE probe processor to complete bus cycles without wait-states and with external READY ignored, even when the 80186/80188 PICE probe has wait-states set. If locations that ignore external READYs are not mapped to USER or HS, the system may hang.

# **CAUTION**

**Programming 80186/80188 internal peripheral control registers can enable the 80186/ 80188 probe processor to complete bus cycles with an internally generated READY signal while ignoring external READY. Bus cycles may be terminated with less waitstates than allowed with external READY or set by the 80186/80188 probe. The system may hang if locations that ignore external READY are not mapped to memory with the corresponding number of wait-states.**

#### **Synchronization Between the Prototype and the Probe**

When the probe is executing code from **HS** memory, but the user prototype expects this mem**ory to exhibit different access time, the user's bus control logic can get out of synchronization with the probe. One solution is to set the BTHRDY pseudo-variable to TRUE.**

**If the user prototype expects slow memory, another solution is to insert an appropriate number of wait-states into the HS memory accesses.**

#### **User-Accessible Test Points**

**The top of the buffer box has two user-accessible user test points, one labeled SYNC START/ and the other TR**

**The TP test point is an output that is active high when the probe is emulating.**

**SYNC START/ is a TTL input. The SYNC START/ test point is normally high. When SYNC START/ is low and the probe enters emulation, READY is low and the probe undergoes a READY hang when fetching the first instruction. You can cause this hang by holding SYNC START/ low.**

#### **NOTE**

**SYNC START/ has no effect if the address of the first instruction fetch is within a range that has been programmed through the peripheral control registers to ignore external READY.**

**To synchronize the probes in a multi-probe system, first set MEMRDY to FALSE in each probe. This prevents a memory time-out from occurring during the first instruction fetch. Then, keep SYNC START/ low on each probe. Ensure that SYNC START/ for each probe goes high at the same time. This raises READY, eliminates the READY hang, and ensures that each probe enters emulation at the same time.**

#### **NOTE**

**If, while SYNC START/ is low, a coprocessor asserts HOLD, the probe's microprocessor will not assert HLDA until you raise SYNC START/. This is important if the coprocessor is performing a time-critical operation.**

#### **NOTE**

If the probe's microprocessor is waiting for READY from the user prototype, that READY must still be there when SYNC START/ goes high. When the prototype asserts its READY, the prototype must not assume that the probe's microprocessor receives that READY after a set time. Rather, the prototype must hold the READY asserted until it has determined that the probe's microprocessor has acknowledged the READY.

SYNC START/ is also useful in a single-probe system because it gives you hardware control over when the probe enters emulation. SYNC START/ must be high for emulation to begin.

#### **User Socket**

Your prototype system contains a socket into which you will connect the user cable. Intel recommends using the Textool/3M socket 268-5400. See Appendix A for instructions on connecting the 80186/80188 probe to the user prototype system.

#### **ALE Pulse Stretching**

The 80186/80188 probe generates ALE before T1. It accomplishes this by decoding the status lines during  $T4$  and  $T<sub>i</sub>$ . Note that generating the ALE pulse during an idle state can produce a stretched ALE pulse for the entire period when idles states are being generated.

For example, A DIV instruction can last longer than 80 idle clock cycles. The corresponding ALE pulse for the instruction following the division will be greater than 80 clock cycles.

In most cases, the long ALE pulse does not cause a problem in a user prototype system. If, however, your prototype system uses the rising edge of ALE to trigger a sequence of events or to generate logic signals, a problem can arise. The triggered logic or event will be distorted in length or time.

# **The 80286 Probe**

The 80286 features multitasking, a large address space with four levels of protection, and high-speed compatibility with previous Intel iAPX microprocessors.

The 80286 runs in either real mode or protected mode. In real mode, the 80286 acts like an 8086. It can address up to 1M byte plus 64K of physical address space. In protected mode, the 80286 can address up to 1G byte of virtual memory per task and up to 16M bytes of physical memory.

When running in real address mode, programs developed for the iAPX 86 and iAPX 88 require minimal modification. The advantage is that these programs run up to six times faster than on the 8086. When running in protected mode, iAPX 86 and iAPX 88 programs may require slight modifications.
This section contains the following subsections that provide information on the 80286 microprocessor and the 80286 probe.

- Address Translation
	- 8086 Address Translation
	- 80286 Address Translation
- **Multitasking**
- **Interrupts**
- Address Protection
	- Real Mode and PCHECK
	- Protected Mode and PCHECK
- Memory Mapping for the 80286 Probe
- Support for Processor Extensions
- Displaying 80286 Registers and Flags
	- $-$  Real Mode and PCHECK = TRUE
	- $-$  Real Mode and PCHECK = FALSE
	- $-$  Protected Mode and PCHECK  $=$  TRUE
	- $-$  Protected Mode and PCHECK  $=$  FALSE
- Hardware and Software Considerations for the 80286 Probe

#### **Address Translation**

**The 80286 probe performs 8086 address translation or 80286 address translation. When the 80286 probe is emulating in real mode, it performs 8086 translation. When the 80286 probe is emulating in protected mode, it performs 80286 translation. When the probe is not emulating, the FICE pseudo-variable SEL286 determines what address translation takes place.**

**SEL286 = TRUE 80286 address translation takes place.**

**SEL286 = FALSE 8086 address translation takes place.**

**When you load a program file that is in 80286 object module format (OMF), the FICE system automatically sets SEL286 to TRUE. When you load a program file that is in 8086 OMF, the FICE system sets SEL286 to FALSE.**

#### **8086 Address Translation**

**A virtual address is represented as a selector: offset pair. The selector and the offset are each 16 bits long. Each can be an expression. The selector:offset pair is of memory type POINTER.**

The PICE system forms a physical address by shifting the selector value left by four bits and then adding the offset. The result is a 20-bit real address. With 20 bits, you can address 1M byte of memory.

If you specify a physical address, you can use 24 bits even though the 8086/8088 microprocessor addresses 1M byte of memory. With a 24-bit physical address, the PICE system can address 16M bytes in program memory. If you specify a pointer address, the PICE system constructs a 20-bit physical address.

#### **80286 Address Translation**

A virtual address is represented as a selector: offset pair. The selector and the offset are each 16 bits long. Of the 16 selector bits, 14 contain address information. The other two bits contain protection information. The complete virtual address contains 30 address bits. With 30 bits, you can address 1G byte of memory.

The 80286 address translation uses the global descriptor table (GDT) and the local descriptor table (LDT) to construct a physical address. There is only one GDT, but many possible LDTs. Both kinds of tables reside within the virtual memory space.

#### **NOTE**

The GDT cannot be indexed with a value greater than 255.

The global table descriptor register (GDTR) contains a GDT descriptor. This GDT descriptor contains the base address of the GDT. The local table descriptor register (LDTR) contains an LDT selector that is an offset into the GDT and points to an LDT descriptor.

The LDTR contains an explicit cache. When you load the selector part of the LDTR (called RLDT), the 80286 loads the LDT descriptor (pointed to by RLDT) into the LDTR cache. The LDTR is actually 64 bits long, 16 for the selector and 48 for the explicit cache.

Figure 4-2 shows the relationship of the two descriptor tables (the GDT and the LDT) and the two registers (the LDTR and the GDTR).

Of the 14 address bits in the virtual address's selector, one bit identifies either the LDT or the GDT, and the other 13 represent an index into the selected table. This index points to a segment descriptor in the descriptor table. The segment descriptor contains access rights, a base address, and the segment limit. The final physical address is the sum of this base address and the virtual address's offset.

Figure 4-3 illustrates 80286 virtual address translation.

When programming the 80286, you can either specify the selector explicity or use a segment register. The 80286 contains four segment registers. Each segment register contains a selector and an explicit cache. When you load a segment register with a selector, the 80286 also loads the explicit cache with the segment descriptor. A segment register is 64 bits long, 16 for the selector and 48 for the explicit cache. As long as the selector does not change, the 80286 does not have to access a descriptor table.

#### (THE LDT DESCRIPTOR MUST RESIDE IN THE GDT.)



**Figure 4-2 The GDT and the LDT**

Figure 4-4 shows the relationship of the two descriptor tables (the GDT and the LDT) and the two registers (the LDTR and the GDTR).

When using I<sup>2</sup>ICE commands, you can represent an 80286 virtual address symbolically or by specifying the selector and offset. You can optionally include an LDT selector, as illustrated in the following syntax.

#### *[exp ressio n -fo r'LD T'S e le ctor:]e xp re ssion -for-sele cto r:exp re ssio n -for-o ffset*

The brackets around the *expression-for-LDT-selector* indicate that it is optional. If you leave out the *expression-for-LDT-selector*, the FICE system assumes the selector in the current LDTR.

The LDT-selector: selector:offset triplet is of memory type POINTER. Debug variables defined as a triplet are displayed as a triplet. Debug variables defined as a selector:offset pair are displayed as a pair.

When you apply the POINTER memory template to program memory locations, these locations are displayed as selector:offset pairs.

The final physical address is limited to 24 bits. With 24 bits, you can address 16M bytes of memory. The virtual address is still 30 bits. The 80286 has a virtual memory space larger than its physical memory space. A bit in the segment descriptor (part of the access field) identifies whether the virtual address currently exists in physical memory.

For more information on 80286 addressing, see the entries for Address, Address protection, and Address translation in the *PICE™ System Reference Manual*.





#### **Multitasking**

The 80286 provides built-in multitasking support. A task switch operation saves the entire 80286 execution state (registers, address space, and a link to the previous task), loads a new execution state, and begins execution on the new task. This operation makes use of a task-state segment.

The GDT contains a task-state segment descriptor (TSSD). In addition to the base address of the task-state segment (TSS), the TSSD contains an access field and a limit field. The task register (TR) contains a task selector (an offset into the GDT) that points to the TSSD

The following syntax displays the TSS.

**TSS** *[(expression-for-selector)]*

The TSS command without an operand displays the task-state segment whose task selector is in TR. You can override the selector currently stored in the TR by including a selector with the



TSS command. The PICE system returns an error if you choose a selector beyond the range of the GDT or one that points to an entry in the GDT that is not a TSSD.

#### **Interrupts**

The 80286 contains an interrupt descriptor table (IDT) that defines up to 256 interrupts. The interrupt descriptor table register (IDTR) contains the base address and the limit of the IDT. The relationship between the IDT and the IDTR is the same as the relationship between the GDT and the GDTR.

#### **Address Protection**

The LDT descriptors and the segment descriptors contain access bits. Two of these bits identify the descriptor protection level (the DPL). There are four protection levels: 0, 1, 2, 3. Level 0 has the most privilege, 3 the least.

The PICE pseudo-variable PCHECK determines whether the PICE system operates with 80286 protection checking on or off. The default for PCHECK is TRUE.

- PCHECK = TRUE the PICE system observes the 80286 protection rules when viewing and modifying 80286 registers and accepting memory addresses.
- $PCHECK = FALSE$  the PICE system ignores the 80286 protection rules as much as possible.

#### **Real Mode and PCHECK**

When the 8086 is in real mode and PCHECK is TRUE, you can neither display nor alter the segment caches, the LDTR, the GDTR, the TR, and the IDTR. When the 8086 is in real mode and PCHECK is FALSE, you can display and alter the segment caches, the LDTR, the GDTR, the TR, and the IDTR.

#### **Protected Mode and PCHECK**

When the user program executes in protected mode and PCHECK is FALSE, the PICE system ignores the 80286 protection rules when loading the 80286 registers and accessing memory. You can display and alter the segment caches, the LDTR, the GDTR, the TR, and the IDTR.

When the user program executes in protected mode and PCHECK is TRUE, the PICE system obeys the 80286 protection rules when loading the 80286 registers. You can display but not alter the segment caches, the LDTR, the GDTR, the TR, and the IDTR. You must use a virtual address to access memory. The PICE system obeys the 80286 protection rules.

For more information on address protection and PCHECK, see the Address protection and PCHECK entries in the *PICE™ System Reference Manual.*

#### **Memory Mapping for the 80286 Probe**

The PICE system with an 80286 probe supports the standard PICE memory mapping features plus the GRANULARITY pseudo-variable.

With the 8086/8088 and the 80186/80188 probes, you must map HS and MB memory in blocks of IK bytes. If you try to map a block of less than IK bytes, the PICE system rounds up to the nearest lK-byte block and prints a message telling you that it rounded the value. With the 80286 probe, however, you can map 1024 blocks of memory in either IK blocks or 16K blocks. When GRANULARITY = 1K, the upper four address bits are ignored by mapping logic; thus, only the lower megabyte of memory is mappable. When GRANULARITY  $=$ 16K, the entire address space is available. Choose the block size by setting the GRANULAR-ITY pseudo-variable. To change the granularity, you must have all program memory mapped to either USER or GUARDED.

The PICE system always maps OHS memory in blocks of 16K, even if GRANULARITY is IK.

#### **Support for Processor Extensions**

The PICE system with an 80286 probe supports the 80287 numeric processor extension with debugging commands. With the PICE pseudo-variables you can display and modify 80287 registers in much the same way you display and modify 8087 registers with the 8086/8088 probe.

The 80287 requires the PEREQ and PEACK lines. The COREQ pseudo-variable determines whether the 80286 probe recognizes its PEREO and PEACK pins.

#### **Displaying 80286 Registers and Flags**

You can access 80286 registers and flags with PICE pseudo-variables. This section uses the local descriptor table register as an example. The format of this register is as follows:

selector access base limit

You can access each field separately with the following pseudo-varibles.

LDTSEL The selector field<br>LDTAR The access rights LDTAR The access rights field<br>LDTBAS The base address field LDTBAS The base address field<br>LDTLIM The limit field The limit field

These pseudo-variables operate differently depending on the operating mode (real or protected mode) and the setting of the PCHECK pseudo-variable. Similar pseudo-variables exist for the other 80286 registers.

#### **Real Mode and PCHECK = TRUE**

When the 80286 probe is in real mode and PCHECK is TRUE, you cannot display or modify any of the LDTR fields. The LDTR has no meaning in real mode.

#### **Real Mode and PCHECK = FALSE**

When the 80286 probe is in real mode and PCHECK is FALSE, you can display and modify each LDTR field. The LDT has no meaning in real mode, but you can access it with PICE commands. Changing the selector field with the LDT pseudo-variable causes the 80286 probe to update the LDTR's explicit cache. Changing the selector field with LDTSEL does not cause the 80286 probe to update the LDTR's explicit cache.

#### **Protected Mode and PCHECK = TRUE**

When the 80286 probe is in protected mode and PCHECK is TRUE, you can display each LDTR field. The LDT has meaning when the 80286 is in protected mode. You cannot modify the LDTR fields directly. Changing the selector field with the LDT pseudo-variable causes the 80286 probe to update the LDTR's explicit cache.

#### **Protected Mode and PCHECK = FALSE**

When the 80286 probe is in protected mode and PCHECK is FALSE, you can display and modify each LDTR field. The LDT has meaning when the 80286 is in protected mode. Changing the selector field with the LDT pseudo-variable causes the 80286 probe to update the LDTR's explicit cache. Changing the selector field with LDTSEL does not cause the 80286 probe to update the LDTR's explicit cache.

#### **Hardware and Software Considerations for the 80286 Probe**

This section describes the unique characteristics of the 80286 probe. You should be aware of these characteristics when designing prototype hardware and software and when emulating your prototype. Separate subsections are provided on the following topics:

- Hardware Slipping Past a Breakpoint
- High-Address Bits Override
- Issuing a RESET Command when an 80287 Is Present
	- The RESET UNIT Command
	- The RESET REGs Command
	- The RESET ICE Command
- Resetting the 80286 Chip and the 80286 Probe
- Timing Differences between iAPX 286 and the PICE™ 80286 Probe
- User Substrate Capicator and  $+5$  Volt Source
- **Tracing Considerations**
- User Socket
- Synchronizing Emulation to an External Event
- Using the Initialization Segment
- Reading from and Mapping to Mapped Memory or I/O
- Pascal-286 and FORTRAN-286 array size

#### **Hardware Slipping Past a Breakpoint**

The are several considerations to note regarding breakpoint slipping:

- Hardware slipping beyond an execution breakpoint occurs in one instance. If the instruction immediately preceding the instruction that causes the break results in an exception that occurs late in the execution cycle, the break may occur after the first instruction in the exception handling routine rather than after the expected instruction. You see a break at an incorrect address. The trace buffer, however, will reveal the path taken by the microprocessor.
- The 80286 probe can only break on instruction boundaries. Therefore, when the PICE system recognizes a data breakpoint, the currently executing instruction must complete before a break can occur.
- When the PICE system is emulating and a breakpoint is encountered, the trace information may include information about the next instruction after the specified break. This can be verified by examining the CS:IP registers. These registers will disagree with the last instruction in the trace buffer. The trace information is incorrect; the processor actually does break in accord with the criteria specified in the pre-emulation session.
- Unlike the 8086/8088 and 80186/80188 probes, the 80286 probe does not slip beyond a breakpoint. However, it may break prematurely if an execution breakpoint is set to occur on the instruction after a HLT instruction is executed. The break occurs at the completion of the specified instruction.
- Do not set a breakpoint on the instruction after a HLT instruction because the message displaying the cause of the break will be invalid if time-outs are enabled.

#### **High-Address Bits Override**

When you reset the 80286 microprocessor, the upper four address bits  $\langle A23-A20 \rangle$  remain high until the code-segment register (CS) is modified. When you set breakpoints, you may want to specify these address bits as high. Do that by preceding the address with an asterisk  $(*).$ 

For example, the following commands set a breakpoint at the same address.



**\*GO TIL \*OFFFF:0** This command specifies a virtual address.

If SEL286 = FALSE, the  $80286$  probe performs  $8086$ address translation. This results in a 20-bit physical address. The upper four address bits  $(**A**23-**A**20>)$  are normally zero. The asterisk forces these bits high. If  $SEL286$  = TRUE, the 80286 probe performs 80286 address translation. The result is a 24-bit physical address. The asterisk forces the upper four address bits  $(<$  $A23-A20>$ ) high.

When  $SEL286 = TRUE$ , you can also represent an address as an LDT-selector:selector:offset triplet. The asterisk forces the upper four address bits  $($ ) high.

**\*GO TIL \*RESET\_VECTOR** This command specifies a symbolic address.

Assume that the user program defines this symbolic address as 0FFFF:0 in real mode. Ordinarily, this results in the 20-bit physical address FFFFO. Address bits 23-20 are zero. The asterisk before the symbolic address forces the upper four address bits  $( $AA23 - A20>$ ) high. The re$ set vector for the 80286 is FFFFF0.

#### **Issuing a RESET Command When an 80287 Is Present**

Each of the following PICE commands activates the RESET pin on the probe's microprocessor:

RESET UNIT RESET REGS RESET ICE

RESET REGS and RESET ICE always return the probe's microprocessor to real mode. Under certain circumstances (as explained in the next section), RESET UNIT may also return the probe's microprocessor to real mode.

None of these commands resets the 80287 numeric processor extension. Consequently, none of them returns the 80287 to real mode.

Running your prototype with the 80286 and 80287 in different address modes will result in invalid address translation. To return the 80287 to real mode, assert its RESET line. This must be performed by prototype hardware.

#### **The RESET UNIT Command**

When you break emulation, the PICE system copies the probe's registers into a register buffer. When issued from interrogation mode (from the \* prompt), the I<sup>2</sup>ICE command RESET UNIT resets the probe's microprocessor but does not affect the register copies. When you resume emulation, the PICE system reloads the probe's registers with the values in the register buffer. Consequently, a RESET UNIT issued from interrogation mode does not appear to have any effect on a user program.

When issued from interrogation mode, a RESET UNIT does not return the probe's microprocessor to real mode.

When issued from emulation mode (from the ? prompt), a RESET UNIT causes a break and returns the registers and their copies to the values they had just before the probe began emulating.

Figure 4-5 shows returning the probe's microprocessor to real mode.



**Figure 4-5 Returning the Probe's Microprocessor to Real Mode**

#### **The RESET REGS Command**

The PICE command RESET REGS asserts the RESET pin on the probe's microprocessor. The RESET REGS command also clears the segment registers, clears the MSW, and loads the CS:IP with the reset vector. It does this both for the probe's actual registers and for their copies in the register buffer. Hence, entering the RESET REGS command returns the probe microprocessor to real mode.

#### **The RESET ICE Command**

The PICE command RESET ICE asserts the RESET pin on the probe's microprocessor and reloads probe software. The RESET ICE command also clears the segment registers, resets the pseudo-variables displayed by the STATUS command (BTHRDY, BUSACT, COENAB, COREQ, CPMODE, IORDY, MEMRDY, PCHECK, RSTEN, SEL286, TRCBUS) to their default values, clears the MSW, and loads the CS.TP with the reset vector. It does this for the probe's actual registers and for their copies in the register buffer. Hence, entering the RESET ICE command returns the probe microprocessor to real mode.

The RESET ICE command also returns the AX, BX, CX, and DX registers, the stack and base pointers, and the source and destination indexes to the same values that the 80286 registers have after reset.

#### **Resetting the 80286 Chip and the 80286 Probe**

The system clock provides the fundamental timing for the 80286 system. It is divided by two inside the 80286 microprocessor to generate the processor clock (PCLK). The 80286 probe also generates a signal called PCLK, as may the target system. The 80286 microprocessor's internal divide-by-two circuitry can be synchronized to an external clock generator by a low-tohigh transition on the RESET input to the 80286 microprocessor. Asynchronous PCLK phasing may cause bus contention between the target system and the PICE system. The following three conditions can cause the phase of PCLK in the 80286 probe to differ from PCLK in the target system.

- Reset from the host (RESET ICE command, RESET UNIT command, UNITHOLD command, and when an auto reset is requested).
- User hardware reset while the probe is in interrogation mode or when the RSTEN pseudovariable is FALSE.
- User system power-on reset.

If PCLK synchronization is a problem, use one of the following solutions.

- Design the PCLK generation circuit in the user system to be synchronized with status bits rather than RESET. (The 82284 clock generator uses the status lines  $\overline{SO}$  and  $\overline{SI}$  to synchronize its PCLK output.)
- Before starting a debug session, enter emualtion and then reset the target system to synchronize the PCLKs. The PCLKs will remain synchronous until a RESET UNIT command, a RESET ICE command, or a target system reset with the probe in interrogation mode. If one of these conditions occurs, enter emulation and reset the target system to restore synchronization.

When the 80286 probe is reset, the address and data buses are in a 3-state condition for the full duration of the reset.

#### **Timing Differences Between the iAPX 286 and the 80286 Probe**

There are timing differences between the ways that the PICE 80286 probe and the 80286 chip handle RESET and HOLD/HLDA. See the PICE data sheet for an explanation of these differences.

#### **User Substrate Capacitor and + 5 Volt Source**

The prototype hardware need not supply a substrate capacitor or  $+5$  volts to the 80286 probe.

#### **Tracing Considerations**

If the 80286 probe releases the memory bus to a coprocessor (the ADMA 82258), it does not record that coprocessor's bus activity in the trace buffer. Because the 80287 processor extension uses the memory protection capabilities of the 80286, the 80286 probe does record 80287 instruction execution and bus activity in the trace buffer.

Cascade interrupt addresses are not recorded in the trace buffer. Connect the chips module to the bus in the target system if you need this data.

#### **User Socket**

Your prototype system contains a socket into which you will connect the user cable. Intel recommends using the Textool/3M socket 268-5400. See Appendix A for instructions on connecting the 80286 probe to the user-prototype system.

#### **Synchronizing Emulation to an External Event**

The top of the buffer box has a user-accessible test point labeled SYNC START/. SYNC START/ is useful because it gives you hardware control over when the probe enters emulation.

The SYNC START/ test point is a TTL input that is pulled up with a IK resistor. The SYNC START/ input is normally high. When SYNC START/ is driven low and the GO command is executed, the probe treats SYNC START/ as an auxiliary hold input (HLDA will not be activated). HOLD is asserted and the 80286 no longer has access to the address and data buses.

To synchronize the probes in a multiple-probe system, first set the BUS ACT and MEMRDY pseudo-variables to FALSE in each probe. This prevents a bus time-out from occurring when the 80286 microprocessor loses control of the address and data buses. Then, keep SYNC START/ on each probe low and ensure that SYNC START/ for each probe goes high at the same time. This lowers HOLD (de-asserts it) and returns the address and data buses to the 80286 microprocessor, allowing emulation to proceed. In this way you can ensure that each probe enters emulation at the same time.

Because SYNC START/ gives you hardware control over when the probe enters emulation, it is also useful in a single-probe system.

#### **Using the Initialization Segment**

The 80286 addresses memory with 24 address lines. After a reset, the 80286 is in real mode and the most significant four bits of the address is high. The 80286 then addresses a 64K-byte segment (called the initialization segment) at the top of the 16M-byte physical address space. After the first long jump (which modifies the CS register), the most significant four bits go low.

The result is that right after a reset, the 80286 temporarily has access to memory locations in addition to the 1M byte provided in real mode.

A problem arises if you try to load the initialization segment with the PICE system 8086 loader (your program is an 8086 OMF). Protected-mode users should construct 80286 OMFs and hence use the 80286 loader.

If you still need to load the initialization segment with the 8086 loader, one method is to first map the initialization segment to where you want the initialization code to reside. Then load the initialization code into HS memory mapped within the lower 1M byte. Move your initialization code with the BYTE command. The following example assumes that your initialization code takes up no more than IK byte.

#### \*MAP0 LENGTH 1KHS \* WAP 1023K LENGTH IK USER \*LOAD init.86  $*$ BYTE 1023K LENGTH 1K = BYTE 0 LENGTH 1K

Another method is as follows. If the granularity is IK, you can load the initialization segment by mapping the 64K-byte segment at the top of the lM-byte address space to HS and then entering the LOAD command. When the granularity is IK, the PICE memory map has address wrap-around. Each physical memory location responds to 16 different addresses. If you map the 64K-byte segment from  $1M - 1$  to  $1M - 64K$  to HS, you are also mapping the 64K-byte segment from  $16M - 1$  to  $16M - 64K$  (the initialization segment) to HS, the 64K-byte segment from  $15M - 1$  to  $15M - 64K$  to HS, etc., to the same physical locations.

#### **Reading from and Mapping to Mapped Memory or I/O**

When you map memory to HS or MB memory or when you map I/O ports to ICE, the bus to the prototype is also active.

For example, assume that you map the first 32K bytes of memory to HS. When you read from one of these memory locations, you also read from user memory. The PICE system, however, ignores the read data. When you write to one of these memory locations, you write to both the HS location and the USER location. Even though the memory locations are mapped to PICE memory, the user memory corresponding to those locations does not remain unchanged.

The same holds true for I/O ports. If you write to an I/O port mapped to ICE, the write data appears on the screen or as an PICE variable in a debug procedure as well as at the user I/O port (if it exists).

#### Pascal-286 and FORTRAN-286 Array Size

The PICE system does not support Pascal-286 and FORTRAN-286 array size greater than 64K.

# 5 **COPROCESSOR SUPPORT**

iny "

A coprocessor is a microprocessor that enhances the functions of the CPU.

The 8087 and 80287 numeric data processors (NDP) perform arithmetic and comparison operations on a variety of numeric data types as well as executing numerous built-in transcendental functions.

The 8089 input/output processor (IOP) performs input and output operations for the CPU. An IOP combines the attributes of a CPU with those of a flexible DMA controller.

The distinction is sometimes made between a coprocessor and a processor extension. A coprocessor can gain control of the memory and data buses, plus it uses the HOLD and HLDA signals. A processor extension uses the PEREQ and  $\overline{PEACK}$  signals. That makes the 80287 a numeric processor extension, while the 8087 and 8089 are coprocessors.

#### **Mapping Restrictions When Using Coprocessors**

When the 8087 is used as an external coprocessor (with the 8086/8088 and 80186/80188 probes), memory accessed by the external 8087 must be mapped to USER. For the 8089, all program memory accessed by the 8089 must be mapped to USER.

#### **The PHANG Pseudo-Variable**

Use the PHANG pseudo-variable to detect 8086/8088 and 80186/80188 coprocessor hangs (the PHANG pseudo-variable is not supported on the 80286 probe). Setting PHANG to TRUE causes a system time-out when the coprocessor has been granted the bus and remains inactive for longer than one second. The default is TRUE.

#### **The 8087/80287 Numeric Data Processors**

The 8086/8088 and the 80186/80188 probes provide debugging support for a prototype system containing the 8087. The 8086/8088 probe supports an 8087 as an internal or an external coprocessor; the 80186/80188 supports an 8087 as an external coprocessor. When an 8087 is used with the 80186/80188 probe, it requires the 82188 coprocessor interface chip.

The 80286 probe processor provides debugging support for a prototype system containing the 80287.

The PICE commands provide access to the 8087's and 80287's stack, status registers, and flags. The PICE system's disassembly and trace features extend to 8087 and 80287 instructions and data types.

How the PICE system treats the 8087 depends on the two pseudo-variables COENAB and CPMODE and on the GET87 command. How the PICE system treats the 80287 depends on the pseudo-variables CPMODE and COREQ.

The following sections introduce the COENAB, CPMODE, and COREQ pseudo-variables and the GET87 command. Table 5-1 summarizes the interactions between the COENAB, CPMODE, and COREQ pseudo-variables. The following subsections describe further the use of the COENAB and CPMODE commands. See also the *HCEJM System Reference Manual* (and the section in Chapter 4 of this manual entitled "Issuing a RESET Command when an 80287 Is Present") for farther information on the coprocessor commands.

|              | $CPMODE = 1$                                                   | $CPMODE = 2$                                                                     |  |
|--------------|----------------------------------------------------------------|----------------------------------------------------------------------------------|--|
| $COREQ = T$  | PEREQ/PEACK are recognized<br>only during emulation.           | PEREQ/PEACK are recognized<br>during both emulation and<br>interrogation.        |  |
| $COREQ = F$  | PEREQ/PEACK off.                                               | PEREQ/PEACK off.                                                                 |  |
| $COENAB = T$ | HOLD/HLDA or RQ/GT are<br>recognized only during<br>emulation. | HOLD/HLDA or RO/GT are<br>recognized during both emulation<br>and interrogation. |  |
| $COENAB = F$ | HOLD/HLDA or RQ/GT off.                                        | HOLD/HLDA or RQ/GT off.                                                          |  |

Table 5-1 Coprocessor Pseudo-variable Interaction

#### **The COENAB Pseudo-Variable**

The coprocessor enable (COENAB) pseudo-variable enables or disables an external coprocessor. The COENAB pseudo-variable has the value TRUE or FALSE. Setting COENAB to TRUE enables an external coprocessor, and the probes respond in the following ways.



Setting COENAB to FALSE disables an external coprocessor, and the probes ignore their request/grant or hold/hold acknowledge lines.

For the 8086/8088 and 80186/80188 probes, COENAB's default value is TRUE. For the 80286 probe, COENAB's default value is FALSE. Note that, for the 8086/8088 and 80186/ 80188 probes, when the PICE software is invoked, it checks the request/grant or hold/hold acknowledge lines before the COENAB pseudo-variable's default value is set.

#### **COENAB and an External Coprocessor**

For an 8086/8088 or 80186/80188 probe, if COENAB is FALSE and your program contains a coprocessor instruction, the PICE system will hang. The coprocessor does not run, but the coprocessor instruction still causes the PICE probe to wait for an acknowledgement. If the PICE system hangs in this way, recover by resetting first the coprocessor (with the hardware reset button) and then the probe (with the RESET UNIT command).

#### **COENAB and an Internal Coprocessor**

If you use an internal coprocessor with your 8086/8088 probe, always set COENAB to TRUE. If COENAB is FALSE, the internal coprocessor still runs, but the coprocessor may get out of synchronization with the probe.

#### **The CPMODE Pseudo-Variable**

Use the CPMODE pseudo-variable to select external coprocessor modes before starting emulation; CPMODE has no effect on an internal coprocessor. The CPMODE pseudo-variable has the value 1 or 2. For the 8086/8088 and 80186/80188 probes, the default is 1. For the 80286 probe, the default is 2.

When CPMODE is 1 and COENAB is TRUE, the probe's microprocessor recognizes its request/grant or hold/hold acknowledge lines only during emulation. For the 8086/8088 and 80186/80188 probes, if a request is issued while the probe is not emulating, the request is stored and the grant occurs as soon as emulation begins. When CPMODE is 2 and COENAB is TRUE, the probe's microprocessor recognizes its request/grant or hold/hold acknowledge lines at any time.

For the 8086/8088 and 80186/80188 probes, CPMODE also determines how the PICE system treats modifications to the 8087 registers made while the PICE system is in interrogation mode. After you enter the GET87 command, the I<sup>2</sup>ICE system maintains copies of the 8087 registers in a register buffer. When you read and write 8087 registers, you read and write the copies in this buffer.

If you resume emulation after modifying one or more 8087 registers and CPMODE is 2, the PICE system loads the actual 8087 registers with the modified values from the register buffer (which is external emulation memory). If you resume emulation after modifying 8087 registers and CPMODE is 1, the PICE system does not load the actual 8087 registers with the modified values from the register buffer. Emulation resumes with the old values.

#### **The COREQ Pseudo-Variable**

The COREQ pseudo-variable enables or disables an external numeric extension and is specific to the 80286 probe. When COREQ = TRUE, the 80286 probe recognizes its PEREQ and **PEACK** lines. Setting COREQ  $=$  FALSE disables the external numeric extension, and the 80286 probes does not recognized the PEREO and PEACK lines.

#### **The GET87 Command**

The GET87 command is specific to the 8086/8088 and 80186/80188 probes. You must enter the GET87 command to tell the PICE system that an 8087 coprocessor is present. The 8087 must be enabled (COENAB must be TRUE) for the PICE system to execute the GET87 command.

The following restrictions apply when you use the GET87 command with an external coprocessor:

- The probe must not be emulating and CPMODE must be 2.
- Include with the GET87 command the starting address of a 110-byte buffer. The PICE system uses this area as an intermediate buffer in saving and restoring the 8087 register data. The original contents of this buffer are preserved between save and restore operations. User's data is restored in the buffer after the GET87 command is entered. This buffer must be mapped to USER and not specified as read-only.

The following restrictions apply when using the GET87 command with an internal coprocessor (8086/8088 probe only):

- The probe must not be emulating. The value of CPMODE is not significant.
- Do not include an address with the GET87 command. The PICE system uses reserved system memory rather than USER memory for the register buffer. If you do include an address, the I<sup>2</sup>ICE system ignores it.
- The I<sup>2</sup>ICE system always loads the actual 8087 registers with the values from the buffer when you resume emulation after modifying one or more 8087 registers.



## 6 **MULTIPLE-PROBE SYSTEMS**

This chapter describes the operation of a multiple-probe PICE system. It introduces the PICE commands that control the system break and trace lines and explains how to arm the PICE system, assert the system break and trace lines, enable a unit, and write debug procedures for use with multiple probes

#### **I2ICE™ System Units**

Up to four PICE chassis may be daisy-chained together in an PICE system. Each chassis is called a unit and has a unit number from 0 to 3. Each unit may have its own probe and can communicate with one or more prototype systems and with any other unit.

By default, the current unit is the unit closest to the host that has a probe attached. (An PICE chassis may have the iLTA without a probe.) The unit numbers increase as you move away from the host. The next chassis is unit 1, then unit 2, and finally unit 3.

The PICE system commands operate on the current unit. The following example changes the current unit with the UNIT pseudo-variable.

#### $*$ UNIT $=2$

You can temporarily change the current unit for the duration of a command with a backslash. The following example displays the modules on unit 1 and on unit 0 (the current unit).

#### **\* \1 dir module; dir module**

Units communicate using the system break (SYSTRIG) and system trace lines (SYSTRACE). When the SYSTRIG line enters a unit, it becomes the local signal SYSBREAKIN. When the SYSTRACE line enters a unit, it becomes the local signal SYSTRACEIN. Figure 6-1 illustrates the system break and trace lines in a multiple-probe configuration.

For a unit to assert SYSTRIG, the PICE system must first be armed. The PICE system does not need to be armed to assert SYSTRACE. For a unit to recognize an assertion of either of the system lines (allow SYSBREAKIN or SYSTRACEIN to be asserted), that unit must be enabled.



**Figure 6-1 A Multiple-Probe PICE™ System**

#### **Arming the PICE™ System**

The PICE system is armed by default. You can arm and disarm the PICE system with the following:

- The SYSTEM ARM/DISARM command.
- An event specification—you can specify the keyword SYS ARM in an event register or in the GO command.
- A system specification—you can specify the keyword SYSARM in a system register or in the GO command.

You cannot arm and disarm the system with a break specification. You arm the FICE system, not individual probes. When the system is armed, all probes are armed.

The following example shows how to disarm the PICE system with the SYSTEM ARM/ DISARM command.

#### **\*SYSTEM DISARM**

The following example shows how to arm the PICE system with a system specification that is stored in a system register called armO.

#### **\* DEFINE SYSREG armO » SYSARM AT :cmaker#12 \* SYSTEM DISARM \*6 0 USING armO**

Before beginning emulation with an event or system specification that arms the PICE system, disarm the system with the SYSTEM DISARM command.

Arming the PICE system is not the same as arming a breakpoint. To arm a breakpoint, use an arm specification. Include the arm specification in an arm register or as part of the GO command. Refer to Chapter 3 for a discussion of arm specifications and arm registers.

#### **Asserting the System Break and Trace Lines**

You can assert the system break line with an event specification or a system specification. You can specify the keyword SYSTRIG (for asserting the system break line) or the keyword SYSTRACE (for asserting the system trace line) in an event register, system register, or in the GO command.

You can assert the system trace line with a trace specification. You can specify the keyword SYSTRACE in a trace register or as part of the GO command.

The following example shows how to assert the system trigger line with a system specification. This system specification is stored in a system register called trig l.

#### **^SYSTEM ARIA \* DEFINE SYSREG trigl « SYSTRIG AT ;ctrtaker#22 \*GO USING trigl**

The emulating unit asserts the system trigger line when the user program begins to execute statement #22. Whether asserting the system trigger line causes a unit to break depends on whether the unit is enabled. If the system trigger line is asserted, then any unit that has its system break line enabled will break.

When you use SYSTRACE in a multiprobe environment with various probe frequencies, the slower probes may miss the system trace event for one instruction. Therefore, specify a range of addresses, such as one of the following:

SYSTRACE AT OUTSIDE *address-start* LENGTH 50

SYSTRACE AT X0X110XY

#### **Enabling I<sup>2</sup>ICE™ System Units**

By default, each unit is enabled for both the system break line and the system trace line. You can enable and disable each line separately. First set the current unit to the unit you want enabled and then enter the ENABLE command. The following example shows how to enable the system break line for unit 1.

#### $*$ **UNIT** $=1$ **\* ENABLE SYSBREAKJN**

The local signal corresponding to SYSTRIG is SYSBREAKIN.

The previous example changed the current unit to 1. The current unit remains 1 until you explicitly change it back. With the backslash, you can change the current unit only for the duration of the command.

The following example deals with two units. Unit 0 arms the system when its program executes statement  $\neq 12$ . Unit 1 triggers the system when its program executes statement  $\neq 22$ . Unit 0 and unit 1 recognize the system trigger line and break when it is asserted.

```
* \0 ENABLE SYSBREAK1N
* \ 1 ENABLE SYSBREAKIN
* DEFINE SYSRE6 armO = SYSARM AT ;cmaker#12
* DEFINE SYSREGtrigl - SYSTRIG AT :dmaker#22
* \0 GO USING armO
*\1 GO USING trigl
```
#### **Symbolic Support for Multiple Probes**

The PICE system provides symbolic support for each of its probes in a multiple-probe system. You can refer to program variables by name in each unit. The program symbol table resides in the host development system.

The following example loads unit 0 with a program called progO and unit l with a program called progl.

#### $*$ UNIT $=0$ **\*LOAD :F1:progO \*\1 LOAD :F1:progt**

Assume that progO contains a program variable called pvarO and that progl contains a program variable called pvarl. The following example sets pvar0 equal to pvarl.

#### $* \setminus 0$  ;prog0.pvar0  $= \setminus 1$  :prog1.pvar1

The following example shows that if the current unit is 0, you need specify only the  $\lambda$ 1, not the  $\lambda$ 0.

```
*:prog0.pvar0 = \1 :prog1.pvar1 /*current unit is 0*/
```
If the current unit is 1, you must specify both the  $\setminus 0$  and the  $\setminus 1$  or verify that the first variable belongs to the current unit. For example, when the PICE system sees the following assignment:

#### **\* \0 cprogO.pvarO « ;prog1 .pvarl**

the PICE system looks for both program variables on unit 0. The following two assignments are equivalent.

\*UNIT **001** \*\0 :prog0.pvar0 = \1 :prog1.pvar1  $*: \text{prog1.pvar1} = \{0 : \text{prog0.pvar0}\}$ 

The following example illustrates inter-probe communication. Assume that unit 0 and unit 1 are emulating a program (prog0 for unit 0 and prog1 for unit 1) and that you want unit 0 to break when unit 1 writes a variable called pvarl. You do not want unit 1 to break.

**^SYSTEM ARM \*\GENABLE SYSBREAKIN \* V1 DISABLE SYSBREAKIN \* \0 GO FOREVER \*\1 GO TIL SYSTRIG WRITE AT .pvart**

#### **Writing Debug Procedures for Multiple Probe Systems**

Debug procedures that handle multiple probe systems must know which probes are emulating. The WAIT function returns the unit number of the probe breaking emulation. Once the break has occurred and if no probe is emulating, the WAIT function returns the value 255T.

The following example assumes that probe 0 and probe 1 are both emulating. Probe 0 breaks. WAIT then returns the value 0. WAIT continues to return 0 until probe 1 breaks. WAIT returns the value 1 when probe 1 breaks; once the break has occurred, WAIT returns the value 255T because no probe is emulating.

**\*UNIT»0 \*\1 <80 USING \$y\$f \*60 USING sys1 fWAIT**

Note that the prompt is determined by the current unit. The prompt is ? when the current unit is emulating. When unit 0 breaks, the FICE system returns its unit number.

#### d<br>\*wait

When the probe (unit 1) breaks, the PICE system returns its unit number. Entering WAIT returns the value 255, indicating that emulation is not occurring.

)<br>\*WAIT ESS

The following debug procedure sets the current unit to 0, then sends unit 0 into emulation. Unit 0 will emulate until the user program writes location 0031:001OH. The procedure then sets the current unit to 1 and waits until unit 0 breaks before sending unit 1 into emulation.

```
* DEFINE PROC bothrun » DO
. *UNIT
. *G 0 Tit WRITE AT 0O3tH:OO1OH
. *UNIT «1
. * REPEAT
```
 $. . *$ IF (WAIT = = 0) OR (WAIT = = 255T) THEN **. . . \*GO TIL WRITE AT 0031H:000EH . . . \*£ND . . \*1NI1 . \*END**

WAIT is also useful in single-probe systems when, for example, the program runs for a long time before breaking. The following debug procedure starts emulation, waits until the break, and then prints out the microprocessor registers.

**\* DEFINE PROC longbreak \* DO . \*0 0 TIL WRITE AT .pvarl IS 25T . ^REPEAT**  $\cdot$   $\cdot$   $\times$  UNTIL WAIT  $=$   $=$  255T **. . \*END . \*REGS • \*END**

Without the REPEAT loop, the PICE system would try to execute the REGS command during emulation and return an error message.

The CAUSE command displays the reason for the last emulation break. The CAUSE message lists the location and reason for the break along with the unit number, the debug register that caused the break, the value of the chips, and trace buffer overflow (if applicable). The following example displays the reason emulation stopped.

#### **\* CAUSE**

```
Probe 0 stopped at :CHAKER#10 because of guarded access
  Bus address = 006274
```
#### **Synchronization Between Units**

Some applications require that different probes begin emulating at the same time. If you start two probes emulating by changing the unit number and entering the GO command, the first probe begins emulating before the second. To synchronize the probes, you need to use the SYNC START/ test point available through a small opening in the side of the probe buffer box. This test point is an input to the probe.

#### **The 8086/8088 and 80186/80188 Probes**

SYNC START/ is normally high. When SYNC START/ is low and the probe enters emulation, READY is low, and the probe undergoes a READY hang when fetching the first instruction. You can cause this hang by holding SYNC START/ low.

To synchronize the probes in a multiple-probe system, first set the MEMRDY pseudo-variable to FALSE in each probe. This prevents a memory time-out from occurring during the first instruction fetch. Then, keep SYNC START/ on each probe low. Ensure that SYNC START/ for each probe goes high at the same time by connecting each SYNC START/ test point to one

of the two clipsout lines. These are output from the PICE system and are initially low. Then, enter the GO command for each probe. Each probe hangs after the first instruction fetch. Then, set the clipsout line to 1. All the probes enter emulation simultaneously.

#### **The 80286 Probe**

SYNC START/ is normally high. When SYNC START/ is low and the probe enters emulation, the probe treats SYNC START/ as an auxiliary hold input (HLDA will not be activated). HOLD is asserted and the 80286 no longer has access to the address and data buses.

To synchronize the probes in a multiple-probe system, first set the BUSACT and MEMRDY pseudo-variables to FALSE in each probe. This prevents a bus time-out from occurring when the 80286 microprocessor loses control of the address and data buses. Then, keep SYNC START/ on each probe low and ensure that SYNC START/ for each probe goes high at the same time. This lowers HOLD (de-asserts it) and returns the address and data buses to the 80286 microprocessor, allowing emulation to proceed. In this way you can ensure that each probe enters emulation at the same time.

### **A<br>
PICE™ SYSTEM NON-HOST<br>
HARDWARE INSTALLATION HARDWARE INSTALLATION**

**intel ■ ■**

The hardware installation procedure for the I<sup>2</sup>ICE system depends on the host development system, the number of PICE chassis in the system, and the system options. Begin installation of your PICE system using the installation instructions in this appendix. The appendix has sections on the following host-independent topics.

- Installing the PICE instrumentation chassis
- Installing the emulation base module
- Installing personality modules and user cables
- Installing the emulation clips module
- Installing the iLTA logic timing analyzer option
- Host installation information

#### **The PICE™ System Instrumentation Chassis Installation**

Refer to Figures A-1, A-2, and A-3 when installing the instrumentation chassis. Perform the following steps for each instrumentation chassis in your PICE system.

1. Unpack the chassis and set it in the desired location.

#### **CAUTION**

Provide at least six inches (15 centimeters) of clearance on all sides to ensure proper cooling.

2. Set the line voltage switch to the appropriate value for your area: 120 for 90-132 VAC operation or 240 for 180-264 VAC operation. (Use a small screwdriver as a lever.)

#### **WARNING**

Changing the power cord involves hazardous voltages and currents. Only qualified personnel should change the power cord.



3. If the system location is in an area where the power outlets do not match the power plug on the instrumentation chassis power cord, remove the power plug and install the appropriate power connector.

Refer to Figure A-l when installing a new power connector.

Do not connect the PICE system to the power outlet yet.



**Figure A-2 Circuit Breaker on the Rear Panel of the PICE™ System Instrumentation Chassis**



**Figure A-3 Termination Switches on the Rear Panel of the PICE™ System Instrumentation Chassis**

### **CAUTION**

To avoid overloading the line circuit, ensure that each PICE instrumentation chassis is on a separate line circuit and that the host development system is on a separate line circuit.

The PICE chassis draws a maximum of 12 amps at 90-132 V and 6 amps at 180-264 V. A Series III development system with two double-density disk drives and an expansion chassis draws a maximum of approximately 10.5 amps at 90-132 V.

- 4. Verify that the circuit breaker CB1 (see Figure A-2) on the instrumentation chassis rear panel is OFF. Connect the line cord to an appropriate power outlet.
- 5. For single-chassis PICE systems, ensure that all five termination switches are ON (up) (see Figure A-3).

For multiple-chassis PICE systems, ensure that the last (the highest-numbered) instrumentation chassis has all five termination switches ON (up). All other chassis in a multiplechassis PICE system must have all termination switches OFF (down) (see Figure A-3).

6. Remove the front panel from the instrumentation chassis and set it aside.



Remove the foam packing behind the front panel (and save it for future storage and shipment). Powering up the PICE instrumentation chassis without removing the foam will damage the equipment.

#### **Emulation Base Module Installation**

The emulation base module consists of a break/trace board, a map-I/O board, the buffer base assembly, and an emulation clips module. The break/trace board, the map-I/O board, and the buffer base assembly are already installed. Figure A-4 shows the location of the break/trace board and the map-I/O board in the PICE instrumentation chassis.

For your reference, the map-I/O board is jumpered at E1-E2 and E3-E4 (see Figure A-5).

In this section one installation task is described: checking buffer box jumpering.

#### **Buffer Base Assembly Jumpering**

Ensure that the buffer board is jumpered correctly (see Figure A-6).

E5-E6 For 16-bit emulation (8086, 80186, or 80286 microprocessors).

E4-E5 For 8-bit emulation (8088 or 80188 microprocessors).

If you have a multiple-chassis system, check the jumpering for each buffer board supplied.

#### **Installing Personality Modules and User Cables**

There are three kinds of personality modules (also called probes): the 8086/8088 probe, the 80186/80188 probe, and the 80286 probe. Separate subsections are provided to explain installation of each probe type and each probe user cable.

#### **Installing the l2ICE™ System 8086/8088 Emulation Personality Module**

The 8086/8088 emulation personality module consists of the 8086/8088 personality board, the user cable, and the buffer box cover. The 8086/8088 emulation personality module connects to the buffer base assembly and configures the generic portion of the FICE system to emulate a specific processor.

The emulation personality board contains jumper selections that define the level of 8087 support. The coprocessor is internal when an iSBC 337 MULTIMODULE™ board is installed on the 8086/8088 emulation personality board. When the FICE system is running with an internal coprocessor, the LED on the buffer box labeled 8087 lights up. The coprocessor is external when an iSBC 337 MULTIMODULE board is installed in the user system.

In Tables A-l and A-2, the jumpers appearing in bold type indicate the default jumper configuration for the 8086/8088 emulation personality board. Refer to Tables A-l and A-2 and Figures A-7, A-8, and A-9 when installing the 8086/8088 emulation personality module. Many of the steps described here may have already been performed; you need only verify them.

1. Two ribbon cables are included with the 8086/8088 personality module. Use these cables to replace the two interconnect cables attached to the 8086/8088 probe buffer board (the probe buffer board is shipped with the emulation base module). The new ribbon cables minimize cross talk. Use Figure A-7 together with the following text to replace the cables.









**Figure A-5 Jumper Positions on the Map-I/O Board**



**Figure A-6 Jumper Positions on the Buffer Board**





\*Do not change these jumper configurations.

|                            | <b>Location of</b>      |                                                              | <b>Jumpers</b>                                                   |                                          |                                          |
|----------------------------|-------------------------|--------------------------------------------------------------|------------------------------------------------------------------|------------------------------------------|------------------------------------------|
| <b>Coprocessor</b>         | <b>User Plug</b>        | <b>NMI Source</b>                                            | W <sub>1</sub>                                                   | W7                                       | <b>W10</b>                               |
| internal<br>coprocessor    | user system<br>loopback | from user system<br>from 8087 INTR<br>none<br>from 8087 INTR | E1-E2<br>$E1-E2$<br>$E1-E2$<br>$E1-E2$                           | E19-E20<br>E20-E21<br>E19-E20<br>E20-E21 | E28-E29<br>E28-E29<br>E28-E29<br>E28-E29 |
| no internal<br>coprocessor | user system<br>loopback | from user system<br>none                                     | E <sub>2</sub> -E <sub>3</sub><br>E <sub>2</sub> -E <sub>3</sub> | E19-E20<br>E19-E20                       | E29-E30<br>E29-E30                       |

**Table A-2 Jumpering for 8087 Support**



**Figure A-7 New Cable Installation for the 8086/8088 Probe**



The two cables that you will replace connect the two halves of the probe buffer box. One half of the buffer box contains the probe buffer board (the words "PROBE BUFFER" are silk-screened on it); this half of the buffer box is shipped with the emulation base module. The other half of the buffer box contains the personality board (the words " 86/8 PERSON-ALITY" are silk-screened on it); this half of the buffer box is shipped with the 8086/8088 personality module. Jack numbers specified in the following instructions are also silkscreened on the boards.

- a) Remove the existing cables connected to J5 and J6 of the probe buffer board.
- b) Locate the bag containing the translucent ribbon cables. Each cable is marked with the number 165199-001.
- c) Insert one of the new translucent cables at J6 on the probe buffer board, aligning the red stripe on the cable with pin 1 of the J6 connector (pin numbers are also silkscreened on the boards).

#### **IMPORTANT**

Ensure that the side of the cable connector from which the cable emerges faces away from the buffer box edge (see Figure A-7).

- d) Bend the other end of the cable so that you can insert it at J2 of the personality board.
- e) Repeat steps 3 and 4 for the second cable, connecting the cable from J5 of the probe buffer to J1 of the personality board.
- 2. Ensure that plug W8P2 of the user cable is connected to J3 of the personality board. Ensure that plug W8P3 of the user cable is connected to J4 of the personality board (see Figure A-8).
- 3. Remove any unnecessary slack. Secure the user cable to the buffer box cover.
- 4. Refer to Tables A-l and A-2 and Figure A-9 and install the indicated jumpers on the personality board.



**Figure A-9 Jumper Positions on the 8086/8088 Personality Board**

- 5. If your emulator configuration calls for an 8087 processor used as an internal coprocessor, perform the following steps to install the iSBC 337 MULTIMODULE board in the U52 socket of the personality board. See Figure A-9.
	- a. Remove the 8086 or 8088 microprocessor from the socket at U52.
	- b. Stack three 40-pin sockets (packaged in an accessory kit) in the existing socket at U52.
	- c. Stack three single-pin sockets in the existing socket at E53.
	- d. Stack the remaining three single-pin sockets in the existing socket at E54.
	- e. Install the microprocessor in the PI socket of the iSBC 337 MULTIMODULE board.
	- f. Install the iSBC 337 MULTIMODULE board in sockets U52, E53, and E54.
- 6. Install the supplied processor chip (8086 or 8088) for your emulator configuration in the U52 socket of the personality board (or PI socket of the iSBC 337 MULTIMODULE board). This CPU chip is specially selected to work in PICE systems.

#### **NOTE**

The microprocessors supplied with the probes are special PICE components. To avoid timing problems, do not use standard production microprocessors with the PICE system.

7. Connect the two halves of the buffer box and secure with two screws, lockwashers, and washers.

The 8086/8088 personality board contains a 74F244 IC installed in a socket at location U30 that causes a 3.2 mA input current (IIL) on the CLK user pin. This load may be excessive in some user applications.

If loading on the CLK pin is critical for applications of 8 MHz and below, replace the 74F244 IC (at location U30 of the 8086/8088 personality board) with the 74S244 packaged with the 8088 microprocessor. This change reduces the input current (IIL) from 3.2 mA to 0.8 mA. In applications between 8 MHz and 10 MHz, the 74F244 IC must remain installed in U30.

#### **Installing the 8086/8088 User Cable**

When you are first learning about the PICE system, you will want to have the user cable looped back to the top of the buffer box for use with the PICE tutorial. Later, when you are ready to connect your probe to your prototype hardware (also called target hardware), return to this section for information on connecting the user cable to prototype hardware.

Figure A-10 shows the 8086/8088 user cable and gives its length and the height of the user plug.

To guard against electrical noise problems, the two ground pins (1 and 20) on the 8086/8088 probe are connected. The connection is at the end of the user cable in the microprocessor carrier. When connecting the user cable to prototype hardware or to the top of the buffer box, take care that pin 1 is in the correct position. Damage may result if the cable is connected


incorrectly (see Figure A-l 1). On some versions a dot identifies the position on the buffer box socket that is intended to contain pin 1 of the user cable. Connect the cable to the top of the buffer box now; note the following caution before you make the connection.

## CAUTION

Connecting the user cable to the top of the buffer box in the wrong orientation shorts + 5V to ground on the personality board. Connecting the user cable to prototype hardware in the wrong orientation shorts  $+5V$  on the prototype to ground on the personality board. Refer to Figure A-11 for the correct orientation of the user cable.

When you want to connect your user cable to prototype hardware, you must determine whether sufficient room exists for placement of the user cable. If the prototype hardware resides in a card cage with a minimum inter-board separation of 0.56 inches (the MULTIBUS card cage), the slot above the prototype board must remain empty to allow access for the 8086/8088 user cable.

If you have multiple PICE chassis, install the emulation clips on the other chassis.

This completes installation of the 8086/8088 probe. If you have no other personality modules to install, go now to the emulation clips installation section that follows the section on installing the 80286 user cable.

### **Installing the PICE™ System 80186/80188 Emulation Personality Module**

The 80186/80188 emulation personality module consists of the 80186/80188 personality board, the user cable, and the buffer box cover. The 80186/80188 emulation personality module connects to the buffer base assembly and configures the generic portion of the PICE system to emulate a specific processor. Refer to Figures A-12 and A-13 when installing the 80186/ 80188 personality module. Many of the steps described here may have already been performed; you need only verify them.

1. Connect the ribbon cable from J5 of the buffer board to J1 of the personality board (see Figure A-12).



**Figure A-11 The Correct Orientation of the 8086/8088 User Cable**

- 2. Connect the ribbon cable from J6 of the buffer board to J2 of the personality board (see Figure A-12).
- 3. Install the indicated jumpers for the emulator configuration (see Figure A -13):

E17-E18 for 16-bit emulation (80186) E 16-E17 for 8-bit emulation (80188)

4. Verify that the proper microprocessor chip (80186 or 80188) for the emulator configuration is in the U 19 socket of the personality board. Note that this is a bond-out chip available only from Intel. The U 19 socket is on the personality board; the PGA socket on top of the buffer box is reserved for the user cable in loopback mode.



The microprocessors supplied with the probes are special FICE components. To avoid problems and potential damage, do not use standard production microprocessors with the FICE system.

5. Connect the two halves of the buffer box and secure with two screws, lockwashers, and washers.

 $\mathcal{L}^{\mathcal{L}}$ 



Figure A-12 80186/80188 and 80286 Emulation Personality Module Installation



Figure A-13 Jumper Positions on the 80186/80188 Personality Board

## **Installing the 80186/80188 User Cable**

When you are first learning about the PICE system, you will want to have the user cable looped back to the top of the buffer box for use with the PICE tutorial. Later, when you are ready to connect your probe to your prototype hardware (also called target hardware), return to this section for information on connecting the user cable to prototype hardware.

Figure A-14 shows the 80186/80188 user cable and its pertinent dimensions.

Prepare now to connect the user cable to the top of the buffer box. You must orient the user socket on the prototype board so that pin 1 is toward the edge connectors and on the right when facing the front of the card cage (see Figure A-14). Read the directions in the following caution note.

## CAUTION

When you connect the user cable to the socket assembly, be careful not to damage the tab by pin 1. Install the user cable as follows (see Figure  $A-15$ ):

- 1. Carefully place the user cable in place while observing that the pin 1 tab is not damaged by the end of the cable.
- 2. Slide the retaining clip in place.
- 3. Turn the retaining bail to secure the user cable in place.







**Figure A-15 Connecting the 80186/80188 User Cable**

When you want to connect your user cable to prototype hardware, you must determine whether sufficient room exists for placement of the user cable. If the prototype hardware resides in a card cage with a minimum inter-board separation of 0.56 inches (the MULTIBUS card cage), the slot above the prototype board must remain empty to allow access for the 80186/80188 user cable.

#### **NOTE**

When you use the 80186/80188 or 80286 probe, Intel recommends that the prototype contain the Textool/3M socket 268-5400.

If you have multiple PICE chassis, install the emulation clips on the other chassis.

This completes installation of the 80186/80188 probe. If you have no other personality modules to install, go now to the emulation clips installation section that follows the section on installing the 80286 user cable.

## **Installing the PICE™ System 80286 Emulation Personality Module**

The 80286 emulation personality module consists of the two 80286 personality boards, the user and ground clip cables, and the 80286 buffer box cover. The 80286 emulation personality module connects to the buffer base assembly and configures the generic portion of the PICE system to emulate a specific processor. Refer to Figure A-12 when installing the 80286 emulation personality module. Many of the steps described here may have already been performed; you need only verify them.

- 1. Connect the ribbon cable from J5 of the buffer board to J1 of the personality board (see Figure A-12).
- 2. Connect the ribbon cable from J6 of the buffer board to J2 of the personality board (see Figure A-12).
- 3. Ensure that plugs P2 and P3 of the user cable are connected to J4 of the personality board. Ensure that plugs P4 and P5 of the user cable are connected to J3 of the personality board (see Figure A-12).
- 4. Connect the two halves of the buffer box and secure with two screws, lockwashers, and washers.
- 5. Install the printed circuit board (PCB) located at the end of the user cable into the loopback socket assembly that protrudes from the module assembly plastic. Do not remove the socket loopback assembly from the module assembly.

**{ c a u t io n }**

Do not install anything except the user cable in the loopback socket.

#### **Installing the 80286 User Cable**

When you are first learning about the PICE system, you will want to have the user cable looped back to the top of the buffer box for use with the PICE tutorial. Later, when you are ready to connect your probe to your prototype hardware (also called target hardware), return to this section for information on connecting the user cable to prototype hardware.

Figure A-16 shows the 80286 user cable and its pertinent dimensions.

Connect the cable to the top of the buffer box now.

When you want to connect your user cable to your prototype hardware, consider whether enough room is available for the user cable. If the prototype hardware resides in a card cage with a minimum inter-board separation of 0.56 inches (the MULTIBUS card cage), the slot above the prototype board may need to remain empty to allow access for the 80286 user cable.

The slot above the prototype need not be empty if the user socket on the prototype has pin 1 toward the edge connectors and on the right when facing the front of the card cage (the A • A ORIENTATION DOES NOT REQUIRE EXTRA SLOT

• B ORIENTATION REQUIRES EXTRA SLOT



orientation). The slot above the prototype must be empty if pin 1 of the user socket is in any other position (the B orientations) because the B orientations require additional room for a bend in the cable (see Figure A-16).

The A and B orientation cautions do not take into account the pin-grid-array (PGA) socket plugged into the leadlcss-ehip-earricr (LCC) socket at the end of the user cable. This socket adds 0.116 inches. If you retain the PGA socket at the end of the cable, even the A orientation may require an empty slot.

#### **NOTE**

When you use the 80186/80188 or 80286 probe, Intel recommends that the prototype contain the TextooI/3M socket 268-5400.

This completes installation of the 80286 probe. If you have no other personality modules to install, go now to the emulation elips installation section.

## **Installing the Emulation Clips Module**

After your personality modules are installed, perform the following steps to install the emulation clips module.

- 1. Connect the terminator assembly to the emulation clips module (P2 to J2) (see Figure  $A-17$ ).
- 2. Install as many microhooks as needed for the system on the wires of the terminator assembly (see Figure A-17).
- 3. Feed the W5P1 end of the emulation clips cable through the external strain relief, then through the left-hand slot at the lower front of the instrumentation chassis, through the internal strain relief, and connect W5P1 to jack J1 on the break/trace board (see Figures A-4 and A-18).

If you have multiple PICE chassis, install the emulation clips on the other chassis.

This completes installation of the emulation clips module. If you have the iLTA logical timing analyzer option, go to the next section. If you do not have this option, remove any unnecessary slack from the probe cables and any other chassis cables. Secure the cables to the bottom of the instrumentation chassis with the supplied cable clamps; then skip the next section and go to the Host Installation section.



**Figure A-17 Assembling the Emulation Clips Module**



**Figure A-18 Instrumentation Chassis Cables**

 $\bar{\lambda}$ 

## **Installing the iLTA Logic Timing Analyzer Option**

Each instrumentation chassis can have only one iLTA module. [The iLTA option is not available for Model 800 or IBM PC hosts.] Refer to Figures A-4 and A -18 when you install the iLTA module.

1. Install the iLTA board in the top slot of the LICE instrumentation chassis.



The iLTA board must be installed in the top slot to ensure proper cooling.

- 2. Route the two iLTA probe cables through the external strain relief on the bottom of the instrumentation chassis and then through the cable slots at the front of the instrumentation chassis base. Route both iLTA probe cables through the left-hand cable slot (together with the emulation clips module cable—see Figure A -18).
- 3. Connect the 7A1P1 connector of the channel 0-7 probe cable to jack J1 of the iLTA board (see Figures  $A-4$  and  $A-18$ ).
- 4. Connect the 8A1P1 connector of the channel 8-F probe cable to jack J2 of the iLTA board (see Figures  $A-4$  and  $A-18$ ).
- 5. Remove any unnecessary slack from the probe cables and any other chassis cables. Secure the cables to the bottom of the instrumentation chassis with the supplied cable clamps.
- 6. Connect a terminator assembly on the end of each of the iLTA probes.
- 7. Install the microhooks needed for the system on the wires of the terminator assembly.

#### **NOTE**

With an iLTA unit installed, there may be some degradation of ESD and AC line noise immunity.

## **Host Installation Information**

You have now completed the installation of host-independent portions of the overall FICE system installation process. Next you must install host-dependent portions.

If your host system has a non-standard terminal, go now to Appendix B for information on configuring your terminal.

If you have an IBM PC host, refer now to Appendix C. If you have an Intel host you did not receive the Appendix C for IBM PC hosts. Instead, you received Appendixes C through G that concern Intel hosts. Table A-3 shows to which appendix (or appendixes) owners of Intel hosts should now refer.

| <b>Your Host</b>        | <b>Hardware Installation</b><br>Appendix | Software Installation<br>Appendix |
|-------------------------|------------------------------------------|-----------------------------------|
| Model 800               |                                          |                                   |
| Stand-alone Series III  |                                          | E                                 |
| Series III on a Network |                                          | F                                 |
| Series IV               | G                                        | G                                 |

**Table A-3 Intel Host Installation Appendixes**

# B  **CONFIGURING THE l**2**ICE™ SYSTEM FOR NON-STANDARD HOST TERMINALS**

The PICE system is designed to run on either an Intel host development system with a standard Intel CRT or on an IBM PC/AT or PC/XT with a standard terminal. The codes expected from the terminal or sent to the terminal are those used by standard Intel or IBM terminals.

You must configure a non-standard terminal for use with the PICE system. Do this by creating a CRT file that contains configuration commands that change the terminal codes to those expected by PICE software.

If your terminal is one commonly used with Intel equipment, check *The AEDIT User's Guide* (order number 121756) for the listings of some commonly used CRT configuration files.

Include the CRT configuration file when you invoke PICE software. If you name the file I2ICE.CRT, PICE software automatically configures the terminal to its specifications. Otherwise, you must specify the file in the invocation line. For example, the following command for a stand-alone Series III host invokes PICE software and configures the terminal according to the specifications in the CRT file, 1510T.CRT.

#### **\*RUN :F1;I2ICE CRT(:F2:t510T,CRT)**

## **Creating a CRT File**

Check the user's manual that comes with the terminal for the codes expected and generated by the terminal. To create a CRT file, compare the terminal's behavior with the following PICE software expectations:

- ASCII codes 20H through 7EH display some symbol requiring a one-column space. The carriage return (ODH), linefeed (OAH), and backspace (08H) perform their usual functions.
- There are cursor key output codes and CRT cursor move input codes for the cursor functions down, home, left, right, and up. There are also cursor key input codes for clear screen, clear rest of screen, and clear line.
- The home position is the upper left corner.
- The terminal accepts a blank-out code that blanks out the contents of the screen.
- The CRT has 22 to 25 lines.
- The screen scrolls. When the cursor is on the bottom line of the screen and you press RETURN (or Enter) or the line wraps around from the right margin, the top screen line is deleted and the screen rolls up one line.

l int⊿i li

The FICE software automatically generates a linefeed each time the carriage return is entered. The terminal should not generate a linefeed with a carriage return. In some terminals, this function can be switched on and off. ;

## **Configuration Commands**

Configuration commands modify the environment and the communication link between PICE software and the keyboard and the screen. There are two types of configuration commands. The A command modifies the way data is presented on the screen. The AF command modifies the codes to and from the terminal.

The format of the A command is as follows:

 $Acode = value$ 

Where:

A is the command name.

*code* represents a single character specifying which parameter is to be changed.

*value* is a hexadecimal number except for the number of lines shown on the display.

The following examples use the A command.

 $AV = 22$  changes the number of lines on the screen to 22.

 $AB = 7$  changes the keyboard BREAK character to CTRL-G (which has a hexadecimal value of  $07$ ).

The format of the AF command is as follows:

AF *c o d e* = *value*

Where:



The following examples use the AF command.

- **AFMD** $= 0$ A specifies that the code required to move the cursor down the screen is a single linefeed (OAH).
- **AFER** specifies that the terminal being used does not have an erase-rest-ofscreen code.

Table B-l lists the valid codes and their values for the A configuration. Table B-2 lists the AF configuration command values.

 $\mathcal{L}^{\text{max}}$ 

| Acode     | Series III<br>& IBM PC*<br><b>Defaults</b> | <b>Series IV</b><br><b>Defaults</b> | <b>Description</b>                                                                                                                                                                                                                                                       |
|-----------|--------------------------------------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AB        | <b>1B</b>                                  | 1B                                  | $ESCAPE - a$ new value should be assigned for<br>terminals that require the ESCAPE key for control<br>sequences.                                                                                                                                                         |
| <b>AO</b> | 0                                          | 20                                  | The offset value to be added to the row and<br>column numbers following the cursor control<br>sequence of the AF command AFAC. The value<br>must be entered as a single hexadecimal byte.<br>The setting has no effect until cursor addressing<br>mode is set with AFAC. |
| <b>AR</b> | 7F*                                        | 7F                                  | RUBOUT - deletes the character to the left of the<br>cursor.                                                                                                                                                                                                             |
| AV        | 25                                         | 25                                  | The number of lines displayed on each screen.<br>The possible values are 22, 23, 24, or 25. Screens<br>smaller than 25 lines have a smaller command<br>area; the text area remains the same at 20 lines. It<br>is entered as a decimal value.                            |
| AW        | $T^*$                                      | F                                   | T (true) indicates that the terminal generates a<br>carriage return and linefeed if a character is<br>printed in column 80 (a wrapping terminal).                                                                                                                        |
|           |                                            |                                     | F (false) indicates that the terminal is not a<br>wrapping terminal.                                                                                                                                                                                                     |
| AX        | т                                          | F                                   | Cursor addressing format. The cursor address is<br>an ordered pair of $(x, y)$ coordinates. The format<br>can be (column, row) or (row, column).                                                                                                                         |
|           |                                            |                                     | T sets the format as (column, row).<br>F sets the format as (row, column).                                                                                                                                                                                               |

**Table B-l The A Configuration Command Values**

\*The defaults for the IBM PC/AT and PC/XT are the same as those for the Series III, with two exceptions. The IBM PC default values for AR and AW are as follows:

$$
AR = 08
$$
  

$$
AW = F
$$

 $\mathcal{L}^{\text{eff}}$ 

**Configuring the PICE™ System for Non-Standard Host Terminals B-3**

 $\mathcal{L}$ 



#### **Table B-2 The AF Configuration Command Values**

\*The defaults for the IBM PC/AT and PC/XT are the same as those for the Series III, with three exceptions. THe IBM PC default values for AFAC, AFDL, and AFIL are as follows:

> $AFAC = 1B47$  $AFDL = 1B49$  $AFIL = 1B4C$

J,

 $\overline{z}$ 

 $\bar{\omega}_\mathrm{a}$ 

ζŊ.

 $\overline{a}$ 

 $\alpha$ 

| <b>AFcode</b> | Series III<br>& IBM PC*<br><b>Defaults</b> | <b>Series IV</b><br><b>Defaults</b> | <b>Description</b>                                                                                                                             |
|---------------|--------------------------------------------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>AFIL</b>   | (null)*                                    | (null)                              | Insert line code. Used for reverse scrolling.                                                                                                  |
| <b>AFMB</b>   | 0D                                         | 0D                                  | Code to move the cursor to the beginning of the<br>line.                                                                                       |
| <b>AFMD</b>   | 1C                                         | 1B02                                | Code to move the cursor down.                                                                                                                  |
| <b>AFMH</b>   | 1D                                         | 1B08                                | Code to move the cursor to the home position.                                                                                                  |
| <b>AFML</b>   | 1F                                         | 1B04                                | Code to move the cursor to the left.                                                                                                           |
| <b>AFMR</b>   | 14                                         | 1B03                                | Code to move the cursor to the right.                                                                                                          |
| <b>AFMU</b>   | 1E                                         | 1B01                                | Code to move the cursor up.                                                                                                                    |
| <b>AFTM</b>   | 16                                         | 16                                  | CTRL-V $-$ this command is unique to $PICE$<br>systems. It sets the control character that<br>enables you to turn the menu display on and off. |
| <b>AFXA</b>   | 1                                          | 1                                   | CTRL-A - delete right.                                                                                                                         |
| <b>AFXF</b>   | 6                                          | 80                                  | CTRL-F - character delete.                                                                                                                     |
| <b>AFXU</b>   | 15                                         | 15                                  | CTRL-U - undo command.                                                                                                                         |
| <b>AFXX</b>   | 18                                         | 18                                  | $CTRL-X$ — delete left.                                                                                                                        |
| <b>AFXZ</b>   | 1A                                         | 82                                  | $CTRL-Z$ $-$ clear line.                                                                                                                       |

**Table B-2 The AF Configuration Command Values (continued)**

\*The defaults for the IBM PC/AT and PC/XT are the same as those for the Series III, with three exceptions. THe IBM PC default values for AFAC, AFDL, and AFIL are as follows:

> $AFAC = 1B47$  $AFDL = 1B49$  $AFIL = 1B4C$

 $\ddot{\phantom{a}}$ 

## **GLOSSARY**

**■ ■ ■ ■ ■ ■ in te rs**



 $\ddot{\phantom{a}}$ 

 $\bar{a}$ 



 $\hat{L}$ 

 $\frac{1}{2} \frac{1}{2} \frac{d^2}{dx^2}$ 



 $\ddot{\phantom{a}}$ 

 $\bar{z}$ 

 $\hat{\mathcal{A}}$ 

**INDEX**

**h** inteT **b h**

\$ pseudo-variable, 3-30 \* high-address-bits override, 4-21 \* prompt, 2-3, 3-3, 3-28 + 5-volt source and user substrate capacitor, 80286 probe, 4-24 \ (backslash) command, 6-1, 6-3 10-MHz 8086 probe MAX mode operation, 4-7 87 INT test point, 4-5 8086 environment, 1-12 8086/8088 personality board jumper positions, A-9 8086/8088 personality module (probe): 4-1 considerations, 4-8 installation, A-4 jumper configurations, A-6 user cable dimensions, A-11 user cable installation, A-10 8087 coprocessor: 4-4, 4-5, 4-6, 5-1 installation, A-10 support, jumpering for, A-10 test point, 4-5 8089 I/O processor, 5-1 80186/80188 personality board jumper positions, A-13 80186/80188 personality module (probe): 4-7 considerations, 4-8 installation, A-11 user cable dimensions, A-14 user cable installation, A-14 80286 microprocessor/80286 probe reset, 4-23 80286 personality module (probe): 4-12 80287 numeric processor extension, 4-19, 5-1 address protection, 4-17 address translation, 4-13 considerations, 4-20 global descriptor table (GDT), 4-14, 4-16 interrupts, 4-17 installation, A-16 local descriptor table (LDT), 4-14, 4-17 memory mapping, 4-18, 4-26 multitasking, 4-16 registers and flags, 4-19 task-state segment, 4-16 virtual address translation, 4-14 user cable dimensions, A-17 user cable installation, A-16

80286/8086: address translation, 4-21, 4-22 loader, 4-25 80287 numeric processor extension, 4-19, 4-22, 5-1 82188 coprocessor interface chip, 5-1 Aborting commands, 3-3 Access codes, 3-39 Accessories of the PICE system, 1-7 Address/data (AD) bus float, 8086/8088 probe, 4-7 ADDRESS memory type, 3-15 Address: even and odd, 3-44 thru 3-55 protection, 80286 probe, 4-17 translation, 80286 and 8086, 4-13, 4-21, 4-22 wrap-around, 8086/8088 probe, 4-2 wrap-around, 80286 probe, 4-26 AEDIT V1.0 editor, 3-10 ALE: pulse stretching, 80186/80188 probe, 4-12 signal, 8086/8088 probe, 4-7 APPEND command, 3-13 Arm: registers, 3-36 specifications, 3-35 windows, 3-35, 3-36 Arming the PICE system, 6-2 ARMREG command, 3-9, 3-35, 3-36 ASM memory template, 3-15 thru 3-17 Base configuration of the PICE system, 1-4 thru 1-6 BCD memory template, 3-15 Block commands, 3-7 BOOLEAN memory template, 3-15 Break: and trace lines, 3-26, 6-1, 6-3 registers, 3-36 windows, 3-36 Break/trace board, 1-5, 1-10, A-4 Breaking: 3-34 thru 3-37 and the RESET signal, 8086/8088 probe, 4-6 in the middle of an instruction: 8086/8088 probe, 4-3 80186/80188 probe, 4-9 on even and odd addresses, 3-44 thru 3-55 Breakpoint slipping: 3-43, 4-3, 4-9, 4-20, 4-21 8086/8088 probe, 4-3 80186/80188 probe, 4-9 80286 probe, 4-20, 4-21

Breakpoint specifications, 3-34 BRKREG command, 3-9, 3-35, 3-36 BTHRDY pseudo-variable: 3-21 8086/8088 probe, 4-4 80186/80188 probe, 4-11 Buffer base assembly: 1-10, A-4 jumpering, A-4 Buffer board, 1-5, 1-10 Buffer, command history, 3-5 Bus float (data/address), 8086/8088 probe, 4-7 Bus inactive time-out, 3-34 BUSACT pseudo-variable: 3-21, 3-34, 6-7 80286 probe, 4-25 BYTE memory template, 3-15 Byte: reads from even and odd addresses, 3-51 writes from even and odd addresses, 3-47 Byte-wide ports, 3-22, 3-24 Cable, internal host installation, see Intel host hardware installation appendix Cables, system interface, 1-11 Cascade interrupt address, 80286 probe, 4-24 CAUSE command, 6-6 CHAR memory template, 3-15 Checkout and installation, see appendixes Clips emulation, 3-25 Clipsin lines, 3-25 CLIPSOUT command: 3-25 8086/8088 probe, 4-5 Clipsout lines: 3-25 8086/8088 probe, 4-5 Clock low time, 8086/8088 probe, 4-7 Clock, processor (PCLK), 80286 probe, 4-23, 4-24 CNTL-C, see CTRL-C CNTL-V, see CTRL-V COENAB pseudo-variable, 5-2, 5-3 Command: history buffer, 3-5 entry, 3-3 language of the PICE system, 1-14 menu, 3-4 nesting level, 3-8 repetition, 3-17 syntax, xiv Commenting commands, 3-4 Communicating between probes, 6-5 Communication board, 1-4, 1-8 Compiling a source file, 3-27 CONCAT function, 3-6

Concatenating strings, 3-6 Confidence tests: see host hardware installation appendix commands, see host hardware installation appendix messages and flags, see host hardware installation appendix Configuration commands, B-2 Configuration file, see software installation appendix Configuration of the PICE system, 1-4 Configuring the PICE system for non-standard host terminals, B-l Continuing commands to another line, 3-3 Conventions, syntax, xiv Converting memory types, 3-6 Coprocessor: A-4 8086/8088 probe, 4-4, 4-6 80286 probe, 4-24 hangs, 5-1, 5-3 inactive time-out, 5-1 interface chip, 5-1 memory access time-out, 3-34, 5-1 support, 5-1 COREQ pseudo-variable, 4-19, 5-2, 5-4 COUNT block command, 3-7 CPMODE pseudo-variable: 5-2, 5-3, 5-4 8086/8088 probe, 4-6 CRT file: 3-2 creation, B-l CTRL-C, 3-3 CTRL-V, 3-5, 3-29 Current execution point, 3-30 Current unit, 6-1, 6-3 Data/address bus float, 8086/8088 probe, 4-7 DC characteristics of the emulation clips, 1-19 DEBUG flag, confidence test, see host hardware installation appendix Debug: object manipulation commands, 1-14 objects, 3-8, 3-31, 3-32 procedures, 3-8, 3-23, 3-37, 6-5 registers, 3-8, 3-9, 3-30, 3-35, 3-37 variables, 3-8, 3-9, 3-16 Debugging, 3-16 DEFINE command, 3-6, 3-8, 3-9, 3-16, 3-36 thru 3-52, 6-3 DEN signal, 8086/8088 probe, 4-7 Designing hardware, 1-2 Designing software, 1-2 Development process, microcomputer, 1-1 Diagnostic: disks, 1-15 messages and flags, see host hardware installation appendix software, see host hardware installation appendix

DIR command, 3-31 DO-END block, 3-7, 3-8 DOS operating system, 1-14 DT/R signal, 8086/8088 probe, 4-7 DWORD memory template, 3-15 EDIT command, 3-10 Editing external files, 3-11 Editors, 3-4, 3-10 Emulating programs, 3-28, 3-30, 3-34 Emulation: base module, 1-10 base module installation, A-4 break, reason for, 6-6 buffer board, 1-10 clips, 1-05, 1-7, 3-25 clips assembly, 1-11 clips module installation, A-18 commands, 1-14 mode, 8086/8088 probe, 4-6 mode, 80286 probe, 4-23 Emulation personality modules (probes), 1-11 Emulation personality module installation: 8086/8088 probe, A-4 80186/80188 probe, A -ll 80286 probe, A-16 Enabling PICE units, 6-3 Environment commands, 1-14 ERRONLY flags, see host hardware installation appendix Error/help disk, 1-15 ESC key used to invoke the screen editor, 3-10 Even addresses: 3-41 breaking, 3-44 byte reads, 3-51 byte writes, 3-47 word reads, 3-48 word writes, 3-44 Event: machines, 1-4, 1-10, 3-35, 3-37 registers, 3-37 specifications, 6-2 Execution event machine (XEM), 3-35 Execution point, 3-30 EXIT command, 3-32 Exiting the PICE system, 3-32 Extending a command to another line, 3-3 External coprocessors, 5-1, 5-3, 5-4 External file editing, 3-11 EXTINT memory type, 3-15

File: editing, external, 3-11 handling, 3-12 handling commands, 1-14 Final hardware checkout, see host hardware installation appendix Flags and registers, 80286 probe, 4-19 Fully qualified references, 3-17 Functions, 1-14 GET87 command, 5-2, 5-3, 5-4 Global descriptor table (GDT) for the 80286 probe, 4-14, 4-16, 4-17 GO command, 3-30 thru 3-32, 3-34, 3-44 thru 3-53, 6-2, 6-3 GRANULARITY pseudo-variable, 80286 probe, 4-18, 4-26 Guarded memory, 3-19, 4-18 HALT command, 3-3, 3-21 Hang condition, 80186/80188 probe, 4-10, 4-11 Hangs, coprocessor, 5-3 Hardware: base configuration, 1-4 components, 1-8 design, 1-2 installation, see appendixes overview, 1-8 slipping on a breakpoint, 3-43, 4-20, 4-21 slipping past a breakpoint, 80286 probe, 4-20 Hardware/software integration, 1-3 High-address-bits override, 80286 probe, 4-21 High-speed (HS) memory: 1-11, 3-19, 4-18 8086/8088 probe, 4-4 History buffer, 3-5 HOLD/HLDA signal: 8086/8088 probe, 4-6 80286 probe, 4-25 Host installation information, A-20 Host interface board: 1-4, 1-8 installation, see host hardware installation appendix Host requirements for supporting the PICE system, 1-17 Host software, 1-6, 1-12, 1-15 disks, 1-15 PICE system: accessories, 1-7 and microcomputer development, 1-1 base configuration, 1-4 command language, 1-14 command menu, 3-4 hangs, 80186/80188 probe, 4-10, 4-11 installation and checkout, see appendixes

introduction, 1-3 options, 1-6 software installation, see software installation appendix software invocation, 1-1, 3-28 specifications, 1-17 tutorial, 1-16, 2-1 IBM PC/XT and PC/AT: confidence tests, see IBM installation appendix configuration requirements, 1-18 memory requirements, see IBM installation appendix operating system, 1-14 software installation, see IBM installation appendix IF block command, 3-7 INCLUDE command, 3-13 Including files, 3-13 Index of tutorial topics, 2-13 iNDX operating system, 1-14 Initialization segment, 80286 probe, 4-25 Installation and checkout, see appendixes Installation: 8086/8088 probe, A-4 8086/8088 probe user cable, A-10 80186/80188 probe, A -ll 80186/80188 probe user cable, A-14 80286 probe, A-16 80286 probe user cable, A-16 host information, A-20 piggy-back board on 8086/8088 probe, A-10 INSTR function, 3-7 Instrumentation chassis: 1-4, 1-8, A-1 installation, A-l INTA signal, 8086/8088 probe, 4-7 INTEGER memory template, 3-15 Integrating hardware and software, 1-3 Intel Logic Timing Analyzer (iLTA): 1-3, 1-6, 1-11 disks, 1-16 Intellec Series III: confidence tests, see Series III hardware installation appendix configuration requirements, 1-18 internal host cable, see Series III hardware installation appendix memory requirements, see Series III hardware installation appendix operating system, 1-13 software installation, see software installation appendix Intellec Series IV: confidence tests, see Series IV hardware installation appendix configuration requirements, 1-18 internal host cable, see Series IV hardware installation appendix memory requirements, see Series IV hardware installation appendix operating system, 1-14

software installation, see software installation appendix Interface cables, 1-11 Interface chip, 5-1 Internal coprocessors, 5-1, 5-3, 5-4 Internal host cable installation, see Intel host hardware installation appendix Inter-probe communication, 6-5 Interrogation mode: 80286 probe, 4-22 8086/8088 probe, 4-6 Interrupt line (INTR), 8086/8088 probe, 4-4 Interrupts, 80286 probe, 4-17 Invoking the PICE system software, 3-1, 3-28 I/O access time-out, 3-34 I/O mapping: 3-21, 3-29 80286 probe, 4-26 I/O simulation: from the console, 3-22 with a debug procedure, 3-23 I/O space management, 3-19 IORDY pseudo-variable, 3-21, 3-34 ISIS operating system, 1-13 ISTEP command: 3-17 8086/8088 probe, 4-4 . Jumper configurations on the 8086/8088 personality module, A-6 Jumper positions: on the 8086/8088 personality board, A-9 on the 80186/80188 personality board, A-13 Jumpering for 8087 support, 8086/8088 probe, A-7 Line editor, 3-4 Link file locating, 3-27 Linking the object file, 3-27 LIST command, 3-12 List files, 3-12 LITERALLYs, 3-5, 3-9 LOAD command, 3-14, 3-16, 3-29, 3-32, 3-38, 6-4 Loader, 80286/8086, 4-25, 4-26 Loading programs, 3-29, 3-32 Local descriptor table (LDT) for the 80286 probe, 4-14, 4-19 Locating the link file, 3-27 Log files, see List files Logic probe pods, 1-7 LONGINT memory template, 3-15 LONGREAL memory template, 3-15 Macro files, 3-2, 3-9

Manuals, PICE system, xii MAP command, 3-19 thru 3-21, 3-29, 3-38, 3-44, 3-48 Map-I/O board, 1-4, 1-10 MAPIO command, 3-21 thru 3-24, 3-29 Mapping considerations, 80186/80188 probe, 4-10 Mapping I/O: 3-21 thru 3-24, 3-29 80286 probe, 4-26 Mapping memory: 3-19, 3-29 80286 probe, 4-18,4-26 MAX mode, 8086/8088 probe, 4-6, 4-7 Memory access time-out, 3-34 Memory management, 3-19 Memory mapping: 3-19 80186/80188 probe, 4-10 80286 probe, 4-18, 4-26 Memory requirements, see host hardware installation appendix Memory type conversion, 3-6 Memory types, 3-15, 3-18 MEMRDY pseudo-variable: 3-21, 3-34, 6-7 80186/80188 probe, 4-11 80286 probe, 4-25 Menu, 3-29 MENU command, 3-5, 3-29 Microcomputer development process, 1-1 Microhook, 1-7 MIN mode, 8086/8088 probe, 4-6, 4-7 M/IO signal, 8086/8088 probe, 4-7 Model 800: confidence tests, see Model 800 hardware installation appendix configuration requirements, 1-17 host/chassis cable, see Model 800 hardware installation appendix memory requirements, see Model 800 hardware installation appendix operating system, 1-13 software installation, see software installation appendix MRDC signal, 8086/8088 probe, 4-7 Mtypes, 3-15, 3-18 MULTIBUS (MB) memory, 1-8, 3-19, 4-18 Multiple commands on a line, 3-4, 3-9 Multiple-unit PICE system, 1-6 Multi-probe systems, 6-1 Multitasking, 80286 probe, 4-16 NDS-II, loading and running PICE system software on, see software installation appendix Nesting level of commands, 3-8 Non-maskable interrupt (NMI), 8086/8088 probe, 4-4, 4-6 Non-maskable interrupt (NMI) line, 8086/8088 probe, 4-4 Non-standard terminal configuration, B-l Numeric processor extension, 80286 probe, 4-22 NUMTOSTR function, 3-6 Object file linking, 3-27

Odd addresses: 3-41

breaking, 3-44 byte reads, 3-51 byte writes, 3-47 word reads, 3-48 word writes, 3-44 OHS memory, see optional high-speed memory Operating systems, 1-12 Optional high-speed (OHS) memory, 1-11, 3-19, 4-18 Options of the PICE system, 1-6 Partially qualified references, 3-18 Pathname, 3-12 PCHECK pseudo-variable: 4-17, 4-19, 4-20 80286 probe, 4-21 Performance, PICE system, 1-18 Personality board, 1-5 Personality module installation 8086/8088 probe, A-4 80186/80188 probe, A-11 80286 probe, A-16 Personality module jumper positions, 80186/80188 probe, A-13 PHANG pseudo-variable, 3-21, 3-34, 5-1 Piggyback board installation, 8086/8088 probe, A-10 POINTER memory template, 3-15, 4-13, 4-15 PRINT command, 3-38 thru 3-55 Probe: 4-1 buffer box, 1-5 disks, 1-15 electrical characteristics, 1-19 hangs, 80186/80188 probe, 4-10, 4-11 installation, 8086/8088 probe, A-4 installation, 80186/80188 probe, A-11 installation, 80286 probe, A-16 jumper positions, 80186/80188 probe, A-13 MIN mode operation, 8086/8088 probe, 4-7 software, 1-12 Probe-specific commands, 1-14 PROC command, 3-8 Processor clock (PCLK), 80286 probe, 4-23, 4-24 Program: emulation, 3-30, 3-34 files, 3-14 loading, 3-29 prologue, 3-16 stepping, 8086/8088 probe, 4-4 variables, 3-16, 3-17, 3-18 Prologue of program, 3-16 Prompt (\*) for PICE system software, 2-3, 3-3, 3-28 Prototype/probe synchronization:

8086/8088 probe, 4-4 80186/80188 probe, 4-11 PSCOPE-86: disk, 1-16 software, 1-6 Pseudo-variables, 1-15 Publications, PICE system, xii Pulse stretching, ALE (80186/80188 probe), 4-12 PUT command, 3-13, 3-32 QSTAT pseudo-variable, 4-8 Read-after-write verification, 3-20 Read-only memory, 3-20 READY hang, 6-6 READY signal: 3-21 set-up time, 8086/8088 probe, 4-4 80186/80188 probe, 4-10 thru 4-12 REAL memory template, 3-15 Real mode, 80286 probe, 4-22 Re-executing commands, 3-17 Registers and flags, 80286 probe, 4-19 Registers: ARMREG, 3-36 BRKREG, 3-36 EVTREG, 3-37 SYSREG, 3-36 TRCREG, 3-37 Related publications, xii Removing the user cable, 3-54 Renaming PICE system files, 3-3 Repair and service assistance, xix REPEAT block command, 3-7 Request/grant: line, 8086/8088 probe, 4-4 signal, 8086/8088 probe, 4-6 RESET: command, 80286 probe, 4-22 ICE command, 80286 probe, 4-23 REGS command, 80286 probe, 4-23 signal, 8086/8088 probe, 4-6 UNIT command, 3-21 UNIT command, 80286 probe, 4-22 Resetting the 80286 microprocessor and the 80286 probe, 4-23 Returning to host development operating system, 3-32 Sample Pascal program, 3-26, 3-33

Sample programs in C, FORTRAN, and Pascal, 2-30 SASM command, 3-48, 3-49, 3-51, 3-53

SAVE command, 3-14 Saving debug object definitions, 3-32 Screen editor, 3-10 Segment boundary increments: 8086/8088 probe, 4-3 80186/80188 probe, 4-10 SEL286 pseudo-variable, 80286 probe, 4-13, 4-21, 4-22 SELECTOR memory template, 3-15 Selector:selector:offset triplet, 80286 probe, 4-22 SEM, 3-35 Series III, see Intellec Series III Series IV, see Intellec Series IV Service and repair assistance, xix Set-up time for the READY signal, 8086/8088 probe, 4-4 SHORTINT memory type, 3-15 Signal generator: 3-22 8086/8088 probe, 4-6 Signals: ALE, 8086/8088 probe, 4-7 DEN, 8086/8088 probe, 4-7 DT/R, 8086/8088 probe, 4-7 HOLD/HLDA, 8086/8088 probe, 4-6 HOLD/HLDA, 80186/80188 probe, 4-11 HOLD/HLDA, 80286 probe, 4-25 INTA, 8086/8088 probe, 4-7 M/IO, 8086/8088 probe, 4-7 MRDC, 8086/8088 probe, 4-7  $\overline{R}/\overline{GT}$ , 8086/8088 probe, 4-6 READY, 8086/8088 probe, 4-4 READY, 80186/80188 probe, 4-10 thru 4-12 Simulating I/O: from the console, 3-22 with a debug procedure, 3-23 Single-line assembler, 3-48, 3-49, 3-51, 3-53 Slipping on a breakpoint, 3-43, 4-20 Slipping past breakpoints: 80286 probe, 4-20, 4-21 on combined instructions, 8086/8088 probe, 4-3 on combined instructions, 80186/80188 probe, 4-9 Slipping past instruction breakpoints: 8086/8088 probe, 4-3 80186/80188 probe, 4-9 Software: base configuration, 1-6 design, 1-2 environment, 1-12 installation, see software installation appendix invocation, 3-1, 3-28 overview, 1-12

packaging, 1-15 Software/hardware integration, 1-3 Source file compilation, 3-27 Specifications, I<sup>2</sup>ICE system, 1-17 STATUS command, 80286 probe, 4-23 Stepping through user programs, 8086/8088 probe, 4-4 String handling, 3-6 Submit file, 3-27 SUBSTR function, 3-6 Substrings, 3-6 Symbolic: debugging, 3-16 display, 3-31 support for multiple probes, 6-4 SYNC START test point: 6-6, 6-7 80186/80188 probe, 4-11, 4-12 80286 probe, 4-25 8086/8088 probe, 4-5 Synchronization between units, 6-6, 6-7 Synchronizing emulation to an external event, 80286 probe, 4-25 Synchronizing the prototype and the probe: 8086/8088 probe, 4-4 80186/80188 probe, 4-11 Syntax conventions, xiv SYSBREAKIN signal, 6-1, 6-3 SYSREG command, 3-30, 3-36 SYSTEM ARM/DISARM command, 6-2 System: break and trace lines, 3-26, 6-1, 6-2 cables installation, see host hardware installation appendix event machine (SEM), 3-35 hangs, 80186/80188 probe, 4-10, 4-11 interface cables, 1-11 performance, 1-18 registers, 3-36 specifications, 1-17, 6-2 SYSTRACE line, 6-1 thru 6-3 SYSTRACEIN signal, 6-1 SYSTRIG line, 6-1 thru 6-3 Task-state segment, 80286 probe, 4-16 TEMPREAL memory template, 3-15 Terminal configuration for non-standard terminals, B-l Test point, user-accessible: 8086/8088 probe, 4-4 80286 probe, 4-25 80186/80188 probe, 4-11 Textool/3M socket: 80186/80188 probe, 4-12

80286 probe, 4-25 TIMEBASE pseudo-variable, 3-42 Time-out pseudo-variables, 3-34, 5-1 Time-outs: MEMRDY, 80186/80188 probe, 4-11 Timetags, 3-42 Timing differences between 80286 probe and 80286 chip, 4-24 Timing differences between probes and chips, 1-19 TP test point, 80186/80188 probe, 4-11 Trace: and break lines, 3-26, 6-1, 6-2 buffer, 2-5, 3-38, 3-42 buffer display, 8086/8088 probe, 4-6 interruption, 3-42 registers, 3-37 specifications, 3-34, 6-3 Tracing: 3-34, 3-38 considerations, 80286 probe, 4-21, 4-24 TRCBUS pseudo-variable, 3-42 TRCREG command, 3-37 TSS command, 4-16 Tutorial: 1-16, 2-1 deactivating, 2-2 disks, 1-16 emulation aid module screens, 2-11 feature aid module screens, 2-12 invoking during program debugging, 2-2 main-path screens, 2-10 menus, 2-4 PL/M program listing, 2-16 program listings, 2-16 reactivating, 2-2 structure, 2-2 topic index, 2-13 UNIT pseudo-variable, 6-1 UNITHOLD command, 3-54 User cable: 80186/80188 probe, 4-12, A-14 dimensions: 8086/8088 probe, A-11 80186/80188 probe, A-14 80286 probe, A-17 installation: 8086/8088 probe, A-10 80186/80188 probe, A-14 80286 probe, A-16 orientation, 8086/8088 probe, A-12 removal, 3-54 User clock loading, 8086/8088 probe, A-10
User memory, 3-19, 4-18, 5-1 User plug, 8086/8088 probe, A-10 User socket: 80186/80188 probe, 4-12, A-14 80286 probe, 4-25 User substrate capacitor and + 5-volt source, 80286 probe, 4-24 User-accessible test points: 8086/8088 probe, 4-4 80186/80188 probe, 4-11 80286 probe, 4-25 Utility commands, 1-14 Variables, 3-16 thru 3-18 Virtual address translation for the 80286 probe, 4-13, 4-14 Virtual addresses, 80286 probe, 4-21 WAIT function, 6-5 WAITSTATE command: 3-19 80186/80188 probe, 4-10 Wait-state generator, 1-10 Wait-states, 1-4 Wait-states, 80186/80188 probe, 4-10 Wait-states, 8086/8088 probe, 4-4 Windows, 3-35, 3-36 WORD memory template, 3-15, 3-31 Word: reads from even and odd addresses, 3-48 writes to even and odd addresses, 3-44 Word-wide ports, 3-22 Wrap-around addresses: 8086/8088 probe, 4-2 80186/80188 probe, 4-9 80286 probe, 4-26 WRITE command, 3-46, 3-48

XEM, 3-35



 $\pmb{\mathfrak{t}}$ 

PICE™ System User's Guide 166298-001

## **WE'D LIKE YOUR OPINI**

Please use this form to help us evaluate the effectiveness of this manual and improve the quality of future documents

To order publications, contact the Intel Literature Department (see page ii of this manual).



## **★ ★ ★ ATTENTION ★ ★ ★**

Receive 50% off on the next Intel publication you buy. Send us your comments, and we'll send you a 50%-off certificate.

 $\hat{\mathcal{G}}_A$ 

If you would like us to call you for more specifics about this book, provide the following information. Please print clearly.



**i Thanks for taking the time to fill out this form.**

## **WE'D LIKE YOUR COMMENTS . . .**

This document is one of a series describing Intel products. Your comments on the back of this form will help us produce better manuals. Each reply will be carefully reviewed by the responsible person. All comments and suggestions become the property of Intel Corporation.

## **BUSINESS REPLY CARD**

FIRST CLASS PERMIT NO. 79 BEAVERTON, OR 95051

NO POSTAGE **NECESSARY** IF MAILED IN THE UNITED STATES

POSTAGE WILL BE PAID BY ADDRESSEE

**Intel Corporation 5200 N.E. Elam Young Pkwy. Hillsboro, OR 97124-6497**

**DSHO Technical Publications**



INTEL CORPORATION, 3065 Bowers Avenue, Santa Clara, California 95051 (408) 987-8080

Printed in U.S.A.

Instrumentation