# **BICEPS-V**

**Emulator Manual** 

Version 7.7

**BRENDES DATENTECHNIK GmbH** 

Dresdener Str. 10D-26160 Bad ZwischenahnGermanyTel.: +49 4403 816838Fax: +49 4403 816839eMail: info@brendes.deInternet: http://www.brendes.de

# Contents

| 1     | Introduction                                        | 1  |
|-------|-----------------------------------------------------|----|
| 2     | Configurating and Starting                          | 5  |
| 2.1   | Configurating the <b>BICEPS</b> emulator            | 7  |
| 2.2   | Configurating the processor adapter (POD)           | 9  |
| 2.3   | Start of the <b>BICEPS</b> emulator with POD        | 10 |
| 2.4   | Special connection types                            | 13 |
| 2.4.1 | Banking                                             | 13 |
| 2.4.2 | BICEPS Universal adapter                            | 13 |
| 2.4.3 | BICEPS Debug-connector                              | 14 |
| 2.4.4 | Active adapter cable A1 (bus mode)                  | 14 |
| 2.5   | Error messages                                      | 15 |
| 3     | Function of the BICEPS Emulator                     | 16 |
| 3.1   | Structure of the <b>BICEPS</b> emulator             | 16 |
| 3.2   | An outline of the Emulation Process                 | 18 |
| 4     | The BicWin User Interface                           | 19 |
| 4.1   | Survey of the operating facilities                  | 19 |
| 4.2   | General aspects of the <b>BicWin</b> user interface | 21 |
| 4.3   | Windows and context menues                          | 22 |
| 4.4   | Status line and mouse panel                         | 23 |
| 4.5   | Dialogs                                             | 23 |
| 5     | Memory Access                                       | 24 |
| 5.1   | Basic Information                                   | 24 |
| 5.2   | Saving and loading files                            | 25 |
| 5.3   | Access to Special Function Registers                | 26 |
| 5.4   | Access to the Program and Data Memory,              | 27 |
| 5.5   | Modification of single memory cells and variables   | 28 |
| 5.6   | Watched variables                                   | 29 |
| 5.7   | Initializing and copying of memory blocks           | 29 |

| 5.8  | Mapping                                             | 3 |  |  |
|------|-----------------------------------------------------|---|--|--|
| 5.9  | Disassembled representation of the program memory   |   |  |  |
| 6    | Break Possibilities                                 |   |  |  |
| 6.1  | Basic information                                   |   |  |  |
| 6.2  | Break mode                                          |   |  |  |
| 6.3  | Definition of break events                          |   |  |  |
| 7    | The Real Time Trace Memory                          | , |  |  |
| 7.1  | Overview                                            |   |  |  |
| 7.2  | Time measurement                                    |   |  |  |
| 7.3  | Search function                                     |   |  |  |
| 7.4  | Sourcetext trace mode                               |   |  |  |
| 7.5  | Control of tracing during program execution         |   |  |  |
| 8    | Program Execution                                   |   |  |  |
| 8.1  | Overview                                            | 4 |  |  |
| 8.2  | Execution of a program in real time, reset          |   |  |  |
| 8.3  | Execution of single steps                           |   |  |  |
| 8.4  | Debugging with Assembler and Sourcetext window      |   |  |  |
| 9    | Sourcetext Debugging                                | , |  |  |
| 9.1  | Introduction                                        |   |  |  |
| 9.2  | Invoking the compiler, loading a program            | 4 |  |  |
| 9.3  | Program execution                                   |   |  |  |
| 9.4  | Handling of several Modules                         |   |  |  |
| 10   | Options for P0/P2 emulation                         |   |  |  |
| 10.1 | The <b>BICEPS</b> Softhooks                         |   |  |  |
| 10.2 | Compatibility with C51 compiler                     |   |  |  |
| 10.3 | Hints for assembler programming                     |   |  |  |
| 10.4 | Specialities for Winbond Turbo51 controller (77E58) |   |  |  |
| 10.5 | Specialities for TI MSC12xx controller              |   |  |  |
| 10.6 | Adavantages and disadvantages of Softhooks          |   |  |  |
| 10.7 | Necessary conditions for <b>BICEPS</b> Softhooks    |   |  |  |
| 10.8 | Softhook sample program                             |   |  |  |

# Appendix

| Α           | BicWin Short Keys                                   | A-1        |
|-------------|-----------------------------------------------------|------------|
| B           | Interfaces                                          | <b>B-1</b> |
| <b>B</b> .1 | Emulation Connector (POD)                           | <b>B-1</b> |
| B.2         | Power supply                                        | <b>B-1</b> |
| B.3         | PC interface (USB or serial)                        | <b>B-1</b> |
| B.4         | Digital inputs                                      | B-2        |
| С           | Description of the Adapters (PODs) for different    |            |
|             | Controllers of the 80C51 Family                     | <b>C-1</b> |
| C.1         | The Universal adapter of the <b>BICEPS</b> emulator | C-1        |
| C.1.1       | Memory circuit types                                | C-2        |
| C.1.2       | Jumper settings                                     | C-4        |
| C.1.3       | Connections via clips cables                        | C-5        |
| C.2         | POD B51 for Standard CPUs in a 40/44 pin package    | C-6        |
| C.3         | POD B51CC for Atmel 89C51CC03/02/03/AC2/AC3         | C-7        |
| C.4         | POD B51CC-52 for Atmel 89C51CC03 (PLCC52)           | C-8        |
| C.5         | POD B51-68 for Atmel 8xC51RD2/ED2 (PLCC68)          | C-9        |
| C.6         | POD B5131USB for Atmel 89C5131                      | C-10       |
| C.7         | POD B51SND1 for Atmel 8xC51SND1                     | C-11       |
| C.8         | POD BuC8xx for AnalogDevices ADµC812/816/824        | C-12       |
| C.9         | POD B552 for Philips 8xC552                         | C-13       |
| C.10        | POD B592 for Philips 8xC592                         | C-14       |
| C.11        | POD B517 for Infineon C517A/80C537                  | C-15       |
| C.12        | POD B390 for Dallas 80C390                          | C-16       |
| D           | BICEPS-Debug-Connector                              | D-1        |
| D.1         | Basic information                                   | D-1        |
| D.2         | P0/P2=Ports, high density pin header                | D-2        |
| D.3         | P0/P2=Bus, standard pin header                      | D-4        |
| D.4         | P0/P2=Bus, banking, standard pin header             | D-5        |
| D.5         | BICEPS-ICE-connect                                  | D-6        |

# **1** Introduction

The in-circuit-emulator **BICEPS** is a professional tool, which considerably eases the development of electronic circuits on the base of microcontrollers of the 80C51 family. The hardware components of the controller as well as the programs executed by it can be emulated in real time, i.e. at the original speed.

For in-circuit emulation the processor will be simply removed from the existing circuit and replaced by an adapter, which is connected with the emulator and which works like the removed processor. Additionally to the normal functions of the processor there are however the following possibilities by means of a normal PC, to which the emulator is connected via a serial, parallel or infrared interface:

- Presentation and altering of all internal registers and memories of the CPU, but also of external memories and assemblies, located on the circuit under test and reachable by the CPU
- Alterations of the program memory contents
- Start of a program to be tested, execution of a program in real time and stop of the program run at different, free chooseable break conditions
- Tracing of states of buses and external signals in a real time trace memory.

As additional possibilities to connect the **BICEPS** emulator and the test board, an Universal adapter and a debug connector are available. In both cases the controller remains on the board; the bus signals are connected via the socket of an external program memory or via a pin header and a flat ribbon cable. All debugging features, i.e. especially the control about the processor and the access to all memory areas, can be used.

The reader of this manual should be familiar with the architecture of processors of the 80C51 family as well as with the fundamental progression of a hardware and software development for microcontrollers. Suitable data books should be at hand, because an exact knowledge of the emulated processor is a supposition for a successful development work. The performance characteristics of the **BICEPS** emulator are separated in BASIC features and PROFESSIONAL features. The BASIC features are in detail:

- Adaption to different processors of 80C51 family by adapter boards (PODs)
- No restrictions with respect to memory space, ports and interrupts
- Emulation of external bus application as well as single chip applications
- Support of single chip emulation with Hook-mode and Bondout versions and Brendes Softhooks<sup>TM</sup>
- Universal adapter for connection of the emulator via external program memory socket with preservation of all debugging possibilities
- Debug connector for connection via pin header and flat ribbon cable
- Emulation memory: 64k RAM program
- Breakpoints on program and extdata memory
- Internal and external CPU clock
- **BicWin** source level debugging software for Windows
- Macros
- Supports file formats of several compilers
- 2 interfaces to PC: USB, serial

The PROFESSIONAL features include the BASIC features and additional:

- Emulation memory: 128k RAM
  - can be configured as: 64k program and 64k Extdata RAM 128k program RAM (banked)
  - expandable to 512k program memory
  - emulator internal or external memory (mapping)
- Watchdog support
- Emulation Dallas 80C390 in Paged/Contiguous Mode
- 16 external inputs for break and trace
- Break with program stop at any state of data bus, address bus or signals at the external logic probes
- Break counter
- Conditional breaks for IF-THEN conditions
- Trigger of external devices
- 32 bit real time counter for time measurements in the range of 100 ns up to ca. 12 h

- 32k/128k x 96 bit real time trace memory with tracing of all states of buses, the external signals and the real time counter (time stamp)
- comfortable search and filter functions for the trace memory
- Performance analysis

The PROFESSIONAL features are activated by professional licences. For details see BicWin online help.

# EMC

<u>Hint:</u> The **BICEPS**-Emulator is a device for testing of electronic circuits. It is designed for the cooperation with such circuits and therefore no device to operate standalone according to §5 point 5 EMVG (German EMC Law). It is restricted to exclusive use by development laboratories or other enterprises with know-how in the field of EMC.

We explicitly indicate that according to §5 point 6 EMVG at development of devices, testing and installation precautions have to be taken to avoid interferences of third parties. Since under certain circumstances dejam measures must be eliminated (e.g. remove the cover) to execute the test, suitable measures for the complete test arrangement have in case to be provided.

#### Attention !

The **BICEPS** hardware and the **BicWin**-software are protected by copyright. A copy of the software is only permitted for backup purposes and for own use; a transfer to others is explicitly prohibited. Software updates and support are given only to customers of **BRENDES DATENTECHNIK GmbH**.

#### HINT !

You will find descriptions of current changes of software as well as additional user hints to this manual in the "READ.ME" files on the enclosed system CD. Kindly notice the contents of these files absolutly.

# 2 Configurating and Starting of the BICEPS Emulator

In the following chapter the steps for starting the **BICEPS** emulator are described. If you want to get an overview over the features of the emulator, you should read the chapters 3-10. Detailed descriptions of the several functions (user interface etc.) you find in the **BICEPS** online help, which can be started without emulator.

To adapt the **BICEPS** emulator to the operation mode needed, several configuration options can be used. The configuration is done on the hardware side by jumpers and on the software side by the "Options" menue of the BicWin software. This configurating procedure has to be done before the emulator is started the first time.

The standard configuration of the **BICEPS** emulator is connection of emulator base unit and processor adapter (POD) via an adapter cable. The bus signals of the controller on the POD are used by the emulator; a port emulation logic or bus drivers provide the target board with I/O signals generated by the emulator (P0 and P2). All other port signals (P1,P3,P4..) are not used by the emulator and are connected directly to the target board.

Optionally, the POD can be plugged directly to the emulator base unit without cable. The advantage of this solution is that there are very short distances between emulator logic and emulated controller. To avoid getting out of balance, the emulator can be supported by pillars or turned round.

