

# AN1560 APPLICATION NOTE

# Design Guide for the uPSD3200 Family

The uPSD3200 family is a series of 8051-class microcontrollers (MCUs) containing an 8032 core with a large dual-bank Flash memory, a large SRAM, many peripherals, programmable logic, and JTAG In-System Programming (ISP) (see Figure 1.).

This document shows the steps to create a design using the DK3200 development board, the software development tool PSDsoft Express, and uVision2 8051 Integrated Development Environment (IDE) from Keil Software.



#### Figure 1. uPSD3234A Block Diagram

# AN1560

|                                                                        | 1      |
|------------------------------------------------------------------------|--------|
| Figure 1. uPSD3234A Block Diagram.                                     | -      |
| uPSD3200 FAMILY OVERVIEW                                               | 4      |
| DK3200 OVERVIEW                                                        | 5      |
| Figure 2. DK3200 Development Board                                     | 5      |
|                                                                        | 6      |
|                                                                        | 0      |
| Figure 3. Design Block Diagram                                         | 6<br>7 |
|                                                                        | •      |
| ENTERING DESIGN IN PSDSOFT EXPRESS                                     | 9      |
| Invoke PSDsoft Express and Create Project                              | 9      |
| Select MCU and Initial Placement of Flash in Code Space or Data Space. | 9      |
|                                                                        | 9      |
|                                                                        | 1      |
|                                                                        | י<br>י |
| Page Register                                                          | 2      |
| Figure 7 Page Register Definition                                      | 2      |
| Chip-Select Equations                                                  | 3      |
| Figure 8. Chip-Select Definition for 8K byte SRAM                      | 3      |
| Figure 9. Chip-Select Definition for Flash Memory Segments             | 4      |
| Figure 10.External Chip-Select Definition for LCD Module               | 5      |
| I/O Logic Equations.                                                   | 5      |
| Figure 11.Logic Equation for signal LCD_rw1                            | 6      |
| User-Defined Node Equations1                                           | 6      |
| Figure 12.4-bit Down-Counter with Automatic Reload of Initial Count    | 6      |
| Figure 13.D-register Node                                              | 7      |
| Edit ABEL HDL Statements for PLD Design1                               | 7      |
| Figure 14.Design Flow Diagram1                                         | 8      |
| Additional µPSD Configuration2                                         | 0      |
| C Code Generation                                                      | 0      |
| Figure 15.Coded Example Generation                                     | 0      |
| Fitting Design                                                         | 0      |
| Merging 8032 Firmware with µPSD Configuration                          | 1      |
| Figure 16.Firmware Merging Utility                                     | 2      |
| Figure 17. Merging the Example Firmware                                | 3      |
|                                                                        | 3      |
|                                                                        | 4      |
| WATCH IT RUN ON DK3200                                                 | 5      |
| USING UVISION2 AND ISD51 DEBUGGER FROM KEIL SOFTWARE, INC              | 6      |
| Loading a Keil uVision2 Project                                        | 6      |

# AN1560

| Building the Project and Programming the µPSD                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                             |
| Figure 19.Debug icon                                                                                                                                                                                                                                                                                                                                                                        |
| Figure 20.Keil ISD51 Just After it is Successfully Invoked    27                                                                                                                                                                                                                                                                                                                            |
| CONCLUSION                                                                                                                                                                                                                                                                                                                                                                                  |
| APPENDIX A.PSDSOFT EXPRESS PROJECT SUMMARY FILE, DK3200_1.SUM                                                                                                                                                                                                                                                                                                                               |
| APPENDIX B.PSDSOFT EXPRESS ABEL HDL FILE DK3200_1.ABL                                                                                                                                                                                                                                                                                                                                       |
| APPENDIX C.PSDSOFT EXPRESS FITTER REPORT DK3200_1.FRP                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                             |
| APPENDIX D.DK3200 BOARD LAYOUT42                                                                                                                                                                                                                                                                                                                                                            |
| APPENDIX D.DK3200 BOARD LAYOUT.         42           Figure 21.DK3200 Board Layout.         42                                                                                                                                                                                                                                                                                              |
| APPENDIX D.DK3200 BOARD LAYOUT.         42           Figure 21.DK3200 Board Layout.         42           APPENDIX E.DK3200 SCHEMATICS         43                                                                                                                                                                                                                                            |
| APPENDIX D.DK3200 BOARD LAYOUT.         42           Figure 21.DK3200 Board Layout.         42           APPENDIX E.DK3200 SCHEMATICS         43           Figure 22.DK3200 Schematics (1)         43                                                                                                                                                                                       |
| APPENDIX D.DK3200 BOARD LAYOUT.       42         Figure 21.DK3200 Board Layout.       42         APPENDIX E.DK3200 SCHEMATICS       43         Figure 22.DK3200 Schematics (1)       43         Figure 23.DK3200 Schematics (2)       44                                                                                                                                                    |
| APPENDIX D.DK3200 BOARD LAYOUT.       42         Figure 21.DK3200 Board Layout.       42         APPENDIX E.DK3200 SCHEMATICS       43         Figure 22.DK3200 Schematics (1)       43         Figure 23.DK3200 Schematics (2)       44         Figure 24.DK3200 Schematics (3)       45                                                                                                   |
| APPENDIX D.DK3200 BOARD LAYOUT.       42         Figure 21.DK3200 Board Layout.       42         APPENDIX E.DK3200 SCHEMATICS       43         Figure 22.DK3200 Schematics (1)       43         Figure 23.DK3200 Schematics (2)       44         Figure 24.DK3200 Schematics (3)       45         Figure 25.DK3200 Schematics (4)       46                                                  |
| APPENDIX D.DK3200 BOARD LAYOUT.       42         Figure 21.DK3200 Board Layout.       42         APPENDIX E.DK3200 SCHEMATICS       43         Figure 22.DK3200 Schematics (1)       43         Figure 23.DK3200 Schematics (2)       44         Figure 24.DK3200 Schematics (3)       45         Figure 25.DK3200 Schematics (4)       46         Figure 26.DK3200 Schematics (5)       47 |

# **UPSD3200 FAMILY OVERVIEW**

The uPSD3200 family is a standard 12-clock per instruction 8032 MCU capable of being clocked up to 40MHz at 5.0V and 24MHz at 3.3V at industrial operating temperature range. Currently there are seven family members that are different combinations of Flash memory size, operating voltage, peripheral set, and packaging (see datasheet). The fullest featured part, uPSD3234A-40U6, is used in this Application Note. The term  $\mu$ PSD is used throughout the remainder of the document for brevity. See  $\mu$ PSD block diagram in Figure 1..

The  $\mu$ PSD has a unique memory structure that includes two independent Flash memory arrays (main and secondary) capable of read-while-write operation. This is ideal for In-Application Programming (IAP) because the 8032 can fetch instructions from one Flash memory array while erasing/writing the other array. Individual sectors of each Flash memory array can be mapped to virtually any 8032 address by the Decode PLD (DPLD) for total flexibility. The  $\mu$ PSD also contains a Page Register whose outputs feed the inputs of the DPLD. This allows paging (or banking) of Flash memory to break the 8032's inherent limit of 64K byte addresses. The 8032 may write to the Page Register at runtime.

For more complex designs, the  $\mu$ PSD is capable of placing each of the Flash memory arrays (Main or Secondary) into 8032 code address space, into 8032 data space, or into both code and data space on the fly. Mapping flexibility like this supports IAP because either Flash memory array may be temporarily placed into data space while the firmware is updated, then moved back into code space when finished, all under control of the 8032.

Many peripherals are available in this  $\mu$ PSD, including: USB v1.1 (low speed), two UART channels, four PWM channels, one I<sup>2</sup>C channel, four 8-bit ADC channels, DDC (Data Display Channel for LCD monitors and projectors), a watchdog timer, low-V<sub>CC</sub> detection with reset-out, a general purpose PLD, and many GPIO.

All of the peripherals on Ports 1, 3, and 4 are controlled using 8032 Special Function Registers (SFRs). I/ O Signals on ports A, B, C, and D are controlled one of two ways: One, by a block of xdata memory mapped control registers, whose base address (*csiop*) can be mapped anywhere using the DPLD; Two, by the programmable logic.

The JTAG ISP channel on Port C is ideal for rapid code iterations during firmware development and for Just-In-Time inventory management during manufacturing. JTAG ISP eliminates the need for sockets and pre-programmed devices, and requires no participation of the 8032.