Other options for connecting emulator and target board are:

- 1. the **BICEPS** Universal adapter (replaces an external program memory on the test board)
- 2. the **BICEPS** debug connectors. For that solution a pin header must be on the test board to connect the **BICEPS** emulator.

To configurate the emulator it firstly has to be defined, which mode of controller and port replacement unit of the emulator are used:

- 1. Bus mode (P0/P2 as external bus, also for banking application and use of bondout versions)
- 2. Softhook mode (P0/P2 emulation for all 80C51 compatible controllers)
- 3. Hardware Hook mode (P0/P2 port emulation by a special multiplex mode for some Philips-CPUs)

#### 2.1 Configurating the BICEPS Emulator

Typically POD and emulator base unit are connected by adapter cable A0. The cable has no additional digital logic; only serial resistors for bus and P0/P2 lines and an additional socket for a clock oscillator are provided. To reduce noise at higher clock rates, it's possible to remove the cable and plug the POD directly to the emulator.

At the bottom side of the emulator there is an opening for selecting the options; the emulator case has not to be opened.



Fig. 2.1 Jumper and connection of banking signals

#### 2.1.1 Clock source

The clock source of the controller on the POD can be:

- oscillator of the emulator base unit (direct plug, hardware hook mode)
- oscillator of the cable A0 (set jumper to "POD")
- clock of the target board (see A1,A2 jumpers on the POD)

The oscillators of the base unit or cables are socketed and can be changed; they are not used if the clock option on the POD is jumpered to external. Debug connector and universal adapter use the controller on the target board and offer no option for clock selection.

#### 2.1.2 Power supply (Jumpers JV1, JV2)

The controller on the POD can be supplied by

- by the emulator: The voltage VccPOD can be choosen by jumpers JV1 and JV2 between 5V and 3.3V. Both jumpers must be set.
- by the target board. If a POD is used, jumpers on the POD must be set to external supply.

Debug connector and universal adapter use the controller on the target board and offer no option for VCC selection.

#### 2.1.3 Hook Mode (Jumper JH)

If the controller is operating in the hardware hook mode (P0 and/or P2 as ports), jumper JH must be set (default setting: not set).

#### 2.1.4 P2 port mode PullUps

A resistor array is used as PullUps for P2 signals when working in port mode (default 10k). It is socketed and can be changed if other values are necessary.

#### 2.1.5 Banking signals A16..A18

For applications with program memory size >64k additional address signals are necessary and must be provided by the user board (typically port lines of the controller), details see chapter 2.4.1.

#### 2.2 Configurating the Processor Adapter (POD)

For different controller derivates and package variants there are different PODs with the controller emulated, and converters. By replacing the POD the **BICEPS** emulator is adapted to the controller. The several options are selected by jumpers (mechanical drawing see appendix C).

#### 2.2.1 CPU clock (Jumper A):

Selection between emulator clock and external clock. Selection is done by jumper and not by software. In hardware hook mode, external clock option is not allowed.

#### 2.2.2 RD and WR signals (Jumper B):

For port bits P3.7 and P3.6 of the CPU it has to be defined, wether they operate as I/O ports or as RD resp. WR signals. In the first case the port pins are directly connected to test board (no internal connection to emulator logic).

#### 2.2.3 Power supply (Jumper C):

The external adapter with the controller emulated (POD) can be supplied by the emulator or by the test board. Default setting is supply by emulator (5V or 3.3V).

#### 2.2.4 Polarity of Reset signal (Jumper D):

Available only if controllers with different reset signals logic levels can be used.

# 2.3 Start of the BICEPS Emulator with POD

After configurating the hardware (chap. 2.1 and 2.2), the **BICEPS** emulator can be started.

The POD is connected at the bottom side of the **BICEPS** emulator; other connectors and operating elements are:

- Status LEDs at the top and the bottom side:
  - "Power": **BICEPS** emulator is switched on
  - "Trigger": Break event was detected (this signal is also available as trigger output at the Break/Trace connector, too)
  - "Running": Program is executed in real time
- Left side:
  - On/Off switch
  - Power supply connector
  - Serial interface
  - Break/Trace connector
- Right side:
  - Reset push-button
  - USB interface
  - Power supply connector

The two power supply connectors are identical and it can be selected, which side is used; so power supply and interface cable can allways be plugged in at the same side of the case. The LEDs at the bottom side are showing the status of the emulator if the emulator was turned round and stands on the top side.

For the start of the **BICEPS** emulator only a few points have to be noticed. It is recommended to proceed in the here given sequence:

- 1.) Start the installation program on the disc (setup.exe). It installs the **BicWin** software on your harddisc.
- 2.) Check, whether the main voltage and the input voltage of the enclosed power supply are in accordance. If this is the case, connect the power supply to the emulator.
- 3.) Connect emulator and PC by means of the enclosed USB or serial interface cable (but not both cables).
- 4.) Check, whether emulator and POD are connected correctly by direct plug or an adapter cable.
- 5.) Let the emulator switched <u>off</u> and start the **BicWin** software. After a short delay, you will be asked for configuring the emulator. Confirm this questions with "Yes". You will get the **BicWin** "Options" dialog. You must set the following options (in the register cards "Interface" and "Processor"). Further options settings as directories, compiler etc. can be done now, but also later after the start of the emulator.
- 6.) Set PC interface: Select the correct interface name. The USB driver software is installed automatically when the emulator is switched on the first time.
- 7.) Set Processor: defines the controller to be emulated
- 8.) Define Hardware: selects the kind of adapter (direct plug, adapter cable, universal adapter ect.) and the mode of ports P0/P2. This option is very important because the emulator hardware initialization depends on this setting.

- 9.) Switch on the power supply of the **BICEPS** emulator. The existing main voltage will be indicated by the Power LED of the emulator. USB driver is installed. Press the reset button on the rear of the **BICEPS** emulator.
- 10.) Click on the "Ok" button of the **BicWin** options dialog now. The emulator is started and **BicWin** presents the default desktop with Register-, Intdata- and Assembler window. The contents of the Special function registers must contain the reset values (e.g. PC=0000, SP=07).
- 11.) In case the emulator has reported no error, it can be connected now with your test board. For this purpose terminate **BicWin** (Close button or Alt+F4).
- 12.) Switch off the emulator and plug the adapter in the socket on your test board.
- 13.) Switch on the power supply of the emulator and after that the power supply of the circuit under test. Start the program **BicWin** again. The emulator has to answer as described under 10.). The **BicWin** user interface is ready for use now.
- 14.) Much success for your work with the **BICEPS** emulator.

# 2.4 Special connection types

#### 2.4.1 Banking

To emulate banking applications a program memory with more than 64k must be addressed. Therefore additional address lines are necessary (A16..A18). If a POD is used, A16..A18 are connected to pin header. If universal adapter or debug connector are used, banking signals are connected via this adapters.

The banking signals can be connected at the pin header (see Fig. 2.1) or at the POD.

In banking applications with bank sizes of 32k or 16k, the address of the common bank is generated by setting the bank nummer to 0 if A15=0 resp. A15=A14=0 (AND function). The **BICEPS** emulator supports this banking variants; it is assumed, that the universal adapter or the debug connector is used and that A15 and A14 are generated correctly by the test board.

#### 2.4.2 Use of the BICEPS Universal adapter

If the universal adapter is used, the bus signals of the controller are connected via the socket of an external program memory; the controller remains on the board under test. The program memory is replaced by an adapter with the same pin layout as standard memory circuits (DIL/PLCC32).

There are no options for external power supply or clock, because the controller of the test board is used. Hardware hook or Softhook mode are not possible.

Please note, that the universal adapter cannot operate without your test board. Two additional clips cables for ALE (input) and RESET (output) must be connected. For supporting your board with the correct reset signal see chap. C.1.3.4.

#### 2.4.3 Use of the BICEPS-Debug-Connector

With the **BICEPS** emulator it is possible to connect the test board via a pin header (debug connector). Possible connections are:

- 26 pin standard flat ribbon cable (pin header grid 2.54 mm) for applications with external bus
- 34 pin standard flat ribbon cable (pin header grid 2.54 mm) for banking applications
- 40 pin high density cable (pin header grid 1.27mm) for bus or port applications (Softhooks)

The detailed pin layout you find in appendix D.

If the test board is used without emulator, the flat ribbon cable is removed and replaced by short-circuit jumpers.

#### 2.4.4 Use of active adapter cable A1 (Bus Mode)

If the active adapter cable A1 is used, the controller operates in external bus mode. External buffer circuits for the signals P0, P2, PSEN, ALE, RD and WR are used. Therefore voltage levels with true 5V (instead of 3.3V) are available. Note as difference to the direct plug configuration:

• The clock of the controller emulated is defined by the oscillator on the A1 part (if not configured external)

#### 2.5 Error messages

When the emulator is started or during operation several error messages can be displayed.

#### "Emulator not ready"

Check, whether the power supply is switched on and whether the serial or parallel interface is set correctly. More information to the interfaces you find in appendix B.

#### "Processor is not responding"

The emulation CPU doesn't answer after a hardware reset. Reasons may be: If you use a processor adapter (POD):

- The adapter is not connected correctly to the emulator
- There is no CPU on the adapter
- The power supply is jumpered externally (jumper D), but the external power is not connected
- Clock is jumpered externally but no clock is connected

If you use an Universal adapter:

- The /PSEN signal is not connected correctly (jumper D1)
- The logic of the reset signal is jumpered wrongly (jumper D2)
- The reset signal is not connected correctly (see appendix C)
- The power supply of the test board is switched off.

If you have starting problems: switch off the emulator, start the **BicWin** software and check, whether the options are set correctly. If this is true, switch on the emulator and leave the options dialogue. Note that not all controllers support the hardware hook mode (P0/P2=Port), so try to start in bus mode or softhook mode and without a test board connected to the POD. If you use an adapter cable, try to plug the POD directly under the emulator to reduce noise problems.

# **3** Basics of the BICEPS-Emulator

#### 3.1 Structure of the BICEPS-Emulator

The **BICEPS** emulator consists of eight essential components:

- The <u>Control Processor</u> takes over the control of the emulation process as well as the communication with the host computer (PC) via a serial, parallel or infrared interface.
- For the <u>Emulation Memory</u> 128k bytes are available, which can be configured as
  - 64k RAM program memory and 64k RAM external data memory or
  - 128k RAM program memory (banked)

The emulation memory can be expanded to 512k RAM.

- A <u>32-bit-Real Time Counter</u> allows exact time measurements of the program executing duration with a solution of 100 ns. A measurement range of up to 12 h is achieved by a switchable time base.
- The bus signals, the external signals, which can be fed-in from the circuit under test by means of test clipses (Logic Probes) as well as the state of the real time counter can be traced in the **<u>Real Time Trace Memory</u>**. In this way the temporal progression of the program run or the access to the external data memory and the execution time of program parts can be represented (also during a running program).
- The <u>Address Range Selection</u> is used for marking either addresses or address ranges. For each address of the address area it can be defined whether a memory access of these address resp. this address range
  - shall lead to a program break
  - shall be traced in the real time trace memory

- Besides the possibility of defining address ranges for program breaks, using the <u>Break Logic</u> one can also determine conditions for the data bus and for external logic probes. Up to two break events can be defined, which are counted (break counter) and combined in real time. The break events can:
  - interrupt the real time program execution (break)
  - start or stop the real time trace
  - trigger an external device.

Real time program execution can be interrupted automatically at certain events or manually by user inputs.

- The <u>Port replacement unit</u> (PRU) generates the P0 and P2 signals for the test board, because these signals of the controller are needed as bus signals. Depending on the operation mode the external signals can be bus or static I/O-port signals. More information about P0/P2 emulation can be found in chap. 10.
- The **External Adapter (POD)**, contains the emulation CPU. By using different PODs one can emulate various CPUs of the 80C51 family. The POD is plugged directly under the Emulator base unit or connected via adapter cables.

#### **3.2** An Outline of the Emulation Process

After the initialization phase (the RESET command) the emulation processor transfers the contents of its internal registers to the control processor and is stopped by the latter. Now one can access the contents of the recovered register as well as those of the emulation memory from the host computer by the help of the control processor. Moreover, one can display and alter memory contents, which are accessible only from the emulation CPU (externally mapped memory ranges). Should the emulation processor now execute a user's program, the (eventually changed) register contents are read and a jump into this program follows. After termination of the program's execution the new register contents are again transferred to the control processor.

The simplest form of program processing is execution in single steps. In this case the internal state of the emulation processor is presented after each program step. However, the normal procedure is the execution of a program in real time. Then the emulation processor is started at a certain position of the user's program. The program execution can be stopped either manually by the user or automatically by previously defined break conditions and the state of the emulation CPU is displayed. The break options are presented in chapt. 6.

If the Universal adapter or the Debug connector of the **BICEPS** emulator is used, the emulator must be able to control the processor of the circuit under test. This is possible by a sophisticated emulator control logic which surveys the program execution in real time and switches between user program and hidden emulator-internal routines. The emulator maintains in this way the control about the processor also during program execution. An additional communication logic permits the transfer of the internal register contents to the PC. No accesses to the external data memory are used for that purpose to avoid restrictions related to the functionallity of the ports.

The use of the **BICEPS** Universal adapter technique combines the advantages of EPROM simulators and in-circuit emulators in an ideal way. Even the support of applications with watch-dog timers are possible with this technique. The user has only to secure that the cernel of the circuit, i.e. the access of the processor to the program memory socket is correct.

# 4 The BicWin User Interface

#### 4.1 Survey of the Operation Facilities

In order to facilitate a comfortable operation of the **BICEPS** emulator, the user interface **BicWin** offers multiple functions. The representation is given in a clear window technique with pull-down menus and status line. All windows can be opened and closed arbitraryly and changed in size and position. The operation is carried out with mouse or keyboard.

General information to the possibilities of the **BicWin** user interface are presented in the following chapters; more detailed descriptions, especially of dialogs and menus are offered by the Online help of the **BicWin** software.

Following a short survey is given .

- 1.) All the memory cells accessible from the emulation processor can be represented and altered. For this serve the windows Extdata, Intdata and Program and the "Modify" functions. "Watch" variables can be defined and represented in special watch windows. With "Copy" memory ranges can be moved and with "Initialize" set to a certain value. With the "Map" function it is defined which memory ranges internally in the emulator and which ones externally on the user board are addressed. There is the possibility to copy the contents of an external EPROM directly into the emulation memory (see chapter 4).
- 2.) The special function registers of the CPU are displayed in the Register window. They can also be retrieved and changed directly by means of the "Modify" function, respectively (chapter 4).
- 3.) <u>Execution of a program</u> is initiated by function keys or by the "Debug" menue. In the single step mode there is a possibility of executing the subroutines in real time ("jump over calls").

- 4.) The program memory contents can be represented in disassembled form. The input of mnemonic instructions will be done with the **BicWin** line assembler.
- 5.) There is the possibility to set or clear <u>breakpoints</u> in the Assembler or Sourcetext window directly. More complex break conditions (e.g. combination of break events or break counters) are defined via the "Break" dialog.
- 6.) By means of the "Trace" functions one can either display the contents of the <u>real time trace memory</u> of the **BICEPS** emulator or select various options of tracing data in the trace memory (see chapter 7). Further functions are e.g. searching of certain contents or calculating of time differences.
- 7.) The memory contents of the emulator as well as the contents of the real time trace memory can be saved on or loaded from a disc. Several standard file formats are supported.
- 8.) Besides absolute addresses <u>symbolic addresses</u> can be used, which were created by an assembler or a compiler. If the use of symbols can be helpful, this is offered by BicWin with the "?" button.
- 9.) <u>Sourcetext Debugging</u> allows the test of a program on source text level. The high level language program can be executed in single steps, i.e. line by line. Breakpoints are set directly in the source text. (chapter 9).
- 10.) All debugging commands are recorded in the <u>"Command" window</u> and can be altered and repeated easily.
- 11.) User-own <u>macros</u> provide the summarization of **BicWin** commands under a free chooseable name. These can be executed by entering the macro name but also automatically at the start of emulator and in case of a break.
- 12.) To handle several projects, the actual configuration of desktop, break and trace settings etc. can be loaded and saved. A context sensitive <u>Help</u> <u>Function</u> offers additional support at the work with the **BicWin** user interface

### 4.2 General Information to BicWin

The **BicWin** user interface consists of a screen divided into four parts:

- in the middle the working plane with windows and dialogs
- above that the selection menu
- below the status line
- the mouse panel with the most important actual functions.

In addition to that every window posseses a local context menu.

All functions can be invoked either with the keyboard or with the mouse.

Opened windows can be moved arbitrarily on the working area resp. enlarged or reduced. Only one window is always selected; this is recognizeable by the highlighted bar.

For all functions and windows short keys (function keys and ALT-keycombinations) are available. The most important are the ALT-keys, with which menu items and windows are selected and the function keys for releasing **BicWin** actions.

The context sensitive **BicWin** help system offers detailed descriptions of every function or windows. In the help window you find key words that can be selected by the mouse and lead you to more help information.

#### 4.3 Windows and context menues

A window is a part of the screen, which you can shift, enlarge and reduce, cover with other windows, open and close. Several windows can be opened, but always only one window can be active (recognizeable at the highlighted bar at the head of the window).

Wih the ALT-key combinations a window can aimed to be opened or activated (e.g. ALT+A = assembler window, ALT+1 = watch window 1). With CTRL+F4 a window is closed, with F6 and Shift+F6 the next or the previous window is activated (see also overview short keys).

An own context menu is assigned to every window, which can be activated with the right mouse key or the context menu key. The context menu key is also designated as PopUp key. For this reason the offered key combinations are called "Pop+letter" so e.g. **Pop+B.** In comparison with the CTRL key the PopUp key has the advantage that it need not be activated synchronously with the letter key and it can therefore better be operated with one hand.

| Label      | Function                                             | ALT key     |
|------------|------------------------------------------------------|-------------|
| Assembler  | Disassembled presentation of the program memory      | ALT+A       |
| Intdata    | Hex presentation of the internal data memory         | ALT+I       |
| Extdata    | Hex presentation of the external data memory         | ALT+E       |
| Program    | Hex presentation of the program memory               | ALT+P       |
| Register   | Special function registers of the CPU                | ALT+R       |
| Sourcetext | Presentation of source text or other text files      | ALT+S       |
| Trace      | Trace memory content                                 | ALT+T       |
| Watch14    | Output of watched variables                          | ALT+1 ALT+4 |
| Command    | Records BicWin commands (with possibility to repeat) | ALT+C       |

The following windows are available:

#### 4.4 Mouse palette and Status line

In the mouse palette the most important functions, which are just available, are offered. These can either be executed directly by mouse click or by input of the highlighted short key. The mouse palette can be oriented horizontally or vertically.

The mouse palette consists of a general part, which stays unchanged and a locally assigned part, where the offered functions change, depending on the just selected window. For instance the function F7 (single step) is always available at the same position, while **Pop+B** (break point set/reset) is only offered in the assembler window and in the source text window.

The status line at the lower margin of the **BicWin** window represents the following information:

- 1. The runtime of the program executed in real-time or in single steps since the last reset of the real-time counter.
- 2. The status of the external digital inputs (logic probes)
- 3. A message when the program to be tested is executed.
- 4. A message about the just executed macro

#### 4.5 Dialog boxes

Menu options with dots (...) open a dialog box, in which settings can be shown and altered. A dialog box must at first be closed, before another window can be activated.

In a dialogue window there are different operating elements:

- Action switches: release an action by activating with mouse or keyboard
- Marking and switching fields: switching options on and off
- Input fields: for input of text
- List window: Selection of elements with the mouse or arrow keys

# 5 Accessing the Memory

### 5.1 Basic Information

The **BICEPS** emulator is equipped with various emulation memories according to the achitecture of the emulated processor. The memory contents can be displayed (output) and changed in order to create specific test conditions. Besides this, we must naturally be able to enter or load the programs to be tested, and possibly also modify them.

Processors of the 80C51 family possess five different memory ranges altogether:

- the Program Memory
- the external Data Memory
- the internal Data Memory
- the bit-addressable Memory
- the Special Function Registers;

the three latter are partially overlapping. A special **BicWin** window is allocated to each memory range, where the bit-addresable memory is displayed in the Intdata window.

In principle, we can distinguish the following access possibilities for various memory types:

- Loading and saving of memory contents
- Displaying and changing the Special Function Registers
- Displaying and changing memory cells (Extdata, Intdata, Program window)
- Modifying of memory cells, registers and variables
- Initializing and copying of memory blocks
- Mapping, i.e. determining whether the RAM internal to the emulator should be accessed or whether we should access the circuit to be tested
- Disassembled representation of the Program Memory (Assembler window)
- Assembling 80C51 Opcodes

# 5.2 Saving and loading files

The **BicWin** user interface offers various functions for loading and saving of memory contents with different formats.

We can load:

- Contents of the program and data memories
- Source text files for highlevel language debugging
- Symbol information

and we can save:

- Contents of the program and data memories
- Trace memory contents

For loading and saving of memory contents four different file formats are available.

**BicWin** can save memory contents of the emulator also as text files, e.g. to evaluate these files with other programs or to edit them with a text editor. Distinguished are

- hexadecimal representation of memory contents (Hexdump)
- disassembled representation of the program memory

It is to be noticed, that significant limits are stated for creating of text files, since the files can otherwise reach a considerable size (several tenthousend lines). At saving the program memory in disassembled form two formats are distinguished:

- in the list format (same contents as in the Assembler window)
- in the sourcetext format the columns with addresses and file contents are omitted, to make the text files usable as source for an assembler

# **5.3** Access to the Special Function Registers

The contents of the special function registers are displayed in the Register window. The names of the registers are preset, and depend on the CPU type selected in the "Options" dialog. In addition to the real special function registers, the display includes the program counter PC, and the register bank R0..R7.

The registers are separated in groups; each group has an own box with title bar (e.g. Timer). The groups can be moved inside the register window; so even if only a small register window is visible, the most interesting registers can be displayed. The names, addresses and groups are contained in the external file "BICREGS.TXT", which can be edited if necessary.

The arrow keys or the mouse can be used to select a register and open the "Modify" dialog to enter a new content. Ports are set at once, i.e. the new content appears at the port pins immediately after entering the new value.

Attention:

The internal data memory and the special function registers overlap in the address range 80H..0FFH. In the Intdata window no special function registers can be accessed, but only the internal RAM cells of the processor (if there are any).

# 5.4 Access to the Program Memory, to the internal and external Data Memories

Memory contents are represented in hexadecimal form in the Extdata, Intdata and Program windows. By means of the arrow keys we can select specific addresses and set at a new value, with the "Got to" function it can be jumped to a new address.

Altogether three fields can be distinguished: the address field, the hexadecimal field and the ASCII field. The cursor can be moved to any position of the hexadecimal and the ASCII field. New memory contents in hexadecimal form or as ASCII character can be entered.

For the individual functions one should keep in mind:

Program:

Entering data is possible only for internal mapped memory ranges.

Extdata:

Entering data is always possible. If the test board should be accessed directly, then the considered memory range must be mapped externally (default setting).