**бу/** 

# **DK3200 OVERVIEW**

A picture of the DK3200 board is shown in Figure 2.. Board layout and schematics are in the Appendix. Connectors JP1, J3, J4, J5 provide easy access to all  $\mu$ PSD I/O signals for expansion or testing. JP1 accepts jumper shunts to wrap  $\mu$ PSD outputs back into  $\mu$ PSD inputs for testing. J3, J4, J5 can connect directly to standard Agilent (HP) Logic analyzer pods. UARTs are available on P1 and P2. A USB host can connect to the  $\mu$ PSD as a peripheral via J2. The FlashLINK JTAG ISP cable connects at J1. Connectors JP2, JP3, JP4, JP5 allow direct connect the switches (SW1, SW2) and the LEDs (LED1, LED2) to PSD port B. LED D5 indicates JTAG ISP Programming. The DK3200 also has a 2-line 16 character LCD interface and a full featured real-time clock with SNAPHAT snap-on battery/crystal pack.

#### Figure 2. DK3200 Development Board



57

# DESIGN EXAMPLE BLOCK DIAGRAM

This simple design example is represented by the block diagram of Figure 3., and the memory map of Figure 4.. All 16 macrocells of the PLD are used, Flash memory is paged, and few of the 8032 interfaces (ADC, PWM, UART) are configured and used. The idea is to touch several aspects of the  $\mu$ PSD that may be unfamiliar to a typical 8051 user and to give you an idea of how to use the design tools and become familiar with  $\mu$ PSD architecture.





Figure 3. shows the design implemented in this application note. Major elements are the  $\mu$ PSD, an LCD module, and an RS-232 transceiver chip.

The 8032 outputs a repetitive PWM pulse train with a slowly varying pulse width to an RC network which converts the pulse train into a slowly sweeping DC voltage (0 to 5V). This DC signal is looped back into an ADC input. The 8032 will write the resulting Hexadecimal ADC conversion value to the LCD so you can watch the results. The RC network and loop-back is implemented with two jumpers on the DK3200 board.

Additionally and independently, a 4-bit auto-reloading down-counter is created using PLD macrocells. The 8032 directly loads the initial count value into four macrocells, and that count is automatically loaded into another four macrocells that create the 4-bit down-counter. Reloading occurs each time the counter reaches terminal count of zero. Terminal count is indicated externally by a pulse on a  $\mu$ PSD output pin. The down-counter is clocked by ALE signal (ALE was random choice, could be any signal). The 8032 may load a different initial count at anytime, creating a variable divider of the ALE signal.

Four more macrocells are used to output the high four 8032 address signals. The 80-pin  $\mu$ PSD only outputs the low twelve 8032 address signals on dedicated pins. If more address signals are needed externally, they have to be added this way using the PLD.

The LCD module is connected to the  $\mu$ PSD via a Port A for data and Port B for some glue logic and a chipselect signal. Port A is operating is an special data bus repeater mode this example, called Peripheral I/O mode. 8032 data will pass through port A only for a given address range specified in PSDsoft Express (illustrated later).





**A**7/

The memory map in Figure 4. shows that the 32K byte secondary Flash memory is used for 8032 code, and the 256K byte main Flash memory is used for 8032 data, banked over eight pages. The nomenclature *fsx, csbootx, rs0, csiop,* and *psel* in Figure 4. refer to the individual internal  $\mu$ PSD memory segments. The  $\mu$ PSD main Flash memory has a total of eight 32K byte segments (*fs0..fs7*). The  $\mu$ PSD secondary Flash memory has a total of four 8K byte segments (*csboot0-csboot3*). The  $\mu$ PSD 8K byte SRAM has a single segment (*rs0*). A group of  $\mu$ PSD control registers which control I/O ports A, B, C, and D lie in a 256-byte xdata address space whose base address is named *csiop*. The  $\mu$ PSD has a data bus repeater feature that is enabled over a given address range as specified by *psel*. Figure 4. also shows one external memory select signal, *LCD\_e*, for the LCD module. This memory map is specified using the software tool PSDsoft Express. Each memory segment can be placed at virtually any address, which provides an infinite number of mapping schemes. This is just one example.

We'll keep things simple for this particular application note, meaning the 8032 will "boot" and run code contained completely within the 32K byte secondary Flash memory in code space and we'll treat the 256K byte main Flash memory as data only. However, this memory map may grow with the needs of your project. For example, if a large Flash memory is needed for code space and IAP is required, a slight variation of the map in Figure 4. can accomplish this. The 8032 can boot from secondary Flash memory (secondary Flash memory resides in code space from 0-7FFF as in Figure 4.), then the 8032 can calculate a checksum on the main Flash memory and then program the main Flash memory if necessary (main Flash memory resides in data space from 8000-FFFF on eight pages as in Figure 4.). After the contents of main

#### AN1560

Flash memory are verified, the 8032 can write to special register, called the VM register within the *csiop* register block, to "reclassify" the main Flash memory from data space to code space. After which, the 8032 will have access to 256K bytes of Flash memory for code in code space, paged across eight code pages in upper memory (8000-FFFF), and the 8032 will have access to 32K bytes of Flash memory for code in code space common to all pages in lower memory (0-7FFF). At that point no Flash memory will reside in data space. Upon reset, the memory map is reset to look like Figure 4. again. The VM register can be accessed by the 8032 at runtime to perform a variety of manipulations. PSDsoft is used to set the initial value of the VM register upon power-up. Future Application notes will illustrate various memory schemes.



# **ENTERING DESIGN IN PSDSOFT EXPRESS**

Highlights of the design process will be given here. The steps are simple and navigation through PSDsoft Express is easy. Invoke PSDsoft Express and follow along if you wish. PSDsoft Express is included in the DK3200 CD, but you should check for latest updates. Updates are available from our web site at www.st.com/psm, in the "Software Downloads" area.

#### Invoke PSDsoft Express and Create Project

- Install PDSsoft Express (from the web or the included CD)
- Start PSDsoft Express
- Create a new project
- Select your project folder and name the project (in this example, name the project "DK3200\_1" in the folder PSDexpress\my\_project\dk3200\_dsn\_1\..

Note that the folder, *dk3200\_dsn\_1 under PSDexpress\my\_project*, does not exist and needs to be created.

#### Select MCU and Initial Placement of Flash in Code Space or Data Space

- Select an MCU. In this case it is STMicroelectronics, then uPSD32xx, then uPSD3234A.
- Select the main Flash memory to reside in 8032 data space at power-up (means that the 8032 \_RD and \_WR signals are routed to the main Flash memory array)
- Select the secondary Flash memory to reside in 8032 code space at power-up (means that the 8032 \_PSEN signal is routed to the secondary Flash memory array)

Note: At runtime, the 8032 can alter the initial settings of code and data space by writing to the VM register.

Figure 5. shows what the screen should look like after you've made the selections.

Click OK. Now you will be asked if you want to use the Design Assistant, Extended Design Assistant, or Example Template. Choose Example Template. This is a predefined design that matches this application note and it runs on the DK3200 board. Next choose the template for the DK3200 Kit when prompted.

#### **Pin Definitions**

You will see the Pin Definitions screen appear. All of the pin definitions shown in block diagram of Figure 3. are filled in. Click through the pins and see how they are configured and how they relate to Figure 3.. You'll notice that you cannot change the definition of some pins because they have a fixed function.

A comment about JTAG pins. This example uses 6-pin JTAG which is up to 30% faster than the default standard 4-pin JTAG. The two extra pins in the 6-pin JTAG configuration are *\_tstat* and *terr*.

Now click "Next" to move on to the Design Assistant for memory mapping and logic equations. You will see the Page Register definition screen.

47/

# Figure 5. MCU Selection

| MCU                        | /DSP and PSD Selection                                                                                                                                                                                                                                                                                                                                                                                                                            | ×                                                                                                                                                                                                                                  |  |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| S<br>M<br>a<br>M<br>T<br>C | Step 1: Select Microcontroller (MCU or DSP)         ielect an MCU/DSP and its control signal options. If your         ACU/DSP does not appear on the list, select 'Other', then         ipecify its control signal configuration. Check latest MCU/DSP         and PSD data sheets to confirm AC timing compatibility.         Manufacturer:       STMicroelectronics         ype:       uPSD32XX         Control Signals:       fw/R, /RD, /PSEN | Step 2: Specify the PSD device         Use product selection wizard         Wizard         PSD Family:       uPSD3000         Part Number:       uPSD3234A         Package:       U (80-Pin TQFP)         Voltage:       4.5V-5.5V |  |
| S                          | Step 3: Select PSD configuration         Select a particular configuration for the device.         Bus Width:         Bus Mode:         ALE/AS Active-level:         Main PSD flash memory will reside in this space at power-up:         Secondary PSD flash memory will reside in this space at power-up:                                                                                                                                       | 8-bit Multiplexed Bus High Data Space Only Program Space Only                                                                                                                                                                      |  |
|                            | Description for any selection above                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                    |  |
|                            | Specify the PSD device family for your design.                                                                                                                                                                                                                                                                                                                                                                                                    | ×                                                                                                                                                                                                                                  |  |
|                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                   | OK Cancel                                                                                                                                                                                                                          |  |

#### Figure 6. Pin Definitions

| Pin Definitions         |                 |                       |              |   | ×                                         |
|-------------------------|-----------------|-----------------------|--------------|---|-------------------------------------------|
| Define each pin by rep  | eating the foll | owing steps:          |              |   | Step 2: Pin Function                      |
| (standard pins already) | defined)        |                       |              |   | Define the pin function, then click the   |
| Step 1: Select a        | pin on the      | chip diagram          | below        |   | Add/Update button. Return to step 1       |
| LCD d7                  | C pa7           | p3.6 🔿                | 8            |   | repeat for next pin.                      |
| LCD d6                  | По раб          | p3.5 C                |              |   | Name: pc7                                 |
| LCD d5                  | l c pa5         | p3.4 C                |              |   |                                           |
|                         | l C pa4         | p3.3 C                |              |   | Pin Function —                            |
| LCD d3                  | По раЗ          | p3.2 C                |              |   | CPLD Input                                |
| LCD d2                  | D pa2           | p3.1 C                | USART1_Txd   | i | Logic or address                          |
|                         | C pa1           | p3.0 🔿                | USART1_Rxd   |   | C Latched address                         |
| LCD_d0                  | D pa0           | p1.7 🔿                |              |   | C PT clocked register                     |
| LCD_e                   | C pb7           | p1.6 🔿                |              |   | O PT clocked latch                        |
|                         | pb6             | p1.5 🔿                |              |   |                                           |
| LCD_rs                  | D pb5           | р1.4 <u>С</u>         | ADC_Ch0      |   | CPLD Output                               |
| term_count              | C pb4           | p1.3 🔿                |              |   | C Combinatorial                           |
| a15_x                   | C pb3           | p1.2 🔿                |              |   | C D-type register                         |
| a14_x                   | о рь2           | p1.1 🔿                |              |   |                                           |
| a13_x                   | 🔿 pb1           | p1.0 🔿                |              |   |                                           |
| a12_x                   | 🗍 🔿 pb0         | a11 C                 | a <b>1</b> 1 |   |                                           |
|                         | 🗇 pc7           | a10 C                 | a10          |   | C External chin select - Active Hi        |
| tdo                     | 🔿 pc6           | a9 (C                 | a9           |   | C External chip select . Active.l o       |
| tdi                     | 🔿 pc5           | a8 (C                 | a8           |   |                                           |
| _terr                   | ] ⊖ pc4         | ad7 C                 | a7           |   | 0 ther                                    |
| tstat                   | ] 🔿 pc3 👘       | ad6 🔿                 | a6           |   | C GBU0 mode                               |
|                         | 🔿 pc2           | ad5 🔿                 | a5           |   | C CD V0 mode                              |
| tok                     | pc1             | $^{\rm ad4}$ C        | a4           |   | Car i/ o mode with pin enable             |
| tms                     | 🔿 pc0           | ad3 🔿                 | a3           |   |                                           |
|                         | 🔿 pd2           | $_{ m ad2}$ $_{ m C}$ | a2           |   | Add Delete                                |
|                         | 🔿 pd1           | ad1 C                 | al           |   | Step 3 (Final Step)                       |
| ale                     | 🔿 ale           | $^{\rm ad0}$ C        | aO           |   | Click Next>> after all pins are defined.  |
| p4_7                    | 🔿 p4.7          | Reset_In 🔿            | Reset_In     |   | Click View at any time to check progress. |
|                         | ⊂ p4.6          | Vref O                | VREF         |   | Click Done to save the update and close.  |
|                         | 🔿 p4.5          | _rd O                 | _wr          |   |                                           |
|                         | 🔿 p4.4          | _psen (C              | _psen        |   | View Next>> Cancel Done                   |
| PWM0                    | 🔿 p4.3          | _wr O                 | _rd          |   |                                           |
|                         | 🔿 p4.2          | USB- C                | USB_minus    | - |                                           |
| 4                       |                 |                       |              |   | 1                                         |

#### AN1560

#### **Memory Map**

Defining the memory map requires defining the address range of chip-selects for individual memory elements of the  $\mu$ PSD (memory external to the 8032 core). Definition of the use of the  $\mu$ PSD Page Register is also required.

Four memory blocks (main Flash memory, secondary Flash memory, SRAM, and control registers) external to the 8032 core are available and are individually selected segment-by-segment when 8032 addresses are presented to the Decode PLD (DPLD). Each of these memory segments has its own chip-select name (*fs3, csboot1, rs0, csiop*, etc.). Equations for these chip-selects, and for any external chip-selects, must be specified using PSDsoft Express. For this example, chip-selects are defined to match the memory map of Figure 4..

#### Page Register

Since eight memory pages (or banks) are needed as shown in Figure 4., three paging bits ( $2^3 = 8$ ) are specified as shown in Figure 7.. The µPSD supports up to 4 paging bits (pg0, pg1, pg2, pg3) for a total of 16 pages. Unused paging bits including pg4, pg5, pg6 and pg7 may be used for other functions. Note that the paging bits used must be the LSB bits in the paging register. Click "Next".

#### Figure 7. Page Register Definition

| <ul> <li>Define how individual F</li> <li>Each bit added for 'pag</li> </ul> | PSD page register<br>ging' can extend t                        | rbits will be us⊧<br>he MCU/DSP                     | ed.<br>address range. Start with pgr0.                                                                           |   |
|------------------------------------------------------------------------------|----------------------------------------------------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------|---|
| Each bit added for 'logi                                                     | c' can be used a:<br>aister bits                               | s logic input to                                    | the PLDs. Start with pgr7.                                                                                       |   |
| Page Reg E                                                                   | Bit Type o                                                     | fUse                                                | Name of Logic Signal                                                                                             |   |
| <br>pgr7:                                                                    | 🔲 paging                                                       | 🔲 logic                                             |                                                                                                                  |   |
| pgr6:                                                                        | 🗖 paging                                                       | □ logic                                             |                                                                                                                  |   |
| pgr5:                                                                        | 🗖 paging                                                       | □ logic                                             |                                                                                                                  |   |
| pgr4:                                                                        | 🗖 paging                                                       | 🗖 logic                                             |                                                                                                                  |   |
| pgr3:                                                                        | 🗖 paging                                                       | 🔲 logic                                             |                                                                                                                  |   |
| pgr2;                                                                        | 🔽 paging                                                       | 🔲 logic                                             | pgr2                                                                                                             |   |
| pgr <b>1</b> :                                                               | 💌 paging                                                       | 🔲 logic                                             | pgr1                                                                                                             |   |
| pgr0:                                                                        | 💌 paging                                                       | 🔲 logic                                             | pgrO                                                                                                             |   |
| Description                                                                  |                                                                |                                                     |                                                                                                                  |   |
| Select this bit for mer<br>define four pages, thi<br>number required page    | nory paging, Use<br>ree bits for eight p<br>es, Always start w | one bit to defir<br>ages and so o<br>ith pgr0 and a | e two memory pages, use two bits to<br>n. Select enough bits to cover the<br>dd more bits going upward, as these |   |
| J                                                                            |                                                                |                                                     | -                                                                                                                | - |

**бу/** 

#### **Chip-Select Equations**

Now you will see the Chip-Select definition screen. Click the chip-select signal *rs0* for the 8K byte xdata SRAM, and see that its definition matches the memory map of Figure 4..

Notice that no page number is specified for *rs0* since the SRAM is common to all pages (page independent). Additional signal qualifiers (8032 control signals *rd*, *wr*, *psen*, *ale*) are NOT needed for internal µPSD chip-selects as this is taken care of in silicon. The SRAM always defaults to 8032 data space.

At any time, you can click the "View" button to see how you are doing. A summary will appear.

Now click on the chip-select *csiop* (Chip Select I/O Port). This is a band of 256 xdata registers used to control  $\mu$ PSD ports A, B, C, D, the Page Register, power management, and other functions. 40 of the 256 registers are used, see  $\mu$ PSD datasheet for register definitions and their address offset from the *csiop* base address. There is no need to specify additional signal qualifiers for *csiop*, and it is not allowed to place *csiop* on a particular memory page. The *csiop* must be xdata address space.

Next click on *fs0. fs0 .. fs7* are chip-selects for the eight 32K byte segments of µPSD main Flash memory. Notice the page number is 0 for *fs0*, and the address range is 8000 - FFFF as shown in memory map of Figure 4.. Click on remaining chip-selects for main Flash memory and notice the page number assignments. No additional signal qualifiers are needed.



#### Figure 8. Chip-Select Definition for 8K byte SRAM



Figure 9. Chip-Select Definition for Flash Memory Segments

Now click on *csboot0. csboot0 .. csboot3* are chip-selects for the four 8K byte segments of µPSD secondary Flash memory. Check the address assignments for each of these chip-selects and notice there are no page numbers assigned. The secondary Flash memory is common to all pages.

Next click on *psel0*. This address range specifies when Port A pins will behave like a data bus repeater in Peripheral I/O Mode to drive the LCD module. Port A pins were earlier specified a "Peripheral I/O Mode" which acts like a '245 bus transceiver chip connecting the 8032 data bus to external peripherals over a given address range specified by the label *psel0* or *psel1*. The direction of this transceiver function is controlled automatically in silicon by the 8032 \_*rd* and \_*wr* signals. See µPSD data sheet for details. So all we have to do is click on *psel0* and enter the address range 300 to 3FF to enable this feature for that address range as shown in Figure 4., with no Page Number assignment. *psel1* is not needed because the Peripheral I/O feature is active for the logical OR of *psel0* or *psel1*.

And finally, click on *LCD\_e*. This is an external chip-select for the LCD module. Since this is an **external** chip-select, we must include signal qualifiers *\_rd* and *\_wr*. In this design, *LCD\_e* is true (active hi) only when the 8032 presents an address in the range of 300 to 3FF AND when either 8032 control signal *\_rd* is true, OR when 8032 control signal *\_wr* is true. To create this logic, information is entered as shown in Figure 10.. Since both signals *\_rd* and *\_wr* are active low, the logical NOT operator (!) is used when they are specified as qualifiers. Signal qualifiers may be added by setting the cursor where you want the signal name to go, then just double click on the signal name in the list of eligible qualifiers.

**Á7/** 

Click "next" to move on to logic definitions.



Figure 10. External Chip-Select Definition for LCD Module

#### **I/O Logic Equations**

Defined here are equations for PLD outputs for the LCD interface signals, the additional 8032 address outputs, and the terminal count output signal from the down-counter. The Design Assistant (DA) will create HDL logic statements using the ABEL language in the background after you enter logic in this point-andclick design entry environment. The DA will also create all the declaration statements in ABEL. This saves much typing and reduces the chance of error. For more complicated logic PSDsoft allows you to edit the ABEL statements directly. In this example you'll see simple logic entered point-and-click style, and you'll see the 4-bit down-counter entered by editing the ABEL file directly.

Click on "*LCD\_rw*" as shown in Figure 11., and notice that the internal signal *a0* is assigned to drive the output signal "*LCD\_rw*". Although this was a very simple logic equation, AND, OR, XOR, NOT, and other logic operators are also available for general purpose logic.

| Page Rogister Detriction   Unips<br>Select signals in the List of sign<br>equation box or double clicking                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | elect Equations AD Logic Equations   Japi defined Node Equations   Japi defined Node Equals' Eax and define the equation by either typing in 'legic<br>the Malid executors', and Eligible signals' bex. | puotions<br>Doublo click: egic operators or signals<br>below to appoind lesk inside the logic<br>equation Eax where the cursor is located.                                                                 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| List of signel:<br>CD_w Output enable<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>LCD_'S<br>L | Chier cojc equation                                                                                                                                                                                     | Valid operators<br>Logical operators:<br>Not (Considerent or Invert,<br>& AND<br>H DR<br>* XDR<br>IS XNDR<br>-EligLite signals<br>-Jetti<br>L<br>ese,<br>of<br>all<br>all<br>-12<br>Done<br>Cancel Shok Eq |

Figure 11. Logic Equation for signal LCD\_rw

Click through the remaining signal names and observe the logic assigned. Notice there is no logic equation assigned to *term\_count* because that assignment will be made by editing the ABEL file directly. Click "Next".

#### **User-Defined Node Equations**

Here you will see how internal logic nodes are created. In this example there are four registers (or nodes) to hold the initial count of the 4-bit down-counter, and four additional registers to create the actual 4-bit down-counter. See Figure 12..





These nodes were created by clicking the "Def Node.." button, naming the node, and then selecting the type node (combinatorial, D-register, J-K register, etc.). In this example, all eight nodes are D-register type. When a register is created, you can specify it's source of Input, Clock, Reset, as Set illustrated in Figure 13.

16/49

### Figure 13. D-register Node



Click though the signal names and look at the assignments. Notice there are no definitions for inputs on any of the eight nodes. For the *down\_count* nodes, the inputs are defined elsewhere (the ABEL file). For the *init\_count* nodes, no logic input (or clock input) is specified because the 8032 will load the nodes directly by writing to the appropriate Output MacroCell register that resides the band of 256 registers of *csiop*.

It may seem odd to divide the design entry this way (some point-and-click entry and some direct ABLE file editing), but many declaration statements are automatically created in the background by the point-and-click entry. You will see that when it is time to enter ABEL equations for the down-counter, there is very little typing involved.

Click "Done". Now you will see the main PSDsoft flow diagram that will guide you through the remaining steps. You can see a summary report at this time by pulling down the "Report" selection in the main menu bar at the top of the screen, then select "Design Assistant Summary". Your report will match the one in Appendix A.

#### Edit ABEL HDL Statements for PLD Design

If your PSDsoft flow diagram does not include the block "Edit/Add Logic Statements" as shown in Figure 14., then pull down the "Project" selection in the main menu bar at the top of the screen, then select "Preference". Click the box that says "Enable ABEL Editing Capability", then "OK".





Click the "Edit/Add Logic Statements" box. You will see an "HDL Assistant" window pop up. Browse through this to see ABEL logic and syntax examples that you can cut and paste into future designs. Close the HDL Assistant and you will see the ABEL HDL source file. All the declarations and logic equations generated from the Design Assistant are there, and should match Appendix B.

There are only two regions in the ABEL file in which you can type statements, otherwise the DA will overwrite what you have typed next time you get into the DA.

The first safe region is for ABEL declarations and lies between the two statements: "// Begin user preserved declarations" and "// End user preserved declarations".

**A7** 

The second safe region is for logic equations and lies between the two statements: "// Begin user preserved equations" and "// End user preserved equations".

Scroll down to the declaration region in the ABEL file, it should look like:

Notice the WSIPSD PROPERTY statements. These are needed whenever you want to dictate the placement of certain macrocells of the PLD. If you do not enter any WSIPSD PROPERTY declarations statement, then the PSDsoft "fitter" process will place the macrocells in random order. This is not a problem for most designs. But in this example we want to load an initial count for the down-counter from the 8032 data bus so we must make sure the output macrocells holding the initial count are in the correct bit order and the correct position in the bank of eight output macrocells. The property statement:

WSIPSD PROPERTY 'DataBus OMC D[7:4]:down count[3:0] MCELLAB'

forces the order of the bits of the down-counter and places them on the upper half of the 8032 data bus. The property statement:

WSIPSD PROPERTY 'DataBus OMC D[3:0]:init count[3:0] MCELLAB'

forces the order of the bits of the initial count and places them on the lower half of the 8032 data bus. Now when the 8032 writes to the OMCAB register at address csiop+20h, the low four bits of the byte will get loaded into the initial count. There is also a OMCAB mask register at csiop+22h that is used to prevent the 8032 from disturbing the other bits in the OMCAB register while writing.

If the PROPERTY statements above ended with MCELLBC instead of MCELLAB, then the other bank of eight output macrocells would be used for the counter. See the µPSD data sheet and PSDsoft Express User's Guide for more details.

The next declaration statements DCOUNT and INIT create a shorthand notation for use in the logic equations.

Now scroll down in the ABEL file to the logic equations until you see:

#### AN1560

These three statements define the down-counter and the PLD output that appears on pin PB4 (term\_count).

So you can see that very little typing is needed to implement logic designs. The same approach is used to create state machines, shifters, etc.

Close the ABEL file and you will see the PSDsoft flow diagram again.

#### Additional µPSD Configuration

Click the box "Additional PSD Configuration". This is where you can choose to set the security bit to prevent a device programmer from examining or copying the contents of the  $\mu$ PSD. The only way to defeat the security bit is to erase the entire  $\mu$ PSD, then it can be used again as a blank part. You can also click through the other sheets on this screen to set the JTAG USERCODE value and set sector protection on individual  $\mu$ PSD Non-Volatile memory segments. Just click "OK" for now.

#### **C** Code Generation

Clicking on the "Generate C Code" box pops up the message shown in Figure 15., directing you to the ST web site where the example code can be downloaded. Click on the web site link (*http:\\www.st.com\psm-software*) in this window and it will launch the PC's web browser and direct it to the ST web page.

From this web page in the "DK3200 - Software" section, download the "*Example code file (1) - dk32dsn1.zip*" file and unzip it to *C:\PSDexpress\my\_project\dk3200\_dsn\_1*. This is the complete project for this application note and it runs on the DK3200 board. It contains all the Keil source and project files as well as all the PSDsoft Express project files. The PSDsoft Express project files are not used in this case since a new project is being created by following this application note. The Keil source and project files will be used later in this application note.

#### Figure 15. Coded Example Generation



In this screen you can specify a folder in which the ZIPPED project files will be written, along with a readme file with instructions. The selection shown in Figure 15. is the complete project for this application note and it runs on the DK3200 board. It contains all the Keil source and project files as well as all the PSDsoft Express project files. Now close the C Code Generation window.

#### **Fitting Design**

Click the next highlighted box in the design flow, "Fit Design to Silicon". PSDsoft will compile all the configuration selections and present a report (also available in Appendix C). The fitter report documents how pins are configured and how the programmable logic is allocated. It also shows how many programmable logic product terms are used, which is needed to estimate power consumption.



#### Merging 8032 Firmware with µPSD Configuration

Now that all  $\mu$ PSD pins and configuration settings have been defined, PSDsoft Express will create a single object file (\*.obj) that is a composite of the 8032 firmware (\*.hex) and the  $\mu$ PSD configuration. FlashLINK or third party programmer tools can use this object file to program a  $\mu$ PSD device. PSDsoft Express will create *DK3200\_1.obj* for this design example.

During this merging process, PSDsoft Express will input firmware files from the 8032 compiler/linker in S-record or Intel HEX format. It will map the content of these files into the physical memory segments of the  $\mu$ PSD according to the choices that were made in the 'Chip Select Equations' screen. This mapping process translates the absolute system addresses inside 8032 firmware files into physical internal  $\mu$ PSD addresses that are used by a programmer device to program the  $\mu$ PSD. This address translation process is transparent. All you need to do is type (or browse) the file name that was generated from the 8032 linker into the appropriate boxes and PSDsoft Express does the rest. You can specify a single file name for more than one  $\mu$ PSD chip-select, or a different file name for each  $\mu$ PSD chip-select. It depends on how the 8032 linker has created the firmware file(s). For each  $\mu$ PSD chip-select in which you have specified a firmware file name, PSDsoft Express will extract firmware from that file only between the specified start and stop addresses, and ignore firmware outside of the start and stop addresses.

Click on 'Merge MCU Firmware' in the main flow diagram. You will see an information window pop up to remind you to be sure you have configured the firmware compiler and linker to support a paged memory mapping scheme. "OK" and you'll see this screen:



#### Figure 16. Firmware Merging Utility

| Memory<br>Select<br>Name | Memory Select Equations                | File<br>Address<br>Start (hex) | File<br>Address<br>Stop (hex) | File Name              |                                   |
|--------------------------|----------------------------------------|--------------------------------|-------------------------------|------------------------|-----------------------------------|
| FSO                      | lpdn & lpgr2 & lpgr1 &<br>lpgr0 & a15; | 8000                           | FFFF                          |                        | Browse                            |
| FS1                      | !pdn & !pgr2 & !pgr1 & pgr0<br>& a15;  | 8000                           | FFFF                          |                        | Browse                            |
| F\$2                     | !pdn & !pgr2 & pgr1 & !pgr0<br>& a15;  | 8000                           | FFFF                          |                        | Browse                            |
| FS3                      | !pdn & !pgr2 & pgr1 & pgr0<br>& a15;   | 8000                           | FFFF                          |                        | Browse                            |
| Intel                    | Record Type<br>Hex Record C Motorola   | S-Record                       | Mapp<br>Direct                | ing Mode<br>O Relative | Concatenate Files<br>File Setting |
| en 2. M                  | erce DSD configuration                 | and MCU                        | INSD firms                    | /378                   |                                   |

In the left column are  $\mu$ PSD memory segment chip-selects (FS0, FS1, etc.). The next column shows the logic equations for selection of each  $\mu$ PSD memory segment. These equations reflect the choices that were made while defining  $\mu$ PSD internal chip-select equations in an earlier step. In the middle of the screen are hexadecimal start and stop addresses that PSDsoft Express has filled in based on the chip-select equations. On the right are fields to enter (browse) the 8032 firmware files.

Select 'Intel Hex Record' for 'Record Type' as shown. Now slide the bar on the right side all the way down to the bottom until you see CSBOOT0. Use the 'Browse' button and select the firmware file for CSBOOT0, \*PSDexpress\my\_project\dk3200\_dsn\_1\dk3200\_1\_c\dk3200\_1\_tex*. This is a small example program that exercises the PWM and ADC channels of the µPSD on the DK3200 board, and this code fits completely within the 8K byte Flash memory segment CSBOOT0. The screen should look like this:



Figure 17. Merging the Example Firmware

| CSB00T0         Ipdn & Ia15 & Ia14 & Ia13;         O         IFFF         C:\PSDexpress\my_proje         Browse           CSB00T1         Ipdn & Ia15 & Ia14 & Ia13;         Q000         3FFF         Image: Complexity of the image: Complex                                                                           | Memory<br>Select<br>Name | Memory Select Equations              | File<br>Address<br>Start (bev) | File<br>Address<br>Stop (bey) | File Name             |              |                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--------------------------------------|--------------------------------|-------------------------------|-----------------------|--------------|----------------------------|
| CSB00T1         Ipdn & Ia15 & Ia14 & a13;         2000         3FFF         Image: CSB00T2         Ipdn & Ia15 & a14 & Ia13;         4000         5FFF         Image: CSB00T3         Ipdn & Ia15 & a14 & a13;         6000         7FFF         Image: CSB00T3         Image: CSB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | CSBOOTO                  | !pdn & !a15 & !a14 & !a13;           |                                | 1FFF                          | C:\PSDexpress\m       | y_proje      | Browse                     |
| CSB00T2         Ipdn & Ia15 & a14 & Ia13;         Id000         5FFF         Image: Second | CSBOOT1                  | lpdn & la15 & la14 & a13;            | 2000                           | 3FFF                          | [                     |              | Browse                     |
| CSB00T3         Ipdn & Ia15 & a14 & a13;         6000         7FFF         Browse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | CSBOOT2                  | lpdn & la15 & a14 & la13;            | 4000                           | 5FFF                          |                       |              | Browse                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | CSB00T3                  | !pdn & !a15 & a14 & a13;             | 6000                           | 7FFF                          | <u></u>               |              | Browse                     |
| Record Type     Mapping Mode     Concatenate Files       Intel Hex Record     Motorola S-Record     Direct     Relative     File Setting                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Intel H                  | Record Type<br>lex Record C Motorola | S-Record                       | Mappi                         | ng Mode<br>C Relative | Conc<br>File | atenate Files<br>e Setting |

This specification places firmware in secondary PSD Flash memory segment csboot0. PSDsoft Express will extract any firmware that lies inside the file *DK3200\_1.hex* between MCU addresses 0000 and 1FFF and place it in PSD memory segment csboot0. Click OK to generate the composite object file, *DK3200\_1.obj*.

### JTAG Programming

Now click the "STMicroelectronics JTAG/ISP" box to program the µPSD. You'll be asked how many JTAG devices are on the target circuit board, choose "Only One". You'll see the screen shown in Figure 18..

| Figure 18. Programming with FlashLINK JTAG Cable |  |
|--------------------------------------------------|--|
|--------------------------------------------------|--|

| 1                                                                                                | project/dk3200_dsn_1/dk3                                                            | 3200_1.obj                                                 | Browse                           | uPSD        | 3234A 🗾         |
|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------|-------------|-----------------|
| Step 2: Specify J                                                                                | TAG-ISP operation a                                                                 | and condition                                              | s                                |             |                 |
| Select operation:                                                                                | Select region:                                                                      | Select # of JT/                                            | AG pins to use on circu          | it board:   | Other condition |
| Program/Verify 💌                                                                                 | All                                                                                 | 6 pins - tdi,tdo                                           | .tck.tms.tstatterr               | -           | Properties      |
| Select package:                                                                                  |                                                                                     |                                                            |                                  |             | 2               |
| U (80-Pin TQFP) 🔫                                                                                |                                                                                     | Click here to perf                                         | orm specified JTAG-IS            | P operation | >> Execute      |
| Step 3: Save or r<br>Specify folder and filen                                                    | etrieve JIAG-ISP se<br>ame to save the setup of the                                 | <b>:tup</b><br>his JTAG-ISP sess                           | ion or retrieve a previo         | us session. | Save            |
| Step 3: Save or r<br>Specify folder and filen<br>Select folder and file:                         | etrieve JIAG-ISP se<br>ame to save the setup of th                                  | : <b>tup</b><br>his JTAG-ISP sess                          | ion or retrieve a previo         | us session. | Save<br>Browse  |
| Step 3: Save or r<br>Specify folder and filen<br>Select folder and file:<br>Log Mode - Click box | etrieve JIAG-ISP se<br>ame to save the setup of th<br>to record session information | s <b>tup</b><br>his JTAG-ISP sess<br>on in the log file *. | ion or retrieve a previo<br>plg. | us session. | Save<br>Browse  |
| Step 3: Save or r<br>Specify folder and filen<br>Select folder and file:<br>Log Mode - Click box | etrieve JIAG-ISP se<br>ame to save the setup of th<br>to record session infomation  | s <b>tup</b><br>his JTAG-ISP sess<br>on in the log file *. | ion or retrieve a previo<br>plg. | us session. | Save<br>Browse  |

This window enables you to perform JTAG-ISP operations and also offers a loop back test for your FlashLINK cable. If this is your first use, test your FlashLINK cable and PC parallel port by clicking the 'HW Setup' button, then click 'LoopTest' button and follow the directions.

Now let's define our JTAG-ISP environment. For this example project, PSDsoft Express should have filled in the folder and filename of the object file to program, the PSD device, and the JTAG-ISP operation, as shown in the screen above. For this design example, we have chosen to use all six JTAG-ISP pins (instead of four), so the screen should indicates 6-pin JTAG is being used.

To begin programming, connect the JTAG cable to the target system, power-up the target system, and click 'Execute' on the JTAG screen. The Log window at the bottom of the JTAG screen shows the progress. Programming should just take a few seconds, the ISP LED at D5 on the DK3200 will light during programming.

There are optional choices available when the 'Properties.." button is clicked. One choice includes setting the state of all pins on port A, B, C, or D during JTAG-ISP operations (make them inputs or outputs). The default state of these pins is "input", which is fine for this design example. The other choice allows you to specify a USERCODE value to compare before any JTAG-ISP operation starts. This is typically used in a manufacturing environment (see on-screen description for details).

After JTAG-ISP operations are complete, you can save the JTAG setup for this programming session to a file for later use. To do so, click on the 'Save' button. To restore the setup of a different previous session, click the 'Browse..' button.

# WATCH IT RUN ON DK3200

After JTAG programming completes in just a few seconds, you should see a message appear on the LCD:

DK3200 for µPSD

PWM to ADC DEMO

Then you'll see the Hexadecimal value of the ADC conversion sweep up and down between 00h and FFh as the PWM pulse width changes. If you do not see the ADC value change, make sure there are two jumpers installed on the DK3200 board. On JP1, install one jumper across the two opposite rows of pins next to the word "PWM0", and the other jumper across the opposite rows of pins next to the word "ADC0". Remove the jumper next the word "ADC0" and watch the ADC value on the LCD drop to 00h.



# USING UVISION2 AND ISD51 DEBUGGER FROM KEIL SOFTWARE, INC.

This next section will briefly highlight the features of the Keil uVision2 IDE (Integrated Development Environment). Keil's evaluation software was used for this example. This software is supplied on the DK3200 CD and can be installed by double clicking on the installation program found in the Keil subdirectory. In the case of version 7.20, the installation program is named *EK51V720.exe*. Please refer to Keil documentation for more details.

#### Loading a Keil uVision2 Project

The file *dk32dsn1.zip* is available from the ST web site (*http:www.st.com/psm-software*). It contains all the source and project files needed to build this design in Keil's uVision2. Once downloaded save the file on your hard drive and unzip it to the folder of your choice. The ZIP file contains two folders, DK3200\_1\_c and DK3200\_1\_p. DK3200\_1\_c has all the Keil files, DK3200\_1\_p has the PSDsoft Express project files for this application note.

Copy the folder DK3200\_1\_c and all of its contents to your Keil folders as follows, ... Keil C51 DK3200\_1\_c. Invoke Keil uVision2, pull down the "Project" menu, then select "Open Project". Now open the uVision2 project that you just got from the ZIP file at ..\keil\c51\DK3200\_1\_C\DK3200\_1.uv2. Everything should be ready to go.

#### Building the Project and Programming the µPSD

You can build the project for this application note which will create a new Intel HEX-80 file, *DK3200\_1.hex*. Invoke PSDsoft Express and open the project *DK3200\_1*, go to the "Merge MCU Firmware" section, select this new HEX file at \*keil\c51\DK3200\_1\_C\DK3200\_1.hex* for the Flash memory segment *csboot0* and merge, then program the DK3200 board with FlashLINK cable just as before. The LCD should display the PWM/ADC demo information.

#### Running the Keil ISD51 UART Debugger

This simple demo program has the ISD51 UART debugger linked into the code. This is a new debug tool from Keil that only consumes 700 bytes of code space and is royalty-free so it can stay in your end product all the time. Unlike the older UART debugger, MON51, this debugger does not require you to debug code in small sections at a time from xdata SRAM. And unlike MON51, this debugger does not require you to combine your code and data space (tie \_PSEN and \_RD together). See Keil documentation for details.

This project, *DK3200\_1.Uv2* has ISD51 already selected for the debugger tool, connected through PC serial COM1 port at 19.2 kbaud with no hardware handshaking. It also assumes there is a 40MHz crystal on the DK3200 board. Connect a DB-9 (nine-pin) male-female straight-through (pins 2 and 3 are not swapped) serial cable to COM1 port1 on your PC and to the UART0 (P1) connector on the DK3200 board.

Click the Debug icon shown in Figure 19., the debugger will start and it will compare contents of the Flash memory in the  $\mu$ PSD Flash memory with the source files, then program execution will begin running to the C source line until just after the function, ISD\_check(), then it will stop and wait for your debug command. The screen should look like Figure 20..

#### Figure 19. Debug icon



**Á7/** 



Figure 20. Keil ISD51 Just After it is Successfully Invoked

Now you can set breakpoints, single-step, view 8032 internal registers and SFRs, view blocks of memory, etc. For example, in the memory window in the lower-right corner of the IDE screen, the byte of memory at Hexadecimal address 96h is the SFR named "ADAT", which is the resulting 8-bit value from the ADC channel from the last voltage conversion before the 8032 stopped. The value at address 96h is BFh in Figure 20.. If you set a breakpoint on the function uPSD\_ADC\_Read(0), then run the program, you will see the data byte at address 96h change value in the memory watch window, and that same data byte will be showing on the LCD. Each time to run until the breakpoint, you should see a new value appearing in the memory watch window at address 96h and the same value on the LCD. Click the debug icon again to exit the debugger ISD51.

# CONCLUSION

Congratulations! You have seen the majority of steps to implement a  $\mu$ PSD design on the DK3200 board. Now you have a basis to understand more detail as you read the  $\mu$ PSD data sheet and the documentation from Keil Software Inc.



#### APPENDIX A. PSDSOFT EXPRESS PROJECT SUMMARY FILE, DK3200\_1.SUM

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

PSDsoft Express Version 8.30 Summary of Design Assistant PROJECT : DK3200\_1 DATE : 09/28/2004 DEVICE : uPSD3234A TIME : 16:35:05 MCU/DSP : uPSD32XX

Initial setting for Program and Data Space:

------

Main PSD flash memory will reside in this space at power-up: Data Space Only Secondary PSD flash memory will reside in this space at power-up: Program Space Only

Pin Definitions:

| Pin      | Signal     | Pin                              |
|----------|------------|----------------------------------|
| Name     | Name       | Туре                             |
|          |            |                                  |
| pa7      |            | Peripheral 1/0 mode              |
| pa6      | TCD_qe     | Peripheral 1/0 mode              |
| pas      |            | Peripheral 1/0 mode              |
| pa4      | LCD_d4     | Peripheral 1/0 mode              |
| pa3      | LCD_d3     | Peripheral I/O mode              |
| pa2      | LCD_d2     | Peripheral I/O mode              |
| pal      | LCD_d1     | Peripheral I/O mode              |
| pa0      | LCD_d0     | Peripheral I/O mode              |
| pb7      | LCD_e      | External chip select - Active Hi |
| pb6      | LCD_rw     | Combinatorial                    |
| pb5      | LCD_rs     | Combinatorial                    |
| pb4      | term_count | Combinatorial                    |
| pb3      | a15_x      | Combinatorial                    |
| pb2      | al4_x      | Combinatorial                    |
| pb1      | a13 x      | Combinatorial                    |
| pb0      | a12 x      | Combinatorial                    |
| tdo      | tdo        | Dedicated JTAG - TDO             |
| tdi      | tdi        | Dedicated JTAG - TDI             |
| pc4      | terr       | Dedicated JTAG - /TERR           |
| pc3      | _<br>tstat | Dedicated JTAG - TSTAT           |
| pc2      | vstby      | SRAM standby voltage input       |
| tck      | tck        | Dedicated JTAG - TCK             |
| tms      | tms        | Dedicated JTAG - TMS             |
| ale      | ale        | ALE output                       |
| p4.7     | PWM4       | GP I/O mode                      |
| p4.3     | PWMO       | PWM0 Output                      |
| r<br>3.1 | USART1 Txd | UART1 TXD                        |
| p3.0     | USART1 Rxd | UART1 RxD                        |
| p1.4     | ADC Ch0    | ADC channel0 input               |
| a11      | a11        | Address line                     |
| a10      | a10        | Address line                     |
| a9       | a9         | Address line                     |
| a8       | <br>a8     | Address line                     |
| ad7      | a7         | Data/Address line                |
| ad6      | af         | Data/Address line                |
| ad5      | a5         | Data/Address line                |
| ad4      | a4         | Data/Address line                |
| LULI     | u1         | DAGA HAATCOD TITE                |

```
ad3
                                    a3
                                                                                                             Data/Address line
 ad2
                                     a2
                                                                                                             Data/Address line
 ad1
                                                                                                             Data/Address line
                                    a1
 ad0
                                    a0
                                                                                                             Data/Address line
                                                                                                             Reset In
  Reset In
                                    Reset In
                                                                                                             VREF input
 Vref
                                    VREF
                                                                                                            Bus control output
 rd
                                     wr
                                    _psen
                                                                                                            Bus control output
 _psen
  wr
                                      rd
                                                                                                             Bus control output
                                    USB_minus
 USB-
                                                                                                            USB- bus
 USB+
                                    USB plus
                                                                                                            USB+ bus
                                                                                                             Xtal1
 Xtal1
                                    Xtal1
 Xtal2
                                    Xtal2
                                                                                                             Xtal2
 User defined nodes:
 _____
 Node
                                    Node
Name
                                    Туре
  down_count0 D-type register
 down_count1 D-type register
down_count2 D-type register
 down count3 D-type register
 init count0 D-type register
 init_count1 D-type register
 init count2 D-type register
 init count3 D-type register
 Page Register settings:
 _____
pgr0 is used for paging
pgr1 is used for paging
pqr2 is used for paging
pqr3 is not used
pgr4 is not used
pgr5 is not used
pgr6 is not used
pgr7 is not used
 Equations:
 _____
rs0 = ((address >= ^h2000) & (address <= ^h3FFF));
 csiop = ((address >= ^h0200) \& (address <= ^h02FF));
csiop = ((address \ge n0200) & (address \le n02FF)); \\fs0 = ((page == 0) & (address \ge h8000) & (address <= hFFFF)); \\fs1 = ((page == 1) & (address \ge h8000) & (address <= hFFFF)); \\fs2 = ((page == 2) & (address \ge h8000) & (address <= hFFFF)); \\fs3 = ((page == 3) & (address \ge h8000) & (address <= hFFFF)); \\fs4 = ((page == 4) & (address \ge h8000) & (address <= hFFFF)); \\fs5 = ((page == 5) & (address \ge h8000) & (address <= hFFFF)); \\fs6 = ((page == 6) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF)); \\fs7 = ((page == 7) & (address \ge h8000) & (address <= hFFFF) & (address <= hFFFF)); \\fs7 = ((page == 7) & (page == 7) &
 csboot0 = ((address >= ^h0000) \& (address <= ^h1FFF));
 csboot1 = ((address >= ^h2000) \& (address <= ^h3FFF));
       csboot2 = ((address >= ^h4000) \& (address <= ^h5FFF)); \\       csboot3 = ((address >= ^h6000) \& (address <= ^h7FFF)); \\            
 psel0 = ((address >= ^h0300) & (address <= ^h03FF) & ( psen));</pre>
```



```
LCD_e = ((address >= ^h0300) & (address <= ^h03FF) & (!_rd))
# ((address >= ^h0300) & (address <= ^h03FF) & (!_wr));
LCD rw = a0;
LCD rw.oe = Vcc;
LCD_rs = a1;
LCD_rs.oe = Vcc;
a15_x = a15;
al5 x.oe = Vcc;
al4 x = al4;
al4_x.oe = Vcc;
a13_x = a13;
a13_x.oe = Vcc;
a12_x = a12;
all x.oe = Vcc;
down_count0.ck = ale;
down_count0.re = !_reset;
down_count0.pr = Gnd;
down count1.ck = ale;
down count1.re = ! reset;
down_count1.pr = Gnd;
down_count2.ck = ale;
down count2.re = ! reset;
down count2.pr = Gnd;
down_count3.ck = ale;
down count3.re = ! reset;
down_count3.pr = Gnd;
init count0.ck = Gnd;
init count0.re = ! reset;
init_count0.pr = Gnd ;
init_count1.ck = Gnd;
init_count1.re = !_reset;
init_count1.pr = Gnd;
init_count2.ck = Gnd;
init_count2.re = !_reset;
init_count2.pr = Gnd;
init count3.ck = Gnd;
init count3.re = ! reset;
init_count3.pr = Gnd;
```

#### APPENDIX B. PSDSOFT EXPRESS ABEL HDL FILE DK3200\_1.ABL

module DK3200 1 LCD d7 PIN 21; "Reserved for Peripheral I/O mode "Reserved for Peripheral I/O mode LCD d6 PIN 22; LCD d5 PIN 24; "Reserved for Peripheral I/O mode LCD d4 PIN 26; "Reserved for Peripheral I/O mode LCD d3 PIN 28; "Reserved for Peripheral I/O mode LCD d2 PIN 32; "Reserved for Peripheral I/O mode LCD d1 PIN 34; "Reserved for Peripheral I/O mode "Reserved for Peripheral I/O mode LCD d0 PIN 35; LCD e PIN 66; LCD rw PIN 67; LCD rs PIN 72; term count PIN 73; a15 x PIN 74; al4 x PIN 76; a13 x PIN 78; a12 x PIN 80; tdo PIN 6; "TDO tdi PIN 7; "TDI terr PIN 9; "/TERR tstat PIN 14; "TSTAT vstby PIN 15; "SRAM standby voltage input tck PIN 16; "TCK tms PIN 20; "TMS ale PIN 4; "ALE output PWM4 PIN 18; "GP I/O PWMO PIN 27; "PWMO Output USART1 Txd PIN 77; "UART1 TxD USARTI Rxd PIN 75; "UARTI RxD ADC Ch0 PIN 59; "ADC channel0 input all PIN 57; "Address line al0 PIN 55; "Address line a9 PIN 53; "Address line a8 PIN 51; "Address line a7 PIN 47; "Data/address bus line a6 PIN 45; "Data/address bus line a5 PIN 43; "Data/address bus line a4 PIN 41; "Data/address bus line a3 PIN 39; "Data/address bus line a2 PIN 38; "Data/address bus line a1 PIN 37; "Data/address bus line a0 PIN 36; "Data/address bus line Reset In PIN 68; VREF PIN 70; "VREF input wr PIN 65; \_psen PIN 63; rd PIN 62; USB minus PIN 8; "USB- bus USB\_plus PIN 10; "USB+ bus Xtall PIN 48; "Xtal1 Xtal2 PIN 49; "Xtal2 psel0 node; rs0 node; csiop node; fs0 node; fs1 node; fs2 node; fs3 node;

fs4 node; fs5 node; fs6 node; fs7 node; csboot0 node; csboot1 node; csboot2 node; csboot3 node; reset node 543; a12 node 512; a13 node 513; a14 node 514; a15 node 515; pgr2..pgr0 node; down\_count0 NODE istype 'reg\_D'; down count1 NODE istype 'reg D'; down count2 NODE istype 'reg D'; down count3 NODE istype 'reg D'; init count0 NODE istype 'reg D'; init\_count1 NODE istype 'reg\_D'; init\_count2 NODE istype 'reg\_D'; init count3 NODE istype 'reg D'; jtagsel node; X = .x.;address = [a15..a0];page = [pgr2..pgr0];

WSIPSD PROPERTY 'DataBus\_OMC D[7:4]:down\_count[3:0] MCELLAB'; // This statement forces the alignment

[7..4].

Vcc = 1;Gnd = 0;

// If this WSIPSD PROPERTY statement was not present, then PSDsoft
// would pick random MCU bit positions. The WSIPSD PROPERTY is needed
// only if the MCU will read or write to MicroCells and only if a
// particular MCU data bus position is required by the designer.

// of down count bits [3..0] to the MCU data bus bit positions

WSIPSD PROPERTY 'DataBus\_OMC D[3:0]:init\_count[3:0] MCELLAB'; // This statement forces the alignment

// of init\_count bits [3..0] to the MCU data bus bit positions [3..0].

DCOUNT = [down\_count3..down\_count0]; // 4-bit down counter INIT = [init\_count3..init\_count0];// 4-bit initial count from MCU //INIT = [0,1,0,0];

equations



```
jtagsel = ! reset;
rs0 = ((address >= ^h2000) & (address <= ^h3FFF));
csiop = ((address >= ^h0200) & (address <= ^h02FF));
      fs0 = ((page == 0) \& (address >= ^h8000) \& (address <= ^hFFFF)); \\       fs1 = ((page == 1) \& (address >= ^h8000) \& (address <= ^hFFFF)); \\       fs2 = ((page == 2) \& (address >= ^h8000) \& (address <= ^hFFFF)); \\       
fs3 = ((page == 3) & (address >= ^h8000) & (address <= ^hFFFF));
fs4 = ((page == 4) \& (address >= ^h8000) \& (address <= ^hFFFF));
fs5 = ((page == 5) & (address >= ^h8000) & (address <= ^hFFFF));
fs6 = ((page == 6) & (address >= ^h8000) & (address <= ^hFFFF));
fs7 = ((page == 7) & (address >= ^h8000) & (address <= ^hFFFF));
csboot0 = ((address >= ^h0000) & (address <= ^h1FFF));
csboot1 = ((address >= ^h2000) & (address <= ^h3FFF));
csboot2 = ((address >= ^h4000) & (address <= ^h5FFF));
csboot3 = ((address >= ^h6000) & (address <= ^h7FFF));
psel0 = ((address >= ^h0300) & (address <= ^h03FF) & (_psen));
LCD_e = ((address >= ^h0300) & (address <= ^h03FF) & (!_rd))</pre>
      # ((address >= ^h0300) & (address <= ^h03FF) & (! wr));
LCD rw = a0;
LCD rw.oe = Vcc;
LCD rs = a1;
LCD_rs.oe = Vcc;
a15 x = a15;
al5 x.oe = Vcc;
al4 x = al4;
al4 x.oe = Vcc;
a13^{-}x = a13;
al3 x.oe = Vcc;
a12 x = a12;
all x.oe = Vcc;
down count0.ck = ale;
down count0.re = ! reset;
down_count0.pr = Gnd;
down count1.ck = ale;
down count1.re = ! reset;
down count1.pr = Gnd;
down count2.ck = ale;
down count2.re = ! reset;
down_count2.pr = Gnd;
down count3.ck = ale;
down count3.re = ! reset;
down count3.pr = Gnd;
init count0.ck = Gnd;
init count0.re = !_reset;
init count0.pr = Gnd ;
init count1.ck = Gnd;
init count1.re = ! reset;
init_count1.pr = Gnd;
init_count2.ck = Gnd;
init_count2.re = !_reset;
init count2.pr = Gnd;
init count3.ck = Gnd;
init count3.re = ! reset;
init count3.pr = Gnd;
```

// Begin user preserved equations (not affected by iterations of DA usage)
\_\_\_\_\_\_

// End user preserved equations (not affected by iterations of DA usage)
\_\_\_\_\_\_

end DK3200\_1



#### APPENDIX C. PSDSOFT EXPRESS FITTER REPORT DK3200 1.FRP \*\* PSDsoft Express Version 8.30 Output of PSD Fitter \*\* PROJECT : DK3200 1 DATE : 09/28/2004 DEVICE : uPSD3234A TIME : 16:33:47 FIT OPTION : Keep Current DESCRIPTION: Example design for uPSD3234A in Application Note AN1560. Simple memory map with 32K secondary flash in code space, and 256K main flash paged in data space. Down-Counter built in PLD. Runs on DK3200 board. \*\* ==== Pin Layout for U (80-Pin TQFP) Package Type ==== -----|1 ] pd2 adio4 [41 | Address Bus a4/Data Port d4, ad4 2] p3\_3 p3\_5 [42| 3] pd1 adio5 [43 | Address Bus a5/Data Port d5, ad5 ale |4 ] pd0 p3\_6 [44 adio6 [45 Address Bus 5] pc7 a6/Data Port d6, ad6 tdo, TDO 6 ] pc6/TDO p3 7 [46] tdi, TDI 7 ] pc5/TDI adio7 [47 | Address Bus a7/Data Port d7, ad7 USB\_minus |8 ] USBm \_terr, TERR |9 ] pc4/TERR USB\_plus |10] USBp Xtal1 [48| Xtal1 Xtal2 [49 VCC [50 Xtal2 |11] N/C adio8 [51 Address Bus a8, a8 |12] VCC p1\_0 [52] |13] GND adio9 [53 | Address Bus a9, a9 tstat, TSTAT |14] pc3/TSTAT pl 1 [54] vstby [15] pc2 adio10 [55] Address Bus a10, a10 tck, TCK |16] pc1/TCK p1\_2 [56| |17] N/C adio11 [57| Address Bus all, all PWM4 |18] p4\_7 p1\_3 [58 19] p4\_6 p1\_4 [59 ADC Ch0 p1\_5 [60 tms, TMS 20] pc0/TMS p1\_6 [61 LCD d7 , Peripheral I/O Mode 21] pa7 22] pa6 cntl0 [62 LCD d6 , Peripheral I/O Mode \_rd cntl2 [63 23] p4\_5 \_psen LCD d5 , Peripheral I/O Mode 24] pa5 p1 7 [64 25] p4 4 cntl1 [65 wr LCD e LCD d4 , Peripheral I/O Mode |26] pa4 pb7 [66 pb6 [67 27] p4\_3 LCD rw PWM0 LCD d3 , Peripheral I/O Mode Reset In [68 28] pa3 Reset In 29] GND GND [69 Vref [70 30] p4\_2 VREF N/C [71 31] p4 1 pb5 [72] LCD d2 , Peripheral I/O Mode 32] pa2 LCD rs 33] p4 0 pb4 [73] term count LCD d1 , Peripheral I/O Mode [34] pal pb3 [74| a15 x

**۲/** 

p3\_0 [75| USART1\_Rxd pb2 [76| a14\_x p3\_1 [77| USART1\_Txd LCD\_d0 ,Peripheral I/O Mode 35] pa0 36] adio0 ad0, Address Bus a0/Data Port d0 |37] adio1 ad1, Address Bus a1/Data Port d1 ad2, Address Bus a2/Data Port d2 38] adio2 pb1 [78 a13 x p3\_2 [79 39] adio3 ad3, Address Bus a3/Data Port d3 40] p3 4 pb0 [80| a12 x \_\_\_\_\_ ==== Global Configuration ==== Data Bus : 8-Bit Address/Data Mode : Multiplexed ALE/AS Signal : Active High Control Signals : /WR, /RD, /PSEN : Data space Main PSD flash memory will reside in this space at power-up Secondary PSD flash memory will reside in this space at power-up : Program space Enable Chip-Select Input (/CSI) : OFF Standby Voltage Input (PC2) : ON : OFF Standby-on Indicator (PC4) RDY/Busy function (PC3) : OFF Load Micro-Cell on : edge Security Protection : OFF ==== DataBus IMC access information ==== CSIOP Address Offset Register Name Location Siqnals \_\_\_\_\_ ===== Resource Usage Summary ===== Total Product Terms Used: 72 Device Resources used / total -----Port A: (pins 35 34 32 28 26 24 22 21) I/O Pins : 8 / 8 GP I/O or Address Out : 0 Peripheral I/O 8 : Logic Inputs : 0 PT Dependent Latch Inputs : PT Dependent Provident PT Dependent Provident 0 0 PT Dependent Register Inputs : 0 Combinatorial Outputs : 0 Registered Outputs 0 : Other Information Microcells : 8 / 8 Micro-Cells AB : Buried Microcells 8 : Output Microcells : 0 15 / 24 Product Terms : 24 / 34 Control Product Terms : Port B: (pins 80 78 76 74 73 72 67 66) GP I/O or Address Out : 0 Logic Inputs : 0 Address Later -I/O Pins : / 8 8 Address Latch Inputs : 0 PT Dependent Latch Inputs : 0

**۲/** 

### AN1560

| PT Dependent Register Inputs    | :   | 0 |    |    |
|---------------------------------|-----|---|----|----|
| Combinatorial Outputs           | :   | 8 |    |    |
| Registered Outputs              | :   | 0 |    |    |
| Other Information               |     |   |    |    |
| Microcells                      | :   | 8 | /  | 8  |
| Micro-Cells AB :                |     |   |    |    |
| Buried Microcells               | :   | 0 |    |    |
| Output Microcells               | :   | 0 |    |    |
| Micro-Cells BC :                |     |   |    |    |
| Buried Microcells               | •   | 0 |    |    |
| Output Microcells               |     | 8 |    |    |
| Product Terms                   |     | 9 | /  | 32 |
| Control Product Terms           | :   | g | ', | 34 |
| Concros Froduce Terms           | •   | 0 | /  | 54 |
| Port C: (pins 20 16 15 14 9 7 6 | 5)  |   |    |    |
| I/O Pins :                      | - / | 7 | /  | 8  |
| GP I/O or Address Out           | :   | 0 | ,  |    |
| Logic Inputs                    |     | 0 |    |    |
| Address Latch Inputs            |     | 0 |    |    |
| PT Dependent Latch Inputs       | :   | 0 |    |    |
| PT Dependent Pegister Inputs    | •   | 0 |    |    |
| TTAC gionald                    |     | 6 |    |    |
| Ctandby Voltago Input           | :   | 1 |    |    |
| Relation and an all             | :   | Ţ |    |    |
| Rdy/Bsy signal                  | :   | 0 |    |    |
| Standby On Indicator            | :   | 0 |    |    |
| Combinatorial Outputs           | :   | 0 |    |    |
| Registered Outputs              | :   | 0 |    |    |
| Other Information               |     |   |    |    |
| Microcells                      | :   | 8 | /  | 8  |
| Micro-Cells BC :                |     |   |    |    |
| Buried Microcells               | :   | 8 |    |    |
| Output Microcells               | :   | 0 |    |    |
| Product Terms                   | :   | 9 | /  | 32 |
| Control Product Terms           | :   | 0 | /  | 34 |
|                                 |     |   |    |    |
| Port D: (pins 4 3 1)            |     |   |    |    |
| I/O Pins :                      |     | 1 | /  | 3  |
| GP I/O or Address Out           | :   | 0 |    |    |
| Logic Inputs                    | :   | 0 |    |    |
| Chip-Select Input               | :   | 0 |    |    |
| Clock Input                     | :   | 0 |    |    |
| Control Signal Input            | :   | 1 |    |    |
| Fast Decoding Outputs           | :   | 0 |    |    |
| Other Information               |     |   |    |    |
| Product Terms                   | :   | 0 | /  | 3  |
| Control Product Terms           | :   | 0 |    | 3  |
|                                 | -   | - | '  | -  |

#### ==== OMC Resource Assignment ====

| Resources<br>Used |   | PT<br>Allocation | User<br>Name |             |
|-------------------|---|------------------|--------------|-------------|
| Micro-Cell AB     | : |                  |              |             |
| Micro-Cells       | 0 | -                | init count0  | => Register |
| Micro-Cells       | 1 | -                | init count1  | => Register |
| Micro-Cells       | 2 | -                | init count2  | => Register |
| Micro-Cells       | 3 | -                | init_count3  | => Register |
| Micro-Cells       | 4 | -                | down_count0  | => Register |



```
Micro-Cells 5
                                    down count1 => Register
 Micro-Cells 6
                                    down count2 => Register
                      _
 Micro-Cells 7
                                    down count3 => Register
Micro-Cell BC :
 Micro-Cells 0
                                    a12 x (mcellbc0) => Combinatorial
                                   a13_x (mcellbc1) => Combinatorial
 Micro-Cells 1
                      -
                                   a14 x (mcellbc2) => Combinatorial
 Micro-Cells 2
                      _
 Micro-Cells 3
                      _
                                   a15 x (mcellbc3) => Combinatorial
 Micro-Cells 4
                                   term count (mcellbc4) => Combinatorial
                      _
 Micro-Cells 5
                                   LCD_rs (mcellbc5) => Combinatorial
                      -
 Micro-Cells 6
                      -
                                   LCD_rw (mcellbc6) => Combinatorial
 Micro-Cells 7
                                   LCD e (mcellbc7) => Combinatorial
External Chip Select :
     ====== Equations =======
DPLD
             EQUATIONS :
_____
    fs0 = !pdn & !pgr2 & !pgr1 & !pgr0 & a15;
     fs1 = !pdn & !pgr2 & !pgr1 & pgr0 & a15;
     fs2 = !pdn & !pgr2 & pgr1 & !pgr0 & a15;
     fs3 = !pdn & !pgr2 & pgr1 & pgr0 & a15;
     fs4 = !pdn & pgr2 & !pgr1 & !pgr0 & a15;
     fs5 = !pdn & pgr2 & !pgr1 & pgr0 & a15;
     fs6 = !pdn & pgr2 & pgr1 & !pgr0 & a15;
     fs7 = !pdn & pgr2 & pgr1 & pgr0 & a15;
     csboot0 = !pdn & !a15 & !a14 & !a13;
     csboot1 = !pdn & !a15 & !a14 & a13;
     csboot2 = !pdn & !a15 & a14 & !a13;
     csboot3 = !pdn & !a15 & a14 & a13;
     csiop = !pdn & !a15 & !a14 & !a13 & !a12 & !a11 & !a10 & a9 & !a8;
     rs0 = !pdn & !a15 & !a14 & a13;
    psel0 = !pdn & psen & !a15 & !a14 & !a13 & !a12 & !a11 & !a10 & a9 & a8;
     jtagsel = ! reset;
PORTA
             EOUATIONS :
_____
     init count0.D := 0;
     init count0.PR = 0;
     init_count0.RE = !_reset;
     init_count0.C = 0;
```

```
init_count1.D := 0;
     init_count1.PR = 0;
     init count1.RE = ! reset;
     init count1.C = 0;
     init count2.D := 0;
     init count2.PR = 0;
     init count2.RE = ! reset;
     init count2.C = 0;
     init count3.D := 0;
     init_count3.PR = 0;
     init count3.RE = ! reset;
     init count3.C = 0;
     down count0.D := (!down count0.Q & !term count.PIN)
          # (init count0 & term count.PIN);
     down count 0.PR = 0;
     down count0.RE = ! reset;
     down_count0.C = ale;
     down count1.D := (down count1.Q & down count0.Q & !term count.PIN)
          # (!down count1.Q & !down count0.Q & !term count.PIN)
          # (init count1 & term_count.PIN);
     down count1.PR = 0;
     down count1.RE = ! reset;
     down count1.C = ale;
     down count2.T := (!down count1.Q & !down count0.Q & !term count.PIN)
          # (!down_count2.Q & init_count2 & term_count.PIN)
          # (down_count2.Q & !init_count2 & term_count.PIN);
     down count2.PR = 0;
     down_count2.RE = ! reset;
     down_count2.C = ale;
     down count3.T := (!down count3.Q & init count3 & term count.PIN)
          # (down_count3.Q & !init_count3 & term_count.PIN)
          # (!down_count2.Q & !down_count1.Q & !down_count0.Q & !term_count.PIN);
     down count3.PR = 0;
     down count3.RE = ! reset;
     down count3.C = ale;
PORTB
             EOUATIONS :
_____
    a12 x = a12;
     a12 x.OE = 1;
    a13_x = a13;
    a13_x.OE = 1;
     al4 x = al4;
    al4 x.OE = 1;
     a15 x = a15;
     a15 x.OE = 1;
     term count = !down count3.Q & !down count2.Q & !down count1.Q & !down count0.Q;
     term count.OE = 1;
```

--- End ---



# APPENDIX D. DK3200 BOARD LAYOUT

# Figure 21. DK3200 BOARD LAYOUT



# **APPENDIX E. DK3200 SCHEMATICS**

# Figure 22. DK3200 SCHEMATICS (1)



# AN1560

Figure 23. DK3200 SCHEMATICS (2)



Figure 24. DK3200 SCHEMATICS (3)



# AN1560





Figure 26. DK3200 SCHEMATICS (5)



# **REVISION HISTORY**

# Table 1. Document Revision History

| Date        | Rev. | Description of Revision                                                                                                                                                                                                                                                                                                                                     |  |  |
|-------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 29-Jul-2002 | 1.0  | Document written                                                                                                                                                                                                                                                                                                                                            |  |  |
| 26-Aug-2002 | 1.1  | Document updated: DK3200 replaces DK3000 development tool, Figures 1, 2, 3, 5, 16, 19, 20, 23 and 24 modified, Screen captures enlarged, Figure 15 (in previous document) removed together with related paragraph. Figure numbering shifted by 1 from Figure 15 on. Details added to paging bit description.                                                |  |  |
| 14-Feb-2005 | 2.0  | Various file names updated in the document,<br>8032 SFRs and idata SRAM removed from Figure 4.<br>C Code Generation section modified, Figure 15. replaced. Figures 17 and 18 modified. P<br>Family modified in Figure 5. DK3200 REV. number changed to 0.1 in Figure 21.<br>Code listings in Appendices A, B and C updated to PSDsoft Express Version 8.30. |  |  |



Information furnished is believed to be accurate and reliable. However, STMicroelectronics assumes no responsibility for the consequences of use of such information nor for any infringement of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of STMicroelectronics. Specifications mentioned in this publication are subject to change without notice. This publication supersedes and replaces all information previously supplied. STMicroelectronics products are not authorized for use as critical components in life support devices or systems without express written approval of STMicroelectronics.

The ST logo is a registered trademark of STMicroelectronics. All other names are the property of their respective owners

© 2005 STMicroelectronics - All rights reserved

STMicroelectronics group of companies

Australia - Belgium - Brazil - Canada - China - Czech Republic - Finland - France - Germany - Hong Kong - India - Israel - Italy - Japan -Malaysia - Malta - Morocco - Singapore - Spain - Sweden - Switzerland - United Kingdom - United States of America www.st.com