Intdata:

In the address range 80H..0FFH the internal Data Memory overlaps with the Special Function Registers. The Special Function Registers cannot be accessed in the Intdata window.

# 5.5 Output and Change of single Memory Cells and Registers (Modify)

If a single memory cell or variable shall be aimed accessed without hexadecimal representation of a memory block, the Modify function must be used. This enables also other formats for input and the output, i.e. memory cells can be entered or represented in binary or decimal form, as ASCII characters or as highlevel language variable. Which variable type can be selected depends on the compiler defined under "Options Highlevel".

The function Modify can be invoked directly from the Register, Assembler and Sourcetext window. For that purpose the requested variable must be only selected by a double click with the mouse. If it is a valid variable then one gets the current value immediately and can enter a new value.

As a speciality the function "Modify write only" is still available, which enables the writing to memory cells, without accessing the corresponding address by previous reading. This is necessary e.g. with I/O components, which can change their state already by the reading access.

#### 5.6 Watched variables

With the Watch function memory contents and variables can be displayed in up to four different watch windows. Which variable shall be represented is determined by the "Watch list" dialog. Variable type (e.g. Unsigned) and format (e.g. binary) can be selected.

Up to four windows are available, into which watch variables can be issued (Watch windows 1..4). By the distinction of up to four windows it can be exchanged in an easy way between sets of variables to be issued without altering the definition in the list of watched variables. Only the windows with the desired variables had to be opened or the not relevant windows closed again. For this the key combinations ALT+1 until ALT+4 are provided.

The watch windows are actualized by choice either automatically after each program execution or only at selection of the watch window.

#### 5.7 Initializing and Copying of Memory blocks

The function "Initialize" writes a constant value into a memory block, defined by start address and end address.

By means of "Memory Copy" we can move memory blocks, i.e. copy them. The source and target areas may overlap. As extension hereto there is the function "Copy EPROM", which transfers the program memory contents from the user's circuit into the Emulation RAM (see chapter 4.8 "Mapping").

## 5.8 Mapping

The memory types program memory and Extdata memory can be mapped. This means that the user can determine with help of the "Memory Map"function whether

• the RAM internal to the emulator (emulation memory), or else

• a memory possibly present on the circuit to be tested (e.g. an EPROM) should be accessed.

The default setting for map is an internal mapped program memory and an external mapped Extdata memory.

The **BICEPS** Universal adapter offers as well a mapping possibility. This is true only for the program memory, the Extdata memory is mapped external always. To access the original EPROM, the EPROM of the test board must be removed, replaced by the adapter and be plugged on the adapter. This means, that an emulation is possible with the original CPU and the original EPROM.

#### 5.9 Disassembled representation of the program memory

The Assembler window gives out the contents of the Program Memory in the form of executable commands, i.e. in disassembled form. The code undergoing this representation is always the code executed by the emulation processor, i.e. - depending on the relevant map configuration - the contents of either a memory internal to the emulator or an external one.

One can move through the memory forwards and backwards, using the cursor keys. The line with the current program counter position, i.e. the command to be executed next, is highlighted.

Besides the the representation of the program additional functions are possible:

- Execution of the program
- Set and clear of breakpoints and trace filter ranges
- Modifying of memory cells and variables

For more information see chapter 7.

The **BicWin** Line Assembler (integrated in the Assembler window) serves as comfortable input of 80C51 program code into the program memory RAM. Before entering a mnemonic command, the command currently present in the program memory is displayed in disassembled form. Entering code is only possible in internal mapped memory ranges.

For denoting the addresses of the program memory, the bit memory and the internal and external data memories one can use arbitrary symbols - provided that they are known, i.e. entered into the corresponding symbol table. The predefined symbols known to the **BicWin** Line Assembler are the names of the special function registers (bit and byte addresses). They correspond to the type of processor selected in the "Options" dialog. Furthermore complex arithmetic expressions can be formed at the declaration of addresses and constants, which can contain symbolic names as well as number constants.

# 6 Break possibilities

#### 6.1 Basic Information

Breaks are defined in order to stop the program execution of the emulation CPU at certain conditions, interesting for the program test. For example, these condition may be the execution of a certain part of the program, or an access to some specific ranges of the Data Memory. The **BICEPS** emulator offers the following possibilities for defining a break condition:

- Access to one or several addresses or address ranges (64k breakpoint memory)
- State of the data bus by accesses to the data memory and program memory
- State of the external inputs (Logic Probes)
- Event counter for breaks (Break Counter)
- conditional breaks
- Overflow of the real time trace memory

The defined state of the address bus, the data bus and the logic probes forms a break event, where the combination is predetermined

(addresses AND data AND Cycle type)

An event is additionally connected with an event counter (break counter).

Altogether there are two break events "Break1" and "Break2", which can generate a break alone or together. The following break actions are possible:

- interruption of the real time program execution (break)
- enabling the second break event for conditional breaks
- start or stop of the real time trace
- triggering external devices.
#### 6.2 Break mode

"Break1" and "Break2" can be combined in several ways. Beside OR and AND combination there are conditional combinations, that allows to enable one break event by the otherone. Furthermore there are the two events "Clear1" and "Clear2", which can reset detected events "Break1" or "Break2". In this way it is possible for example to define an event, which is only enabled in a special subroutine.

The events "Break1" and "Berak2" are available as signal outputs to trigger external devices (see chapter "Interfaces").

In the **BicWin** help function you can find several examples of the break and controlling possibilities of the **BICEPS** emulator.

In addition to states of the address and data buses, we can also define a state of the external inputs as a break event. When the signals at the external inputs become effective and what qualities they must possess is described in chapter B.2. The definition is made as binary combination, i.e. as a sequence consisting of the symbols "0", "1" and "x", where to the external inputs 16 characters (corresponding to the 16 inputs) are assigned.. "x" stands for don't care, these bits are not rated.

#### 6.3 Definition of Break Events

The most important function of the break logic of the **BICEPS** emulator is interrupting the program execution at a specific position of the program. This position is defined by its address.

For the four break events "Break1", "Break2", "Clear1" and "Clear2" one can define as many addresses or address ranges as one likes. By the definition of the "Cycle type" it is possible to distinguish between Program and Extdata memory accesses; in addition a specific data bus state can be defined. A defined break address is only then valid when during the program execution the defined state of the data bus occurs at the same time.

For accesses to the program memory the options "Opcodes" (default), "Line numbers" and "All accesses" are available. "Opcodes" means, that a break is only then recognized when the first byte of a command is executed (independent of of the value of the read date). This is a very important option, since CPUs of the 80C51 family access addresses, partly unnecessarily, and reject the read data afterwards. With "All accesses" this restriction is omitted; with "Line numbers" the opcodes cycles are restricted to sourcetext line beginnings.

The data bus conditions Read and Write contain the ranges 00-FF as presetting, i.e no restriction to a specific state. Each reading or writing access to an address of the external data memory leads to a valid break event, as far as the address is marked as break address.

Each of the possible break events is assigned an event counter (break counter). In order to effect a break, an event defined by the states of the address bus, the data bus and the logical probes must occur as often as it is predetermined in the break counter. Preset is a value of 1, i.e. the event is immediately valid at its first occurrence. For "Break1" a 24 bit counter is available, but this is reduced if break counter capacity is needed by other events.

# 7 The Real Time Trace Memory

#### 7.1 Overview

The **BICEPS** emulator can be provided with a Real-Time Trace Memory of a 32k x 96 bit capacity. It is used for recording certain signals during a real time program execution, similar to a logic analyser. Additionally existent is a 32 bit real time counter, which runs synchronously with each program execution and therefore enables exact time measurements.

The data recorded in the trace memory are:

- 24 bits address bus signals
- 16 bits data bus signals
- 16 bits external signals (logical probes)
- 32 bits status of the real time counter (time stamp)
- 8 control signals

On the basis of the traced information one can easily obtain an overview of the run and the time duration of a program or the external signals.

The real time trace memory of the **BICEPS** emulator can store up to 32766 entries. Each entry has a size of 96 bit and is named a "frame". The frame number is jointly represented in the trace window, where number 0 corresponds to the oldest entry and the largest frame number to the entry traced at last.

Traced are all program steps, i.e. single steps as well as program fragments executed in realtime.

The contents of the real time trace memory is displayed in the "Trace" window. This is also possible during the program execution, without influencing it ("on the fly" access).

The real time trace memory of the **BICEPS** emulator offers the following functions:

- representation of the traced data either as program or as sequences of cycles with time stamp and state of the external inputs
- show context in the Assembler or Sourcetext window while scrolling in the trace window
- calculating of time differences of the traced time stamp
- search functions for traced data
- Sourcetext trace mode (tracing of source text lines)
- selecting of address ranges and access modes for the tracing
- real time filter to enable/disable memory address ranges for tracing
- start and stop of tracing by break events
- Program break by overflow of the trace memory with a predetermined number of frames to be traced
- Performance analysis, i.e. calculating the execution time for different parts of the program

#### 7.2 Time Measurements

The **BICEPS** emulator possesses a 32 bit real time counter, which counts timing marks during a program execution. The time base is switchable between

- 100 ns (measurement range up to ca. 7 min)
- 1  $\mu$ s (measurement range up to ca. 70 min)
- $10 \ \mu s$  (measurement range up to ca. 12 h)

The actual value of the real time counter is displayed in the status line. It can be set directly to 0.0 with the function "Reset real time counter" or together with a CPU reset with the function "Debug Reset all". The status line displays the time of program execution since the last reset of the real time counter.

Time measurements come in connection with the real time trace memory, since the position of the counter is traced as time stamp. The time of program execution yields to the difference of traced time stamps. Since their calculation from absolute values is too troublesome, the trace window offers several possibilities for forming of time differences:

- 1. The time stamp at the current cursor position in the trace window can be set to 0. All following time stamp entries are represented then relative to this zero mark.
- 2. The multiple manual setting to zero of the time stamp can be simplified with the time filter function. In the time filter dialogue conditions can be defined to which the continous time stamp representation starts again with 0.0. Is e.g. the address of a subroutine entered as condition, then the duration of execution of this subroutine is automatically represented in the trace memory window. Besides addresses also conditions for the data bus or the external inputs can be defined as time filter condition.

#### 7.3 Search function

A complex search function allows to find those information in the large amount of traced data, which are interesting for the debugging. Default setting is no restriction, that means all traced frames met this condition. By restricting the search conditions (e.g. address range 1000-1020 instead of 0000-FFFF) the search function becomes more sensible.

In addition to address and data bus contents it is possible to search changes in break events "Break1" and "Break2".

#### 7.4 Sourcetext Trace Mode

In the sourcetext trace mode only the execution of lines of a loaded highlevel language program is traced instead of the complete program run. Assumption for this is, that a source text as well as the corresponding symbol information were loaded (see chapter 9).

Each line of a highlevel language program is related to a memory range of the program memory. Since in the sourcetext language trace mode only the start of this address range is traced, the real time trace memory can trace up to 32766 sourcetext lines.

When scrolling in the Trace window, it is possible to display automatically the part of the program in the Assembler and Sourcetext window, which belongs to the actual selected trace address.

#### 7.5 Controlling the real time trace

The tracing is controlled by trace filter conditions. Single addresses or address ranges can be defined; also symbolic names, in particular module names, are admissible there. Only accesses to the addresses defined in this way are traced in the real time trace memory of the **BICEPS** emulator.

Three real time filters are available. Default setting is one filter for each cycle type, i.e.

- accesses to the program memory
- writing accesses to the external data memory (Write)
- reading accesses to the external data memory (Read).

For the program memory filter "Opcodes", "Line numbers" and "all accesses" are distinguished.

It is possible to switch from one filter to another during program execution, controlled by a break event.

The **BICEPS** emulator allows to start or stop the real time tracing at predefined events. For this purpose break events are used. It can be defined, which action should be released by break events. Possible are:

- 1. Start of tracing at program execution start Stop of tracing at program execution end
- 2. Start of tracing at program execution start Stop of tracing at an event
- Start of tracing at an event
   Stop of tracing at program execution end
- 4. Start of tracing at an event Stop of tracing at another event
- Start of tracing at program execution start Switch to another filter at an event Stop of tracing at program execution end

# 8 **Program Execution**

#### 8.1 Overwiev

The **BICEPS** emulator offers various functions for executing a user's program.

- Execution of a program in real time (Run)
- Execution of a single step
- Execution of a single step, but with the condition that subroutines are executed in real time (Jump over calls)
- Generation of a hardware reset of the emulation CPU (Reset processor)
- Execution of a program in real time until a break address is reached
- Set and clear of breakpoints

#### 8.2 Execution of a program in real time, Reset

One of the essential functions of an in-circuit emulator is the execution of programs under real time conditions until the program's run is stopped. In the simplest case the break follows after executing a single step of the program (Single Step). However, the real time relation can be obtained only by executing several program steps.

By means of the "Run"-function we initialize the break logic and start the program.

The execution of a program in real time is indicated by a light diode in the field "Running" on the front panel of the emulator. The real time trace memory can be accessed, while the program is executed, and its contents displayed without

disturbing the program execution. An interruption of the program can be performed

- by the user with the mouse or the keyboard or
- by occurrence of a break condition.

After a break, the actual values of the open windows and the status line are displayed. Very important for program debugging are the register window with the actual PC and registers and the actual part of the program in the Assembler window. After a break, an access to all memory ranges is possible in order that the current memory contents could be changed.

The function "Reset processor" resets the emulated CPU by executing a hardware reset.

#### 8.3 Execution of single Steps

The emulated CPU can execute a user's program either in real time or in single steps. In the first case, the program is started up and executed until a break occurs. In case of single steps, the internal state of the processor is displayed after each program step.

The "Jump over Calls" function allows to execute single steps with executing of subroutines in real time. This means: if the next command to be executed is a CALL opcode, then a break point is set immediately after this opcode, and the program is started up in real time; otherwise a normal single step is executed. If the processor fails to return from the subprogram, then the program execution must be stopped by the user.

Single steps are traced in the real time trace memory as programs executed in real time are.

## 8.4 Debugging with the Assembler and Sourcetext window

The most important debugging functions can be executed and monitored directly in the Assembler and Sourcetext window. This functions are:

- Reset of the processor
- Execution of a single step, i.e. an assembler opcode or a sourcetext line
- Single step with "Jump over Calls"
- Execution of the program in real time
- Program execution to the cursor, i.e. the command marked by the cursor is provided with a breakpoint and the program is started
- Setting the program counter PC on the command marked by the cursor
- Setting and clearing of breakpoints
- Marking of program ranges and setting/clearing of trace filters for this program ranges. By this feature it is possible to disable the tracing of program loops whose execution leads to an overflow of the trace memory
- Opening the "Modify" dialog by a double click of the mouse with the selected variable name.
- representation of another part of the program

Most of this functions can be executed directly by a click with the mouse in the mouse palette or by a function key. The remaining functions can be activated via the local context menue.

In combination with the Trace window it is possible to show the actual part of the program in the Assembler or Sourcetext window when scrolling in the Trace window. The address of the just selected trace frame is shown as highlighted bar in the Assembler or Sourcetext window. The user can watch the traced program flow in a representation with a moving bar just like the execution of single steps.

By deactivating the option "Follow program counter" it is possible to freeze a representation of the Assembler or Sourcetext window. The shown part of the

program is not adapted when the program counter is changed by execution of the program.

The following lines are shown highlighted:

- 1. the actual program counter address
- 2. breakpoints
- 3. disabled trace filter ranges
- 4. the address of the just selected frame in the trace window
- 5. marked areas.

# 9 Sourcetext Debugging

## 9.1 Introduction

The **BicWin** user interface supports a program test on the base of highlevel language debugging. This means that the source text of programs, which is written in a highlevel language (e.g. C51) or in assembler language, can be loaded by **BicWin** and is represented during the debugging process.

The sourcetext is shown in the Sourcetext window. All debugging features known from the Assembler window are available in the Sourcetext window, too (e.g. execution of the program line by line). In the real time trace memory sourcetext lines instead of assembler opcodes can be traced. Highlevel language variables are represented and altered corresponding to their type definition.

The switching between Assembler and Sourcetext window makes it possible to execute a program in different "resolution".

The assumption is, that the relation between the line numbers of the original source text and the addresses of the executable code is known. The used compiler or assembler software must generate the necessary symbolic and line number information.

#### 9.2 Invoking the Compiler, Loading a Program

The **BicWin** user interface uses different files for handling sourcetext during debugging. They are:

- a file with the program code and the symbolic information
- one or more files containing the source text

For the cooperation with the **BicWin** software it is important to correctly select the various options of the compiler, so that the program and symbol files could be created in a form readable by the emulator. Very important are the line number symbols because they are needed for the relation of program code and source text line. To access highlevel language variables, symbolic names and typedef information are needed. Check in your compiler manual, which options must be set to generate this information (e.g. Keil-C51: objectextend). The function "Load status" of the **BicWin** software shows how many symbol names and line numbers were loaded.

After starting up the emulation software **BicWin**, a program to be tested is loaded by means of the function "File Load". This function loads the program file as well as the symbol file and the source text, if source text information are contained in the symbol file. More sourcetext modules are loaded by the function "File Open". It should be noticed that the program file and the source text are loaded from the directories determined under "Options Directories".

#### 9.3 Program execution

The loaded source text is represented in the Sourcetext window. Every line of the text can be selected by the mouse or the cursor keys. The line with the actual program counter, i.e. that line of the source text, which is to be executed next, is optically highlighted.

The Sourcetext window offers the same functions for executing a program and for debugging as the Assembler window (see chapter 8.4). The execution of a program in a high-level language does not differ in principle from that of an assembler program. The essential differences are the representation of the current program sector and the execution of single steps.

Breakpoints can be set only on the lines which have been translated into the corresponding program code by the compiler, so they cannot be set e.g. on empty lines, or on comment lines. If either the program counter of the CPU or a breakpoint cannot be set on some line, since no corresponding line number symbol for this line has been generated by the compiler, then an error message is given.

It can always be switched between Assembler window and Sourcetext window and therewith between the highlevel language representation and the assembler one. We can also determine in this way whether in case of single steps an assembler command is executed or whether the program will be executed line by line (i.e a single step corresponds to a line of the source program). Highlevel language single steps are only executed, when the Assembler window is not selected and the program counter points to a line number.

## 9.4 Handling of several modules

If the program is composed of several source text files (modules), more than one text files can be represented in the Sourcetext window. With the function "File Open" every text file can be loaded.

If the option "Follow program counter" is activated (default setting), more sourcetext files are reloaded automatically when the program counter points to another module after a break or a single step.

More than one Sourcetext window can be opened. In this windows the option "Follow PC" is switched off to enable one window for the actual program section and other windows for fixed program representations.

Switching between different modules is possible only, if sourcetext file names and module names are contained in the symbol table.

## **10** Options for P0/P2 Emulation

An in-circuit-emulator needs the bus signals of the emulated controller, to control the emulation memory, the real time trace memory ect. So it is no severe problem to emulate applications which use an external bus. More difficulties arise if true single chip applications without an external bus have to be emulated, because port pins are lost if used as bus signals. Therefore the bus signals must be connected in another way or the ports must be regenerated. For 80C51 controllers this is true for ports P0 and P2.

The **BICEPS** emulator supports the following modes of the emulated controller:

1. Applications with external bus. P0 and P2 operate as address and data bus.

To emulate applications without an external bus (e.g. P0 and P2 operate as I/O-ports or are not avialable) there are the several possibilities:

- Use of Bondout CPUs: Bondout CPUs are special controller variants, which are manufactured for emulation purposes only. The bus signals are connected additional pins. Bondout CPUs are available for a few 80C51 controllers only.
- 3. Hardware Hook Mode Emulation: Some controllers can be set in a special emulation mode (Hook mode). In this mode bus and I/O information are multiplexed on P0 and P2. A seperate port-replacement-unit can filter the port status from the data stream an regenerate the port signals.

#### 4. Use of **Softhooks**:

For all controllers for which the first two options are not available, Brendes Datentechnik developed the **Softhook** method. Contrary to the hardware hook emulation mode the I/O information of ports P0 and P2 are generated by the emulator and not by the controller. Nearly all bit and most byte operations ( but not all ! ) to P0 and P2 can be emulated in real time. Using the Keil C51 compiler, **Softhook** compatible code can be generated.

# **10.1 The BICEPS Softhooks**

For the controller, which can not support bondout or hardware-hook mode emulation for ports P0 and P2, the **BICEPS** emulator offers **Softhook** emulation. This method emulates the port P0 and P2 and the opcodes accessing this ports; the port registers are located in the emulator hardware and not in the controller. During program execution P0/P2 operations are detected and executed in real time by the emulator while the controller excutes opcodes which have exactly the same clock cycles as the emulated opcode. Therefore the emulated controllers works like a single chip, although it is running in external bus mode.

Most opcodes accessing P0 or P2 – including nearly all bit opcodes - can be emulated. Those opcodes which can't be emulated directly (e.g. MOV P0,A) are replaced by 3 byte intrinsic functions. The C51 compiler can be forced to generate **Softhook** compatible code; nearly no loss in performance can be detected. If the **Softhook** compatible opcodes are used only, Assembler programming is possible without problems (see chapter 10.3)

The basic function of the SoftHook methode is:

- 1. Regeneration of ports P0 and P2 <u>and</u> the operations accessing these ports by emulator hardware (port-replacement-unit PRU).
- 2. The code generated by compiler or assembler is checked automatically for **Softhook** compatibility. Source text lines, which are not compatible, can be selected by mouse click. Normaly more than 95% of all C51-statements with P0/P2 accesses can be emulated without changes.
- 3. The generated hex file can be programmed in the controller or loaded in the emulator directly.
- 4. Therefore the result is no or a minimal loss in perfomance.
- 5. The controller operates during emulation in normal bus mode. All P0/P2 opcodes are recognized by the **BICEPS** emulator in real time. They are replaced by compatible opcodes, which have the same execution time and which can trigger the port replacement unit.

It is important to know for the user:

- no difference in code size or timing between emulator and controller
- no or minimal loss of performance
- C51 compiler compatible

#### **10.2** Compatibility with C51-Compiler

The following method is used to make sure that the C51 compiler generates **Softhook** compatible code:

After the link process, it is checked, wether the generated code is **Softhook** compatible. If a "MOV portbit,C" opcode is detected (the only bit operation which cannot be emulated directly), a "\_nop\_" statement has to be inserted in the corresponding source text line. This statement is compiled to a "NOP" opcode.

For incompatible byte access opcodes the **BICEPS** emulator supports four routines to access P0 and P2. This are:

Set port byte:WriteP0, WriteP2Read port byte:ReadP0, ReadP2

This function calls have to be used in source lines with a incompatible code generation; the right **Softhook** intrinsic functions (3 bytes, see chapter 10.3) are inserted then automatically.

**Examples:** 

| C51 statement    | replaced by      | Softhook Intrinsic<br>function (3 Bytes) |
|------------------|------------------|------------------------------------------|
| $P2_3 = bitvar;$ | $P2_3 = bitvar;$ | MOV P2.3,C                               |
|                  | _nop_;           | NOP                                      |
| P0 = variab;     | WriteP0(variab); | MOV P0,R7                                |
|                  |                  | MOV A,R7                                 |

This four routines requires that they are executed in register bank 0. If port accesses with different register bank are needed, the following routines have to be used:

```
Set port byte:WriteP0RegBank, WriteP2RegBankRead port byte:ReadP0RegBank, ReadP2RegBankConfigure register bank to use in options dialog on register card hardware.
```

The Softhook emulation method is optimized for the Keil C51 compiler. The user interface  $\mu$ Vision is extended by a special tool: the Softhook checker. It checks the code generated by the compiler and generates the right hex and object file. If an incompatible opcode is detected, an error message is

presented; the corresponding line of the source text can be selected directly by mouse click. In this line the right function call (WritePx, ReadPx) or an "\_nop\_;" statement has to be used.

If the compiler, linker and Softhook checker have been executed without error messages, the generated code can be used to program the controller or to load in the emulator. There are not different program versions for emulator and controller.

Because only a few source text lines have to be altered and because in this cases only 3 bytes for the intrinsic functions are necessary, there is no or a minimal loss in performance, which is not significant normally.

## **10.3** Hints for assembler programming

The Softhook checker utility makes sure that compiled programs are **Softhook** compatible. It can be used for A51 assembler programs, too. But the assembler programmer has to know, which 8051 opcode can be emulated and which not. The opcodes can be classified in three classes:

- 1. can be emulated without restrictions
- 2. can be emulated by an intrinsic function
- 3. can not be emulated.

The following tables show, which bit and byte opcodes with P0/P2 accesses can be emulated by **Softhooks**:

| Opcode     | can be emulated | intrinsic<br>function |
|------------|-----------------|-----------------------|
| CLR bit    | yes             | -                     |
| SETB bit   | yes             | -                     |
| CPL bit    | yes             | -                     |
| MOV C,bit  | yes             | -                     |
| ANL C,bit  | yes             | -                     |
| ANL C,/bit | yes             | -                     |
| ORL C,bit  | yes             | -                     |
| ORL C,/bit | yes             | -                     |

| JB bit,rel            | yes              |           | -                 |  |
|-----------------------|------------------|-----------|-------------------|--|
| JNB bit,rel           | yes              |           | -                 |  |
| JBC bit,rel           | yes              |           | -                 |  |
| MOV bit,C             | with intrinsic   | MOV       | bit,C             |  |
|                       | function         | NOP       |                   |  |
| tab                   | le 10.1 bit opco | des       |                   |  |
| Opcode                | can be emul      | ated i    | ntrinsic function |  |
| MOV A,Px              | yes              |           | -                 |  |
| MOV direct,Px         | yes              |           | -                 |  |
| MOV Px,#data          | yes              |           | -                 |  |
| ANL/ORL/XRL Px,#data  | yes              |           | -                 |  |
| ANL/ORL/XRL A,Px      | yes              |           | -                 |  |
| ADD/ADDC/SUBB A,P2    | x yes            |           | -                 |  |
| INC/DEC Px            | yes              |           | -                 |  |
| DJNZ Px,rel           | yes              | yes -     |                   |  |
| CJNE A,Px,rel         | yes              |           | -                 |  |
| MOV Px,A              | with             | Μ         | OV R7,A           |  |
|                       | intrinsic        |           | OV Px,R7          |  |
|                       | function         |           | egister bank 0)   |  |
| MOV Px,R7             | with intrins     | -         | OV Px,R7          |  |
|                       | function Write   | <b>V</b>  | OV A,R7           |  |
|                       |                  |           | egister bank 0)   |  |
| MOV R7,Px             | with intrins     | sic M     | MOV 07H,Px        |  |
|                       | function Read    | Px(); (re | (register bank 0) |  |
| ANL/ORL/XRL Px,A      | no               |           | -                 |  |
| MOV Px, Ri/@Ri/direct | no               |           | -                 |  |
| MOV Ri/@Ri, Px        | no               |           | -                 |  |
| PUSH/POP Px           | no               |           | -                 |  |
| XCH A,Px              | no               |           | -                 |  |

table 10.2 Byte opcodes

Additionally the following opcode sequences with P0/P2 accesses are recognized as Softhooks:

| Opcode sequence | can be emulated |
|-----------------|-----------------|
| MOV bit,C       | yes             |
| CLR A           |                 |
| MOV A,#data     | yes             |
| MOV Px,A        |                 |
| CLR A           | yes             |
| MOV Px,A        |                 |
| MOV Ri,#data    | yes             |
| MOV Px,Ri       |                 |

table 10.3 Emulatable opcode sequences

Not executable code in program memory (e.g. constant tables accessed by MOVC instructions) can detected wrongly as Softhook only, if the assembler generates no line number symbols. In this case

- two 00 bytes can appended to the constant table or
- the first opcode following the constant table can be marked by a label with the beginning "\_sh\_" (e.g. "\_sh\_label1")

#### **10.4** Specialties for Winbond Turbo51-Controllers (77Exx)

The Turbo51 controllers of Winbond have a faster program execution than standard 80C51 CPUs. Therefore other intrinisc functions are necessary for this controllers.

The Winbond Turbo51 controllers need more program bytes for **Softhook** compatibility. For this reason in C51 statements additional "\_nop\_;" statements must be inserted, if a **Softhook** intrinsic function is used:

| Original C51<br>statement | C51 statement<br>(Winbond 77x) | Intrinsic function<br>(Winbond 77x) | Hex codes | Bytes /<br>Cycles |
|---------------------------|--------------------------------|-------------------------------------|-----------|-------------------|
| Px = ();                  | WritePx();                     | SJMP \$+2                           | 80 00     | 4 / 5             |
|                           | _nop_;                         | MOV Px,R7                           | 8F 80/A0  |                   |
| Px_y = ();                | $Px_y = ();$                   | MOV bit,C                           | 92 8y/Ay  | 4 / 5             |
|                           | _nop_; _nop_;                  | SJMP \$+2                           | 80 00     |                   |

Assembler programmers can use the following opcodes:

| Original<br>opcode | Bytes /<br>Cycles | Softhook<br>compatible opcodes | Hex<br>codes | Bytes /<br>Cycles |
|--------------------|-------------------|--------------------------------|--------------|-------------------|
| MOV Px,A           | 2 / 2             | SJMP \$+2                      | 80 00        | 4 / 5             |
|                    |                   | MOV Px,A                       | F5 80/A0     |                   |
| MOV Px.y,C         | 2/2               | MOV Px.y,C                     | 92 8y/Ay     | 4 / 5             |
|                    |                   | SJMP \$+2                      | 80 00        |                   |

Contrary to standard 8051 controllers, the reading access MOV Ri,Px

can be emulated without restrictions.

#### **10.5** Specialties for TI MSC1210 controllers

The MSC12xx controllers of Texas Instruments have a faster program execution than standard 80C51 CPUs. Therefore other intrinisc functions are necessary for this controllers.

The TI MSC12xx controllers need more program bytes for **Softhook** compatibility. For this reason in C51 statements additional ,,\_nop\_;" statements must be inserted, if a **Softhook** intrinsic function is used:

| Original C51<br>statement | C51 statement<br>(MSC12xx) | Intrinsic function<br>(MSC12xx) | Hex codes | Bytes /<br>Cycles |
|---------------------------|----------------------------|---------------------------------|-----------|-------------------|
| Px = ();                  | WritePx();                 | MOV Px,R7                       | 8F 80/A0  | 4/6               |
|                           | _nop_;                     | SJMP \$+1                       | 80 FF     |                   |
|                           |                            | MOV R7,A                        |           |                   |
| $Px_y = ();$              | $Px_y = ();$               | MOV bit,C                       | 92 8y/Ay  | 5/6               |
|                           | _nop_; _nop_;              | SJMP \$+2                       | 80 00     |                   |
|                           | _nop_;                     | NOP                             | 00        |                   |

Assembler programmers can use the following opcodes

| Original   | Bytes / | Softhook           | Hex codes   | Bytes / |
|------------|---------|--------------------|-------------|---------|
| opcode     | Cycles  | compatible opcodes |             | Cycles  |
| MOV Px,A   | 2 / 2   | MOV Px,ACC         | 85 E0 80/A0 | 5 / 6   |
|            |         | SJMP \$+2          | 80 00       |         |
| MOV Px.y,C | 2 / 2   | MOV Px.y,C         | 92 8y/Ay    | 5/6     |
|            |         | SJMP \$+2          | 80 00       |         |
|            |         | NOP                | 00          |         |

Contrary to standard 8051 controllers, the reading access

#### MOV Ri,Px

can be emulated without restrictions.

## 10.6 Advantages and disadvantages of Softhooks

The advantages of **SoftHook** emulation are:

- No difference between emulation and controller (timing and code size)
- Bit- and byte-access to P0 and P2
- Compatible with C51-compilery by use of intrinsic functions
- No critical bus timing for higher frequencies, because a lower bus clock is used compared with the hardware-hook mode.
- Independent of silicon vendors, suits all controllers with 80C51 architecture
- lower price

The disadvantages are:

- Current 80C51 programs have to be checked by the the Softhook utility for compatibility
- At some few program parts there can be a minimal loss in performance (typical 1 cycle)

#### **10.7** Necessary conditions for BICEPS Softhooks

At the moment the **BICEPS** Softhook routines are compatible with Keil-C51compiler, i.e. parameters are transferred in register R7 of registerbank 0.

The expansion tool "Softhook checker" is integrated in the  $\mu$ Vision user interface by definig it as "Run User Program #1" in the menue "Project/Options for Target/Output".

For the **Softhook** functions (ReadPx and WritePx) 4 dummy addresses are used (0FFF8H-0FFFBH). The correct definition files for the C51-compiler (see files Shook.h, Shook.a51) and a sample program come with the **BicWin** debugging software. The IAP entry point at 0FFF0H can be used without restrictions.

The following files are on the disc:

ShChecker.exe

checkes a linked OMF or HEX file for Softhook compatibility and generates the correct hex file for programming

ShChecker.txt

Describes softhook checker incl. command parameters

Shook.h, Shook.a51, Shook.obj:

Definition file for Softhook addresses

Shdemo.omf

Demo program for Softhook use <u>with</u> softhook intrinsic functions with the files ShDemo.c, ShDemo.obj, ShDemo.uv2, ShDemo.opt

ShRotP51:

Demo pogram for Softhook use with the files ShRotP51.c, ShRotP51.obj, ShRotP51.uv2, ShRotP51.opt

The project- and option-files of Keil  $\mu$ Vision are correctly defined in that way, that ShChecker is called after link process.

#### **10.8** Softhook sample program

here you find a C51 sample program with typical bit- and byte-accesses to P0 and P2. The example shows, which routines can be used and which 80C51 code is generated:

```
void main (void)
{
    uchar i;
    while (TRUE)
    {
        P2_3 = 1;
        if (P0_4) i=1;
        else i=i+1;
        i = P2;
        P0 = i;
    }
}
```

The **Softhook** checker detects a problem with the line P0 = i; , only: Demo.C(20): ERROR: MOV P0, A can't be emulated: replace with: WriteP0() The statement in this line is replaced by an intrinsic function call:

void main (void)
{
 uchar i;
 while (TRUE)
 {
 P2\_3 = 1;
 if (P0\_4) i=1;
 else i=i+1;
 i = P2;
 WriteP0(i);
}

; FUNCTION main (BEGIN) ?C0001: SETB P2.3 JNB P0.4,?C0003 MOV i,#01H SJMP ?C0004 ?C0003: i INC ?C0004: A,P2 MOV i,A MOV R7,i MOV A,R7 ; Intrinsic Function MOV P0,A MOV SJMP ?C0001 RET ; FUNCTION main (END)

The following final program is generated by the compiler:

Appendix

# Appendix

# A BicWin short keys

# A.1 Function keys

|     |                | ALT       | STRG         | SHIFT           |
|-----|----------------|-----------|--------------|-----------------|
| F1  | Help           |           |              |                 |
| F2  | CPU Reset      | Reset all | Clear trace  | Macro short key |
| F3  | Search Again   |           |              | Macro short key |
| F4  | Run to Cursor  | Terminate | Close window | Macro short key |
| F5  | Go to          |           | Go to symbol | Macro short key |
| F6  | Next window    |           |              | Previous window |
| F7  | Single step    |           |              | Macro short key |
| F8  | Jump over Call |           |              | Macro short key |
| F9  | Run            |           |              | Macro short key |
| F10 | Menue          |           |              | Context menue   |

# A.2 ALT-keys

| key   | function   | type      |
|-------|------------|-----------|
| Alt+A | Assembler  | (window)  |
| Alt+B | Break      | (dialog)  |
| Alt+C | Command    | (window)  |
| Alt+D | Debug      | (menue)   |
| Alt+E | Trace      | (menue)   |
| Alt+F | File       | (menue)   |
| Alt+H | Help       | (menue)   |
| Alt+I | IntData    | (window)  |
| Alt+K | Break      | (menue)   |
| Alt+M | Macro      | (menue)   |
| Alt+N | Window     | (menue)   |
| Alt+O | Options    | (menue)   |
| Alt+P | Program    | (window)  |
| Alt+R | Register   | (Fenster) |
| Alt+S | Sourcetext | (window)  |
| Alt+T | Trace      | (window)  |
| Alt+V | Views      | (menue)   |
| Alt+W | Watch      | (menue)   |
| Alt+X | ExtData    | (window)  |
| Alt+Y | Memory     | (menue)   |
| Alt+1 | Watch 1    | (window)  |
| Alt+2 | Watch 2    | (window)  |
| Alt+3 | Watch 3    | (window)  |
| Alt+4 | Watch 4    | (window)  |

# **B** Interfaces

#### **B.1** Emulation POD Connector

Most signals of the Emulation CPU are connected directly with the Emulation Connector. The following lines are buffered:

- P0.0 ... P0.7 (Port 0)
- P2.0...P2.7 (Port 2)
- PSEN, ALE and P3.6 (only if it is used as WR signal).

These and the following information are true for processor adapters (PODs) only. If an **BICEPS** Universal adapter is used see appendix C.1. The emulator hardware operates with 3.3V logic levels and so are the output levels for generated signals. Inputs and outputs are full HCMOS compatible.

## **B.2 Power Supply**

The **BICEPS** emulator is supplied over the power socket by the provided power supply unit. It generates a stabilized 5V voltage. Please take care of the correct mains voltage (normally 230V).

#### **B.3 PC interface (USB or serial)**

The USB interface is detected by the PC automatically and the **BICEPS** USB driver is installed when connected to the PC the first time.

If the serial interface is used, the communication format and baud rate are set automatically. Important: all pins are connected directly; no cross-cable must be used!

# **B.4** Digital inputs

Up to 16 external digital inputs (logic probes) are available; their signals are traced in the real-time trace memory or they can be used as break inputs (see chapter 6 and 7). The inputs have a pull-up-resistor.

In addition to the 16 signal inputs two output signals for triggering external devices are available. These two signals correspond with the break events "Break1" and "Break2". Please note the following specialities:

- the signal "Break1" drives also the "Trigger" LED at the front panel of the emulator
- the signal "Break2" is inverted to enable an activ low triggering of devices.



Fig. B.1 External input connector

# C Specialities of the Adapters for different CPUs of the 80C51 family (PODs)

# C.1 The Universal Adapter of the BICEPS emulator

A speciality of the **BICEPS** emulator is realized with the Universal adapter: It connects the bus signals of the controller without the necessity of replacing the processor (e.g. with PCBs in SMD technique). The Universal adapter has the same pin layout as a standard memory circuit. So it can be plugged in a socket of an external program memory (EPROM) for example.

Besides the signals of the program memory socket two further signals are of importance:

- The emulator gets control about the processor on the circuit via a reset output. The RESET signal has to be fed into the circuit or connected to the RESET pin of the processor.
- The ALE signal of the processor must be taken off.

These two necessary connections are realized by means of two additional cables (with test clipses), which are connected to the Universal adapter.

Please notice:

- A system is assumed, where the data bus of the processor and the program memory socket are connected directly, so that by means of the ALE signal the lower address bits can be produced out of the data bus signals.
- Since the Universal adapter is directly, i.e. without buffering, connected to the local data bus of the circuit under test, errors with noise loaded systems cannot be excluded. In such cases an adapter with emulation processor must be used.

#### C.1.1 Memory circuit type

The address bus signals A0...A15 are taken via the Universal adapter, the data bus signals D0...D7 as well as the /PSEN signal via the /CS or the /OE pin of the program memory socket. For this a DIL plug with 32 pins is provided. PLCC versions can be adapted by means of a corresponding PLCC converter DIL28-PLCC32 or DIL32-PLCC32.

If the program memory does not use all 16 address lines, i.e. the program memory is <64k, this option has to be set in the "Options" menue of the **BicWin** software.

| Pin nu | Pin number Signal Pin number |     | Signal |      |     |
|--------|------------------------------|-----|--------|------|-----|
| DIL    | PLCC                         |     | DIL    | PLCC |     |
|        |                              |     |        |      |     |
| 3      | 2                            | A15 | 30     | 32   |     |
| 4      | 3                            | A12 | 29     | 31   | A14 |
| 5      | 4                            | A7  | 28     | 30   | A13 |
| 6      | 5                            | A6  | 27     | 29   | A8  |
| 7      | 6                            | A5  | 26     | 28   | A9  |
| 8      | 7                            | A4  | 25     | 27   | A11 |
| 9      | 8                            | A3  | 24     | 25   | /OE |
| 10     | 9                            | A2  | 23     | 24   | A10 |
| 11     | 10                           | A1  | 22     | 23   | /CS |
| 12     | 11                           | A0  | 21     | 22   | D7  |
| 13     | 13                           | D0  | 20     | 21   | D6  |
| 14     | 14                           | D1  | 19     | 20   | D5  |
| 15     | 15                           | D2  | 18     | 19   | D4  |
| 16     | 16                           | GND | 17     | 18   | D3  |

#### EPROM up to 64k, DIL28, PLCC32 (nc 1,12,17,26):

The DIL32 layout is compatible with the DIL28 layout: Pins 1,2,31,32 remain unconnected
| Pin number |      | Signal |     | umber | Signal |
|------------|------|--------|-----|-------|--------|
| DIL        | PLCC |        | DIL | PLCC  |        |
|            |      |        |     |       |        |
| 1          | 1    | A18    | 32  | 32    |        |
| 2          | 2    | A16    | 31  | 31    | /WR    |
| 3          | 3    | A15    | 30  | 30    | A17    |
| 4          | 4    | A12    | 29  | 29    | A14    |
| 5          | 5    | A7     | 28  | 28    | A13    |
| 6          | 6    | A6     | 27  | 27    | A8     |
| 7          | 7    | A5     | 26  | 26    | A9     |
| 8          | 8    | A4     | 25  | 25    | A11    |
| 9          | 9    | A3     | 24  | 24    | /OE    |
| 10         | 10   | A2     | 23  | 23    | A10    |
| 11         | 11   | A1     | 22  | 22    | /CS    |
| 12         | 12   | A0     | 21  | 21    | D7     |
| 13         | 13   | D0     | 20  | 20    | D6     |
| 14         | 14   | D1     | 19  | 19    | D5     |
| 15         | 15   | D2     | 18  | 18    | D4     |
| 16         | 16   | GND    | 17  | 17    | D3     |

# EPROM larger than 64k, DIL32, PLCC32:

If a banking memory application is emulated (program memory >64k), the address lines A16..A18 are connected via this program memory socket.

#### C.1.2 **Jumper Settings**



# **Reset logic (Jumper RST)**

Standard-80C51-RESET, high activ (default) RST=2-3:

# **Connection of /PSEN signal (Jumper JP1)**

| PSEN=1-2: | /PSEN exists at pin 24 of the socket (/OE) (default) |
|-----------|------------------------------------------------------|
|           |                                                      |

/PSEN exists at pin 22 of the socket (/CS) **PSEN=2-3**:

# WR-signal (Jumper WR)

| set:     | WR is used to write to program memory (Flash circuits) |
|----------|--------------------------------------------------------|
| removed: | WR is not used for program memory (default)            |

# C.1.3 Connections via Clips Cable

The Universal adapter of the **BICEPS** emulator has up to 5 connections for signals, which cannot be contacted directly via the EPROM socket. Two signals have to be connected in any case; the remaining signals are optional:

- 1: **RESET-Out** (necessary)
- 2: RD (optional)
- 3: WR (optional)
- 4: RESET-In (optional)
- 5: ALE (necessary)

# **Reset Output (Clips cable 1)**

The feeding of a reset signal into the circuit under test is absolutely necessary to control the processor of the circuit. It is to notice here that the Reset signal output is not disturbed by the user board. Admissible is e.g. a voltage monitoring and reset device with an open collector output. Problems can occur with an electrolytic capacitor parallel to the reset signal, it must be eliminated during the test phase.

# Must be connected!

# Write and Read (Clips cables 2,3)

The connections 2 (/RD) and 3 (/WR) are provided for systems with external data memory. If the signals are connected, accesses to the external data memory can be defined as break condition and traced in the real time trace memory. If the /WR-signal is connected via the socket (jumper /WR), clips cable 3 is not necessary.

# Input for external Reset (clips cable 4)

Not supported.

ALE signal (clips cable 5) Must be connected!

# C.2 POD B51 for CPUs in standard 40/44 pin package (8xC51, 8xC51RB2/RC2/RD2/ED2, 80C320, C501...)



## **CPU clock (Jumper A)**

A1=2-3: Emulator clock (oscillator of partA, default)

A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

## **RD- and WR signals (Jumper B)**

B1, B2, B4: P3.7 = RD, P3.6 = WR (default) B3: P3.7 = Port, P3.6 = Port

## Power supply of the adapter (Jumper C)

- C2, C3, C4: Standard-80C51, internal power supply (default)
- C1, C3, C4: Standard-80C51, exteral power supply by the user board
- C1, C2, C5: Philips 8x591, internal power supply
- C1, C4, C5: Philips 8x591, external power supply by the user board

## **Reset logic (Jumper D)**

| D1=2-3, D2=2-3: | Standard-80C51-RESET, high activ (default)             |
|-----------------|--------------------------------------------------------|
| D1=1-2, D2=1-2: | Inverted reset: /RESET, low activ (for example 8xC591) |

# C.3 POD BC51CC for AT89C51CC01/02/03/AC2/AC3



## **CPU clock (Jumper A)**

A1=2-3: Emulator clock (oscillator of partA, default) A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

## **RD- and WR signals (Jumper B)**

B1, B2, B4: P3.7 = RD, P3.6 = WR (default) B3: P3.7 = Port, P3.6 = Port

| JC=1-2: | internal power supply (default)        |
|---------|----------------------------------------|
| JC=2-3: | exteral power supply by the user board |

# C.4 POD BC51CC-52 for AT89C51CC03 (PLCC52)



#### **CPU clock (Jumper A)**

A1=2-3: Emulator clock (oscillator of partA, default) A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

#### **RD- and WR signals (Jumper B)**

B1, B2, B4: P3.7 = RD, P3.6 = WR (default) B3: P3.7 = Port, P3.6 = Port

#### Power supply of the adapter (Jumper C)

JC=1-2:internal power supply (default)JC=2-3:exteral power supply by the user board

# C.5 POD B51-68 for Atmel 8xC51RD2/ED2 (PLCC68)



## **CPU clock (Jumper A)**

A1=2-3: Emulator clock (oscillator of partA, default) A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

## **RD- and WR signals (Jumper B)**

B1, B2, B4: P3.7 = RD, P3.6 = WR (default) B3: P3.7 = Port, P3.6 = Port

| JC=1-2: | internal power supply (default)        |
|---------|----------------------------------------|
| JC=2-3: | exteral power supply by the user board |

# C.6 POD B5131USB for Atmel 89C5131 (PLCC52)



## **CPU clock (Jumper A)**

A1=2-3: Emulator clock A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

#### **RD- and WR signals (Jumper B)**

B1, B2, B4: P3.7 = RD, P3.6 = WR (default) B3: P3.7 = Port, P3.6 = Port

| JC=2-3: | internal power supply (default)        |
|---------|----------------------------------------|
| JC=1-2: | exteral power supply by the user board |

# C.7 POD B51SND1 for Atmel 8xC51SND1 (QFP80)



## **CPU clock (Jumper A)**

A1=2-3: Emulator clock (oscillator of partA, default) A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

## **RD- and WR signals (Jumper B)**

B1, B2, B4: P3.7 = RD, P3.6 = WR (default) B3: P3.7 = Port, P3.6 = Port

| JC=1-2: | internal power supply (default)        |
|---------|----------------------------------------|
| JC=2-3: | exteral power supply by the user board |

# C.8 POD BuC8xx for AnalogDevices ADµC812/816/824



## **CPU clock (Jumper A)**

A1=2-3: Emulator clock (oscillator of partA, default) A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

# **RD- and WR signals (Jumper B)**

| B1, B2, B4: | P3.7 = RD,   | P3.6 = WR   | (default) |
|-------------|--------------|-------------|-----------|
| B3:         | P3.7 = Port, | P3.6 = Port |           |

| JC=1-2: | internal power supply (default)        |
|---------|----------------------------------------|
| JC=2-3: | exteral power supply by the user board |

# C.9 POD B552 for Philips 8xC552



## **CPU clock (Jumper A)**

A1=2-3: Emulator clock (oscillator of partA, default) A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

# **RD- and WR signals (Jumper B)**

| B1, B2, B4: | P3.7 = RD,   | P3.6 = WR   | (default) |
|-------------|--------------|-------------|-----------|
| B3:         | P3.7 = Port, | P3.6 = Port |           |

| JC=2-3: | internal power supply (default)        |
|---------|----------------------------------------|
| JC=1-2: | exteral power supply by the user board |

# C.10 POD B592 for Philips 8xC592



## **CPU clock (Jumper A)**

A1=2-3: Emulator clock (oscillator of partA, default) A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

# **RD- and WR signals (Jumper B)**

| B1, B2, B4: | P3.7 = RD,   | P3.6 = WR   | (default) |
|-------------|--------------|-------------|-----------|
| B3:         | P3.7 = Port, | P3.6 = Port |           |

| JC=2-3: | internal power supply (default)        |
|---------|----------------------------------------|
| JC=1-2: | exteral power supply by the user board |

# C.11 POD B517 for Infineon C517A/80C537 (with converter also for C515A/80C535)



# CPU clock (Jumper A)

A1=2-3: Emulator clock (oscillator of partA, default) A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

## **RD- and WR signals (Jumper B)**

B1, B2, B4: P3.7 = RD, P3.6 = WR (default) B3: P3.7 = Port, P3.6 = Port

- JC=2-3: internal power supply (default)
- JC=1-2: exteral power supply by the user board

# C.12 POD B390 for Dallas 80C390



## **CPU clock (Jumper A)**

A1=2-3: Emulator clock (oscillator of partA, default) A1=1-2, A2: external clock or crystal (XTAL pins are connected directly with the board)

## **RD- and WR signals (Jumper B)**

B1, B2, B4: P3.7 = RD, P3.6 = WR (default) B3: P3.7 = Port, P3.6 = Port

## Power supply of the adapter (Jumper C)

| JC=2-3: | internal power supply (default)        |
|---------|----------------------------------------|
| JC=1-2: | exteral power supply by the user board |

## Mux input (Jumper D)

Do not use

# **D BICEPS-Debug-Connector**

# **D.1** Basic information

By use of the pin headers described in this chapter it is possible to connect the test board and the **BICEPS** emulator by a flat ribbon cable. The controller is not replaced, a special POD is not needed.

Some signals of the controller have to be separated from the rest of the circuit. Their connection is done via the debug connector. The signals which are connected directly with the controller have the extension "\_CPU". The signals which are connected with the rest of the circuit have the extension "\_Board".

If the board is to be operated without emulator, the emulator cable is removed and replaced by short-circuit jumpers, i.e. ,\_\_CPU"- and ,,\_Board"-signals are connected.

It can be choosen between two pin header types (standard and high-density) and between several operating modes for P0 and P2.

Pin 1 of the pin header is to be located at the border of the PCB, because the flat ribbon cable has to be thought to come from the <u>left</u> side according to the following tabels.

# D.2. Applications without external bus (P0=Port, P2=Port, emulation with Softhooks)

High-density pin header, 40 pins, grid 1.27/2.54

| P20_Board | 1  | 2  | P20_CPU  |
|-----------|----|----|----------|
| P21_Board | 3  | 4  | P21_CPU  |
| P22_Board | 5  | 6  | P22_CPU  |
| P23_Board | 7  | 8  | P23_CPU  |
| P24_Board | 9  | 10 | P24_CPU  |
| P25_Board | 11 | 12 | P25_CPU  |
| P26_Board | 13 | 14 | P26_CPU  |
| P27_Board | 15 | 16 | P27_CPU  |
| GND       | 17 | 18 | PSEN_CPU |
| GND       | 19 | 20 | ALE_CPU  |
| Rst_Board | 21 | 22 | Rst_CPU  |
| EA_Board  | 23 | 24 | EA_CPU   |
| P07_Board | 25 | 26 | P07_CPU  |
| P06_Board | 27 | 28 | P06_CPU  |
| P05_Board | 29 | 30 | P05_CPU  |
| P04_Board | 31 | 32 | P04_CPU  |
| P03_Board | 33 | 34 | P03_CPU  |
| P02_Board | 35 | 36 | P02_CPU  |
| P01_Board | 37 | 38 | P01_CPU  |
| P00_Board | 39 | 40 | P00_CPU  |

Separated signals:

EA, RST, P00..P07 and P20..P27



# PCB layout for 40 pin connector and PLCC44 controller

# **D.3** Applications with external bus <u>without</u> banking

# Standard pin header, 26 pins, grid 2.54 mm

| Rst_Board  | 1  | 2  | Rst_CPU  |
|------------|----|----|----------|
| WR_CPU     | 3  | 4  | WR_Board |
| RD_CPU     | 5  | 6  | GND      |
| PSEN_Board | 7  | 8  | PSEN_CPU |
| GND        | 9  | 10 | ALE_CPU  |
| A8_CPU     | 11 | 12 | A9_CPU   |
| A10_CPU    | 13 | 14 | A11_CPU  |
| A12_CPU    | 15 | 16 | A13_CPU  |
| A14_CPU    | 17 | 18 | A15_CPU  |
| AD7_CPU    | 19 | 20 | AD6_CPU  |
| AD5_CPU    | 21 | 22 | AD4_CPU  |
| AD3_CPU    | 23 | 24 | AD2_CPU  |
| AD1_CPU    | 25 | 26 | AD0_CPU  |

Condition: Separated signals: EA\_CPU = GND RST, PSEN and WR

# **D.4** Applications with external bus <u>with banking</u>

# Standard pin header, 34 pins, grid 2.54 mm

| A16        | 1  | 2  | A17      |
|------------|----|----|----------|
| A18        | 3  | 4  | A19      |
| GND        | 5  | 6  | GND      |
| EA_CPU     | 7  | 8  | EA_Board |
| Rst_Board  | 9  | 10 | Rst_CPU  |
| WR_CPU     | 11 | 12 | WR_Board |
| RD_CPU     | 13 | 14 | GND      |
| PSEN_Board | 15 | 16 | PSEN_CPU |
| GND        | 17 | 18 | ALE_CPU  |
| A8_CPU     | 19 | 20 | A9_CPU   |
| A10_CPU    | 21 | 22 | A11_CPU  |
| A12_CPU    | 23 | 24 | A13_CPU  |
| A14_CPU    | 25 | 26 | A15_CPU  |
| AD7_CPU    | 27 | 28 | AD6_CPU  |
| AD5_CPU    | 29 | 30 | AD4_CPU  |
| AD3_CPU    | 31 | 32 | AD2_CPU  |
| AD1_CPU    | 33 | 34 | AD0_CPU  |

Separated signals: EA, RST, PSEN and WR

# **D.5 BICEPS-ICE-connect**

The BICEPS-ICE-connect adapter combines the ICE-connect standard with the Softhook emulation technique. A 30-pin pin-header connects the bus signals of the controller on the target board. Two additional 10-pin connectors are used for P0 and P2 I/O-port emulation signals.

# Standard pin header, 30 pins, grid 1.27/2.54 mm

| 1  | 2                                                                      | AD0_CPU                                                                                        |
|----|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------|
| 3  | 4                                                                      | AD2_CPU                                                                                        |
| 5  | 6                                                                      | AD4_CPU                                                                                        |
| 7  | 8                                                                      | AD6_CPU                                                                                        |
| 9  | 10                                                                     | GND                                                                                            |
| 11 | 12                                                                     | A9_CPU                                                                                         |
| 13 | 14                                                                     | A11_CPU                                                                                        |
| 15 | 16                                                                     | VCC                                                                                            |
| 17 | 18                                                                     | A14_CPU                                                                                        |
| 19 | 20                                                                     | GND                                                                                            |
| 21 | 22                                                                     | PSEN_Board                                                                                     |
| 23 | 24                                                                     | RD_Board                                                                                       |
| 25 | 26                                                                     | WR_Board                                                                                       |
| 27 | 28                                                                     | Rst_Board                                                                                      |
| 29 | 30                                                                     | ALE-CPU                                                                                        |
|    | 3<br>5<br>7<br>9<br>11<br>13<br>15<br>17<br>19<br>21<br>23<br>25<br>27 | 3 4   5 6   7 8   9 10   11 12   13 14   15 16   17 18   19 20   21 22   23 24   25 26   27 28 |

| Condition:         | $EA_CPU = GND$       |
|--------------------|----------------------|
| Separated signals: | RST, PSEN, RD and WR |

# JP0 Port P0 connector Standard pin header, 10 pins, grid 2.54 mm

| P0.0 | 1 | 2  | P0.1 |
|------|---|----|------|
| P0.2 | 3 | 4  | P0.3 |
| P0.4 | 5 | 6  | P0.5 |
| P0.6 | 7 | 8  | P0.7 |
| GND  | 9 | 10 | GND  |

# JP2 Port P2 connector Standard pin header, 10 pins, grid 2.54 mm

| P2.0 | 1 | 2  | P2.1 |
|------|---|----|------|
| P2.2 | 3 | 4  | P2.3 |
| P2.4 | 5 | 6  | P2.5 |
| P2.6 | 7 | 8  | P2.7 |
| GND  | 9 | 10 | GND  |