# Stellaris® LM3S9D96 Development Kit # User's Manual # Copyright Copyright © 2009–2011 Texas Instruments, Inc. All rights reserved. Stellaris and StellarisWare are registered trademarks of Texas Instruments. ARM and Thumb are registered trademarks, and Cortex is a trademark of ARM Limited. Other names and brands may be claimed as the property of others. Texas Instruments 108 Wild Basin, Suite 350 Austin, TX 78746 http://www.ti.com/stellaris # **Table of Contents** | Chapter 1: Overview | | |-----------------------------------------------------------------------|----| | Features | | | Development Kit Contents | | | Block Diagram | | | Development Board Specifications | | | Chapter 2: Hardware Description | | | Microcontroller Overview | | | Jumpers and GPIO Assignments | | | Clocking | | | Reset | | | Power SuppliesUSB | | | Debugging | | | Color QVGA LCD Touch Panel | | | I <sup>2</sup> S Audio | | | User Switch and LED | | | | | | Chapter 3: External Peripheral Interface (EPI) | | | Flash and SRAM Memory Expansion Board | | | FPGA Expansion Board | | | EM2 Expansion Board | | | Chapter 4: Using the In-Circuit Debugger Interface | | | Appendix A: Schematics | | | Appendix B: Component Locations | | | Appendix C: Connection Details | | | DC Power Jack | | | ARM Target Pinout | 35 | | Appendix D: Microcontroller GPIO Assignments | 37 | | Appendix E: Stellaris® LM3S9B96 Flash and SRAM Memory Expansion Board | | | Features | | | Installation | 41 | | Hardware Description | 43 | | Functional Description | 43 | | Memory Map | 45 | | Component Locations | 46 | | Schematics | 46 | | Appendix F: Stellaris® LM3S9B96 FPGA Expansion Board | 51 | | Features | 51 | | Installation | | | Hardware Description | | | FPGA | | | Camera | 54 | | SRAM | 54 | |---------------------------------------------------------|----| | Configuration PROM | 54 | | Configuration Pushbutton | 55 | | Test Port | 55 | | Camera Connector | 55 | | 5 V Power Pin | 55 | | 24-MHz Oscillator | 55 | | External Peripheral Interface (EPI) Module | 55 | | Using the Widget Interface | 55 | | Writing Your Own Stellaris Application | 56 | | Memory Map | 56 | | Register Descriptions | 57 | | Loading a New Image to the FPGA | 63 | | Installing the Software | | | Modifying the Default Image | 64 | | Default FPGA Image Blocks | 64 | | EPI Signal Descriptions | 66 | | Component Locations | 67 | | Schematics | 68 | | Appendix G: Stellaris® LM3S9B96 EM2 Expansion Board | 73 | | Features | 73 | | Installation | 73 | | Installation of EM Modules onto the EM2 Expansion Board | 76 | | Hardware Description | 78 | | Primary EM Header | 78 | | Secondary EM Header | 79 | | CAT24C01 EEPROM | _ | | I <sup>2</sup> S Header | 79 | | Analog Audio Header | 79 | | SDIO Header | 79 | | EPI Signal Descriptions | 79 | | Component Locations | | | Schematics | 81 | | Annendix H: References | 87 | # **List of Figures** | Figure 1-1. | DK-LM3S9D96 Development Board | 9 | |-------------|-------------------------------------------------------------------------------------------|------| | Figure 1-2. | DK-LM3S9D96 Development Board Block Diagram | . 11 | | Figure 2-1. | Factory Default Jumper Settings | . 14 | | Figure 4-1. | ICD Interface Out Mode | . 23 | | Figure B-1. | Component Placement Plot for Top | . 34 | | Figure E-1. | Flash and SRAM Memory Expansion Board | . 41 | | Figure E-2. | Removing EPI Board from DK-LM3S9D96 Development Board | . 42 | | | Flash/SRAM/LCD IF Expansion Board Block Diagram | | | Figure E-4. | Component Placement Plot for Top and Bottom | . 46 | | Figure F-1. | FPGA Expansion Board | . 51 | | Figure F-2. | Removing EPI Board from DK-LM3S9D96 Development Board | . 53 | | Figure F-3. | FPGA Expansion Board Block Diagram | . 54 | | Figure F-4. | FPGA Boundary Scan | . 64 | | Figure F-5. | Component Placement Plot for Top | . 67 | | Figure F-6. | Component Placement Plot for Bottom | . 68 | | Figure G-1. | EM2 Expansion Board | . 73 | | Figure G-2. | Removing EPI Board from DK-LM3S9D96 Development Board | . 74 | | Figure G-3. | EM2 Expansion Board | . 75 | | Figure G-4. | Assembled DK-LM3S9D96 Development Board with EM2 Expansion Board | . 75 | | Figure G-5. | Connecting an EM Module to the EM2 Expansion Board | . 76 | | Figure G-6. | Fully Assembled DK-LM3S9D96 Board with EM2 Expansion Board and Wireless EM Module $\! \!$ | . 77 | | Figure G-7. | EM2 Expansion Board Block Diagram | . 78 | | Figure G-8. | Component Placement Plot for Top and Bottom | . 81 | # **List of Tables** | Table 2-1. | Board Features and Peripherals that are Disconnected in Factory Default Configuration | 13 | |------------|---------------------------------------------------------------------------------------|----| | Table 2-2. | USB-Related Signals | 15 | | Table 2-3. | Hardware Debugging Configurations | 16 | | Table 2-4. | Debug-Related Signals | 17 | | Table 2-5. | LCD-Related Signals | 18 | | Table 2-6. | I <sup>2</sup> S Audio-Related Signals | 19 | | Table 2-7. | Navigation Switch-Related Signals | 19 | | Table C-1. | Debug Interface Pin Assignments | 35 | | Table D-1. | Microcontroller GPIO Assignments | 37 | | Table E-1. | Flash and SRAM Memory Expansion Board Memory Map | 45 | | | LCD Latch Register | | | Table F-1. | FPGA Expansion Board Memory Map | 56 | | Table F-2. | Version Register | 58 | | Table F-3. | System Control Register | 58 | | Table F-4. | Interrupt Enable Register | 59 | | Table F-5. | Interrupt Status Register | 60 | | Table F-6. | Test Pad Register | 61 | | Table F-7. | LCD Control Register | 61 | | Table F-8. | EPI Signal Descriptions | 66 | | Table G-1. | EPI Signal Descriptions | 79 | ## **Overview** The Stellaris® LM3S9D96 Development Board provides a platform for developing systems around the advanced capabilities of the LM3S9D96 ARM® Cortex™-M3-based microcontroller. The LM3S9D96 is a member of the Stellaris Firestorm-class microcontroller family. Firestorm-class devices include capabilities such as 80 MHz clock speeds, an External Peripheral Interface (EPI) and Audio I<sup>2</sup>S interfaces. In addition to new hardware to support these features, the DK-LM3S9D96 board includes a rich set of peripherals found on other Stellaris boards. The development board includes an on-board in-circuit debug interface (ICDI) that supports both JTAG and SWD debugging. A standard ARM 20-pin debug header supports an array of debugging solutions. The Stellaris® LM3S9D96 Development Kit accelerates development of Firestorm-class microcontrollers. The kit also includes extensive example applications and complete source code. ### **Features** The Stellaris® LM3S9D96 Development Board includes the following features. - Simple set-up—USB cable provides debugging, communication, and power - Flexible development platform with a wide range of peripherals - Color LCD graphics display - TFT LCD module with 320 x 240 resolution - Resistive touch interface - 80 MHz LM3S9D96 microcontroller with *512* K Flash, 96 K SRAM, and integrated Ethernet MAC+PHY, USB OTG, and CAN communications - 8 MB SDRAM (plug-in EPI option board) - EPI break-out board (plug-in option board) - 1 MB serial Flash memory - Precision 3.00 V voltage reference - SAFERTOS<sup>™</sup> operating system in microcontroller ROM - I<sup>2</sup>S stereo audio codec - Line In/Out - Headphone Out - Microphone In - Controller Area Network (CAN) Interface - 10/100 BaseT Ethernet - USB On-The-Go (OTG) Connector - Device, Host, and OTG modes - User LED and push button - Thumbwheel potentiometer (can be used for menu navigation) - MicroSD card slot - Supports a range of debugging options - Integrated In-circuit Debug Interface (ICDI) - JTAG, SWD, and SWO all supported - Standard ARM® 20-pin JTAG debug connector - USB Virtual COM Port - Jumper shunts to conveniently reallocate I/O resources - Develop using tools supporting Keil<sup>TM</sup> RealView® Microcontroller Development Kit (MDK-ARM), IAR Embedded Workbench, Sourcery CodeBench development tools, Code Red Technologies development tools, or Texas Instruments' Code Composer Studio<sup>TM</sup> IDE - Supported by StellarisWare® software including the graphics library, the USB library, and the peripheral driver library - Optional expansion boards that work with the External Peripheral Interface (EPI) of the DK-LM3S9D96 development board extend the capabilities of this development platform (each board sold separately) - Stellaris® Flash and SRAM Memory Expansion Board (DK-LM3S9B96-FS8) (sold separately) - Provides Flash memory, SRAM, and an improved performance LCD interface For more information on the DK-LM3S9B96-FS8 memory expansion board, see Appendix E, "Stellaris® LM3S9B96 Flash and SRAM Memory Expansion Board," on page 41. - Stellaris® FPGA Expansion Board (DK-LM3S9B96-FPGA) (sold separately) - Provides machine-to-machine (M2M), high-bandwidth, parallel interface capability of the Stellaris microcontroller - Allows users to control and display the FPGA expansion board's video on the DK-LM3S9D96 development board's large, 3.5" touchscreen display - For more information on the DK-LM3S9B96-FPGA expansion board, see Appendix F, "Stellaris® LM3S9B96 FPGA Expansion Board," on page 51. - Stellaris® EM2 Expansion Board (DK-LM3S9B96-EM2) (sold separately) - Provides a transition between the Stellaris External Peripheral Interface (EPI) connector and the RF Evaluation Module (EM) connector - Enables wireless application development using Low Power RF and RF ID evaluation modules on the Stellaris DK-LM3S9D96 platform - For more information on the DK-LM3S9B96-EM2 expansion board, see Appendix G, "Stellaris® LM3S9B96 EM2 Expansion Board," on page 73. Headphone Output 5 VDC supply input Audio Line Output Microphone Input USB Connector for Audio Line Input Debug and or Power On- board JTAG SWD **CAN Bus Interface** Debug Interface **EPI Expansion Board** USB connector with Reset switch Host, Device and On-the- Go modes JTAG/ SWD In/ Stellaris **Out Connector** LM3S9D96 Microcontroller Power and 10/100 Ethernet **Ground Test Points** User LED E E E E E E E E E E E E E E E Potentiometer User Switch 3.00 V Analog microSD Card Slot Reference 1 MB Serial Flash Memory 3.5 " LCD Touch Panel Figure 1-1. DK-LM3S9D96 Development Board ## **Development Kit Contents** The Stellaris® LM3S9D96 Development Kit contains everything needed to develop and run a range of applications using Stellaris microcontrollers: - DK-LM3S9D96 development board - 8 MB SDRAM expansion board - EPI signal breakout board - Retractable Ethernet cable - USB Mini-B cable for debugger use - USB Micro-B cable for OTG-to-PC connection - USB Micro-A to USB A adapter for USB Host - USB Flash memory stick - microSD Card - 20-position ribbon cable - CD containing: - A supported version of one of the following (including a toolchain-specific Quickstart guide): - Keil™ RealView® Microcontroller Development Kit (MDK-ARM) - IAR Embedded Workbench - Sourcery CodeBench development tools - Code Red Technologies development tools - Texas Instruments' Code Composer Studio™ IDE - Complete documentation - Quickstart application source code - Stellaris® Firmware Development Package with example source code ## **Block Diagram** Figure 1-2. DK-LM3S9D96 Development Board Block Diagram ## **Development Board Specifications** - Board supply voltage: 4.75–5.25 Vdc from one of the following sources: - Debugger (ICDI) USB cable (connected to a PC) - USB Micro-B cable (connected to a PC) - DC power jack (2.1 x 5.5mm from external power supply) - Break-out power output: 3.3 Vdc (100 mA max) - Dimensions (excluding LCD panel): - 4.50" x 4.25" x 0.60" (LxWxH) with SDRAM board - 4.50" x 4.25" x 0.75" (LxWxH) with EPI breakout board - Analog Reference: 3.0 V +/-0.2% - RoHS status: Compliant **NOTE:** When the LM3S9D96 Development Board is used in USB Host mode, the host connector is capable of supplying power to the connected USB device. The available supply current is limited to ~200 mA unless the development board is powered from an external 5 V supply with a =600mA rating. ## **Hardware Description** In addition to an LM3S9D96 microcontroller, the development board includes a range of useful peripheral features and an integrated in-circuit debug interface (ICDI). This chapter describes how these peripherals operate and interface to the microcontroller ### **Microcontroller Overview** The Stellaris LM3S9D96 is an ARM Cortex-M3-based microcontroller with 512-KB flash memory, 80-MHz operation, Ethernet, USB, EPI, SAFE**RTOS**™ in ROM, and a wide range of peripherals. See the *LM3S9D96 Microcontroller Data Sheet* (order number DS-LM3S9D96) for complete microcontroller details. The LM3S9D96 microcontroller is factory-programmed with a quickstart demo program. The quickstart program resides in on-chip flash memory and runs each time power is applied, unless the quickstart has been replaced with a user program. ### **Jumpers and GPIO Assignments** Each peripheral circuit on the development board is interfaced to the LM3S9D96 microcontroller through a 0.1" pitch jumper/shunt. Figure 2-1 on page 14 shows the factory default positions of the jumpers. The jumpers must be in these positions for the quickstart demo program to function correctly. The development board offers capabilities that the LM3S9D96 cannot support simultaneously due to pin count and GPIO multiplexing limitations. For example, as configured, the board does not support SDRAM and I<sup>2</sup>S receive (microphone or line input) functions at the same time. The jumpers associated with I<sup>2</sup>S receive are omitted in the default configuration. Table 2-1 lists all features and peripherals that are disconnected in the factory default configuration. Using these peripherals requires that other peripherals be disconnected. Appendix D, "Microcontroller GPIO Assignments," on page 37 lists alternative jumper configurations used in conjunction with some of the StellarisWare™ example applications for this board. Table 2-1. Board Features and Peripherals that are Disconnected in Factory Default Configuration | Peripheral | Jumpers | |----------------------------------------|------------------| | I <sup>2</sup> S Receive (Audio Input) | JP44, 45, 47, 49 | | Controller Area Network (CAN) | JP14, 15 | | Ethernet Yellow Status LED (LED2) | JP2 | | Analog 3.0V Reference | JP33 | See Appendix D, "Microcontroller GPIO Assignments," on page 37, for a complete list of GPIO assignments. The table lists all default and alternate assignments that are supported by the 0.1" jumpers and PCB routing. The LM3S9D96 has additional internal multiplexing that enables additional configurations which may require discrete wiring between peripherals and GPIO pins. The ICDI section of the board has a GND-GND jumper that serves no function other than to provide a convenient place to 'park' a spare jumper. This jumper may be reused as required. Figure 2-1. Factory Default Jumper Settings ## Clocking The development board uses a 16.0-MHz (Y2) crystal to complete the LM3S9D96 microcontroller's main internal clock circuit. An internal PLL, configured in software, multiples this clock to higher frequencies for core and peripheral timing. A 25.0-MHz (Y1) crystal provides an accurate timebase for the Ethernet PHY. #### Reset The RESETn signal into the LM3S9D96 microcontroller connects to the reset switch (SW2) and to the ICDI circuit for a debugger-controlled reset. External reset is asserted (active low) under any one of the three following conditions: - Power-on reset (filtered by an R-C network) - Reset push switch SW2 held down - By the ICDI circuit (U12 FT2232, U13D 74LVC125A) when instructed by the debugger (this capability is optional, and may not be supported by all debuggers) The LCD module has special Reset timing requirements requiring a dedicated control line from the microcontroller. ### **Power Supplies** The development board requires a regulated 5.0 V power source. Jumpers JP34-36 select the power source, with the default source being the ICDI USB connector. Only one +5 V source should be selected at any time to avoid conflict between the power sources. When using USB in Host mode, the power source should be set to either ICDI or to EXT if a +5 V power supply (not included in the kit) is available. The development board has two main power rails. A +3.3 V supply powers the microcontroller and most other circuitry. +5 V is used by the OTG USB port and In-circuit Debug Interface (ICDI) USB controller. A low drop-out (LDO) regulator (U5) converts the +5 V power rail to +3.3 V. Both rails are routed to test loops for easy access. #### **USB** The LM3S9D96's full-speed USB controller supports On-the-Go, Host, and Device configurations. See Table 2-2 for USB-related signals. The 5-pin microAB OTG connector supports all three interfaces in conjunction with the cables included in the kit. The USB port has additional ESD protection diode arrays (D1, D2,D5) for up to 15 kV of ESD protection. Table 2-2. USB-Related Signals | Microcontroller Pin | Board Function | Jumper Name | |---------------------|------------------------------------------|-------------| | Pin 70 USB0DM | USB Data- | - | | Pin 71 USB0DP | USB Data+ | - | | Pin 73 USB0RBIAS | USB bias resistor | - | | Pin 66 USB0ID | OTG ID signal (input to microcontroller) | OTG ID | | Pin 67 USB0VBUS | Vbus Level monitoring | +VBUS | | Pin 34 USB0EPE | Host power enable (active high) | EPEN | | Pin 35 USB0PFLT | Host power fault signal (active low) | PFLT | U6, a fault-protected switch, controls and monitors power to the USB host port. USB0EPEN, the control signal from the microcontroller, has a pull-down resistor to ensure host-port power remains off during reset. The power switch will immediately cut power if the attached USB device draws more than 1 Amp, or if the switches' thermal limits are exceeded by a device drawing more than 500 mA. USB0PFLT indicates the over-current status back to the microcontroller. The development board can be either a bus-powered USB device or self-powered USB device depending on the power-supply configuration jumpers. When using the development board in USB-host mode, power to the EVB should be supplied by the In-circuit Debugger (ICDI) USB cable or by a +5 V source connected to the DC power jack. Note that the LM3S9D96's USB capabilities are completely independent from the In-Circuit Debug Interface USB functionality. ### **Debugging** Stellaris microcontrollers support programming and debugging using either JTAG or SWD. JTAG uses the TCK, TMS, TDI, and TDO signals. SWD requires fewer signals (SWCLK, SWDIO, and, optionally, SWO for trace). The debugger determines which debug protocol is used. ### **Debugging Modes** The LM3S9D96 development board supports a range of hardware debugging configurations. Table 2-3 summarizes these configurations. **Table 2-3. Hardware Debugging Configurations** | Mode | Debug Function | Use | Selected by | |------|------------------------------|---------------------------------------------------------------------------------------------------|--------------------------------------------------------| | 1 | Internal ICDI | Debug on-board LM3S9D96 microcontroller over Debug USB interface. | Default mode | | 2 | ICDI out to JTAG/ SWD header | The development board is used as a USB to SWD/<br>JTAG interface to an external target. | Remove jumpers on TCk,<br>TMS, TDI, TDO, and PIN1 | | 3 | In from JTAG/SWD header | For users who prefer an external debug interface (ULINK, JLINK, etc.) with the development board. | Connecting an external debugger to the JTAG/SWD header | #### **Debug In Considerations** Debug Mode 3 supports board debugging using an external debug interface such as a Segger J-Link or Keil ULINK. Most debuggers use Pin 1 of the Debug connector to sense the target voltage and, in some cases, power the output logic circuit. Installing the VDD/PIN1 jumper will apply 3.3 V power to this pin in order to support external debuggers. #### **Debug USB Overview** An FT2232 device from Future Technology Devices International Ltd implements USB-to-serial conversion. The FT2232 is factory-configured to implement a JTAG/SWD port (synchronous serial) on channel A and a Virtual COM Port (VCP) on channel B. This feature allows two simultaneous communications links between the host computer and the target device using a single USB cable. Separate Windows drivers for each function are provided on the Documentation and Software CD. The In-Circuit Debug Interface USB capabilities are completely independent from the LM3S9D96's on-chip USB functionality. A small serial EEPROM holds the FT2232 configuration data. The EEPROM is not accessible by the LM3S9D96 microcontroller. For full details on FT2232 operation, go to www.ftdichip.com. #### **USB to JTAG/SWD** The FT2232 USB device performs JTAG/SWD serial operations under the control of the debugger. A simple logic circuit multiplexes SWD and JTAG functions and, when working in SWD mode, provides direction control for the bidirectional data line. #### **Virtual COM Port** The Virtual COM Port (VCP) allows Windows applications (such as HyperTerminal) to communicate with UART0 on the LM3S9D96 over USB. Once the FT2232 VCP driver is installed, Windows assigns a COM port number to the VCP channel. Table 2-4 shows the debug-related signals. Table 2-4. Debug-Related Signals | Microcontroller Pin | Board Function | Jumper Name | |---------------------|-------------------------------------|-------------| | Pin 77 TDO/SWO | JTAG data out or trace data out | TDO | | Pin 78 TDI | JTAG data in | TDI | | Pin 79 TMS/SWDIO | JTAG TMS or SWD data in/out | TMS | | Pin 80 TCK/SWCLK | JTAG Clock or SWD clock | тск | | Pin 26 PA0/U0RX | Virtual Com port data to LM3S9D96 | VCPRX | | Pin 27 PA1/U0TX | Virtual Com port data from LM3S9D96 | VCPTX | | Pin 64 RSTn | System Reset | RSTn | ### Serial Wire Out (SWO) The development board supports the Cortex-M3 Serial-Wire Output (SWO) trace capabilities. Under debugger control, on-board logic can route the SWO datastream to the VCP transmit channel. The debugger software can then decode and interpret the trace information received from the Virtual Com Port. The normal VCP connection to UART0 is interrupted when using SWO. Not all debuggers support SWO. See the *Stellaris LM3S9D96 Microcontroller Data Sheet* for additional information on the Trace Port Interface Unit (TPIU). #### Color QVGA LCD Touch Panel The development board features a TFT Liquid Crystal graphics display with 320 x 240 pixel resolution. The display is protected during shipping by a thin, protective plastic film which should be removed before use. #### **Features** Features of the LCD module include: - Kitronix K350QVG-V1-F display - 320 x RGB x 240 dots - 3.5" 262 K colors - Wide temperature range - White LED backlight - Integrated RAM - Resistive touch panel #### **Control Interface** The Color LCD module has a built-in controller IC with a multi-mode parallel interface. The development board uses an 8-bit 8080 type interface with GPIO Port D providing the data bus. Table 2-4 shows the LCD-related signals. Table 2-5. LCD-Related Signals | Microcontroller Pin | Board Function | Jumper Name | |---------------------|-------------------------|-------------| | PE6/ADC1 | Touch X+ | X+ | | PE3 | Touch Y- | Y- | | PE2 | Touch X- | X- | | PE7/ADC0 | Touch Y+ | Y+ | | PB7 | LCD Reset | LRSTn | | PD07 | LCD Data Bus 07 | LD07 | | PH7 | LCD Data/Control Select | LDC | | PB5 | LCD Read Strobe | LRDn | | PH6 | LCD Write Strobe | LWRn | | - | Backlight control | BLON | #### **Backlight** The white LED backlight must be powered for the display to be clearly visible. U7 (FAN5331B) implements a 20 mA constant-current LED power source to the backlight. The backlight is not normally controlled by the microcontroller, however, the control signal is available on a header. A jumper may be installed to disable the backlight by connecting it to GND. Alternatively, a wire may be used to control this signal from a spare microcontroller GPIO line. Because the FAN5331B operates in a constant current mode, its output voltage will jump up if the LCD should become disconnected. To prevent over-voltage failure of the IC or diode D3, a zener (D4) clamps the voltage. The current will limit to 20 mA, but the total board current will be higher than when the LCD panel is connected. To avoid over-heating the backlighting circuit, install the BLON jumper to completely shut-down the backlighting circuit. #### **Power** The LCD module has internal bias voltage generators and requires only a single 3.3 V dc supply. #### Resistive Touch Panel The 4-wire resistive touch panel interfaces directly to the microcontroller, using 2 ADC channels and 2 GPIO signals. See the StellarisWare<sup>™</sup> source code for additional information on touch panel implementation. ## I<sup>2</sup>S Audio The LM3S9D96 development board has advanced audio capabilities using an I<sup>2</sup>S-connected Audio TLV320AlC23 CODEC. The factory default configuration has Audio output (Line Out and/or Headphone output) enabled. Four additional I<sup>2</sup>S signals are required for Audio input (Line Input and/or Microphone). All four audio interfaces are through 1/8" (3.5mm) stereo jacks. Table 2-6 shows the I<sup>2</sup>S audio-related signals. Table 2-6. I<sup>2</sup>S Audio-Related Signals | Microcontroller Pin | Board Function | Jumper Name | |---------------------|---------------------------|-------------------| | I2C0SDA | CODEC Configuration Data | SDA | | I2C0SCL | CODEC Configuration Clock | SCL | | I2STXSD | Audio Out Serial Data | TXSD | | I2STXWS | Audio Out Framing signal | TXWS | | I2STXSCK | Audio Out Bit Clock | BCLK <sup>a</sup> | | I2STXMCLK | Audio Out System Clock | MCLK | | I2SRXSD | Audio In Serial Data | RXSD <sup>b</sup> | | I2SRXWS | Audio In Framing signal | RXWS <sup>b</sup> | | I2SRXSCK | Audio In Bit Clock | BCLKb | | I2SRXMCLK | Audio In System Clock | MCLKb | a. Shares GPIO line with Analog voltage reference. Jumper installed by default. The Audio CODEC has a number of control registers which are configured using the I<sup>2</sup>C bus signals. CODEC settings can only be written, but not read, using I<sup>2</sup>C. See the StellarisWare™ example applications for programming information and the TLV320AIX23B data sheet for complete register details. The Headphone output can be connected directly to any standard headphones. The Line Output is suitable for connection to an external amplifier, including PC desktop speaker sets. #### User Switch and LED The development board provides a user push-switch and LED (see Table 2-7). Table 2-7. Navigation Switch-Related Signals | Microcontroller Pin | Board Function | Jumper Name | |---------------------|----------------|------------------| | PJ7 | User Switch | SWITCH | | PF3 | User LED | LED <sup>a</sup> | a. Shared with Ethernet Jack Yellow LED. This jumper is installed by default. b. Shares GPIO line with LCD data bus – Port D. Jumper omitted by default. # **External Peripheral Interface (EPI)** The External Peripheral Interface (EPI) is a high-speed 8/16/32-bit parallel bus for connecting external peripherals or memory without glue logic. Supported modes include SDRAM, SRAM, and Flash memories, as well as Host-bus and FIFO modes. The LM3S9D96 development kit includes an 8 MB SDRAM board in addition to an EPI break-out board. Other EPI expansion boards may be available. ## **SDRAM Expansion Board** The SDRAM board provides 8 MB of memory (4M x 16) which, once configured, becomes part of the LM3S9D96's memory map at either 0x6000.0000 or 0x8000.0000. The SDRAM interface multiplexes DQ00..14 and AD/BA0..14 without requiring external latches or buffers. Of the 32 EPI signals, only 24 are used in SDRAM mode, with the remaining signals used for non-EPI functions on the board. ## Flash and SRAM Memory Expansion Board The optional Flash and SRAM Memory Expansion Board (DK-LM3S9B96-FS8) is a plug-in for the DK-LM3S9D96 development board. This expansion board works with the External Peripheral Interface (EPI) of the Stellaris microcontroller and provides Flash memory, SRAM, and an improved performance LCD interface. For more information on the Flash and SRAM Memory Expansion Board (sold separately), see Appendix E, "Stellaris® LM3S9B96 Flash and SRAM Memory Expansion Board," on page 41. ## **FPGA Expansion Board** The FPGA Expansion Board (DK-LM3S9B96-FPGA) is an optional expansion board which connects directly to the External Peripheral Interface (EPI) port of the Stellaris DK-LM3S9D96 development board to demonstrate the machine-to-machine (M2M), high-bandwidth, parallel interface capability of the Stellaris microcontroller. Right out of the box, users are able to control and display the FPGA expansion board's video on the DK-LM3S9D96 development board's large, 3.5" touchscreen display. For more information on the FPGA Expansion Board (sold separately), see Appendix F, "Stellaris® LM3S9B96 FPGA Expansion Board," on page 51. ## **EM2 Expansion Board** The EM2 Expansion Board (DK-LM3S9B96-EM2) is an optional expansion board which connects directly to the External Peripheral Interface (EPI) port of the Stellaris DK-LM3S9D96 development board. The EM2 Expansion Board provides a transition between the Stellaris External Peripheral Interface (EPI) connector and the RF Evaluation Module (EM) connector. The DK-LM3S9B96-EM2 enables wireless application development using Low Power RF and RF ID evaluation modules on the Stellaris DK-LM3S9D96 platform. For more information on the EM2 Expansion Board (sold separately), see Appendix G, "Stellaris® LM3S9B96 EM2 Expansion Board," on page 73. ## **Using the In-Circuit Debugger Interface** The Stellaris® LM3S9D96 Development Kit can operate as an In-Circuit Debugger Interface (ICDI). ICDI acts as a USB to the JTAG/SWD adaptor, allowing debugging of any external target board that uses a Stellaris microcontroller. See "Debugging Modes" on page 16 for a description of how to enter ICDI Out mode. Figure 4-1. ICD Interface Out Mode The debug interface operates in either serial-wire debug (SWD) or JTAG mode, depending on the configuration in the debugger IDE. The IDE/debugger does not distinguish between the on-board Stellaris microcontroller and an external Stellaris microcontroller. The only requirement is that the correct Stellaris device is selected in the project configuration. The Stellaris target board should have a 2x10 0.1" pin header with signals as indicated in Table C-1 on page 35. This applies to both an external Stellaris microcontroller target (Debug Output mode) and to external JTAG/SWD debuggers (Debug Input mode). ICDI does not control RST (device reset) or TRST (test reset) signals. Both reset functions are implemented as commands over JTAG/SWD, so these signals are usually not necessary. ## **Schematics** This section contains the schematics for the DK-LM3S9D96 development board. - Micro, EPI connector, USB, and Ethernet on page 26 - LCD CAN, Serial Memory, and User I/O on page 27 - Power Supplies on page 28 - I<sup>2</sup>S Audio Expansion Board on page 29 - EPI and SDRAM Expansion Boards on page 30 - In-circuit Debug Interface (ICDI) on page 31 # **Component Locations** This appendix contains details on component locations for the DK-LM3S9D96 development board, including: ■ Component placement plot for top (Figure B-1) Figure B-1. Component Placement Plot for Top ## **Connection Details** This appendix contains the connection details for the DK-LM3S9D96 development board including the following sections: - DC Power Jack (see page 35) - ARM Target Pinout (see page 35) ### **DC Power Jack** The EVB provides a DC power jack for connecting an external +5 V regulated (+/-5%) power source. The socket is 5.5 mm dia with a 2.1 mm pin. ## **ARM Target Pinout** In ICDI input and output mode, the Stellaris® LM3S9D96 Development Kit supports ARM's standard 20-pin JTAG/SWD configuration. The same pin configuration can be used for debugging over serial-wire debug (SWD) and JTAG interfaces. Table C-1. Debug Interface Pin Assignments | Function | Pin Number | |--------------|---------------------------------| | TDI | 5 | | TDO/SWO | 13 | | TMS/SWDIO | 7 | | TCK/SWCLK | 9 | | System Reset | 15 | | VDD | 1 | | GND | 4, 6, 8, 10, 12, 14, 16, 18, 20 | | No Connect | 2, 3, 11, 17, 19 | Insert Jumper VDD/PIN1 Jumper (JP57) only when using the development board with an external debug interface such as a ULINK or JLINK. # **Microcontroller GPIO Assignments** Table D-1 shows the pin assignments for the LM3S9D96 microcontroller. Table D-1. Microcontroller GPIO Assignments | LM3S9D96 GPIO Pin | | Development Board Use | | | | | | |-------------------|-------------|-----------------------|------------------|---------------|---------------|--|--| | Number | Description | Default Function | Default Use | Alt. Function | Alternate Use | | | | 26 | PA0 | U0Rx | Virtual Com Port | | | | | | 27 | PA1 | U0Tx | Virtual Com Port | | | | | | 28 | PA2 | SSI0Clk | SPI | | | | | | 29 | PA3 | SSI0Fss | SD Card CSn | | | | | | 30 | PA4 | SSI0Rx | SPI | | | | | | 31 | PA5 | SSI0Tx | SPI | | | | | | 34 | PA6 | USB0EPEN | USB Pwr Enable | CAN0RX | | | | | 35 | PA7 | USB0PFLT | USB Pwr Fault | CAN0TX | | | | | 66 | PB0 | USB0ID | USB OTG ID | | | | | | 67 | PB1 | USB0VBUS | USB Vbus | | | | | | 72 | PB2 | I2C0SCL | Audio I2C | | | | | | 65 | PB3 | I2C0SDA | Audio I2C | | | | | | 92 | PB4 | ADC10 | Potentiometer | EPI0S23 | EPI Breakout | | | | 91 | PB5 | PB5 | LCD RDn | EPI0S22 | EPI Breakout | | | | 90 | PB6 | PB6 | I2STXSCK | AVREF | Ext Volt Ref | | | | 89 | PB7 | PB7 | LCD RST | | | | | | 80 | PC0 | TCK/SWCLK | JTAG | | | | | | 79 | PC1 | TMS/SWDIO | JTAG | | | | | | 78 | PC2 | TDI | JTAG | | | | | | 77 | PC3 | TDO/SWO | JTAG | | | | | | 25 | PC4 | EPI0S2 | SDRAM D02 | | EPI0S02 | | | | 24 | PC5 | EPI0S3 | SDRAM D03 | | EPI0S03 | | | | 23 | PC6 | EPI0S4 | SDRAM D04 | | EPI0S04 | | | | 22 | PC7 | EPI0S5 | SDRAM D05 | | EPI0S05 | | | | 10 | PD0 | PD0 | LCD Data 0 | I2SRXSCK | I2S Audio In | | | Table D-1. Microcontroller GPIO Assignments (Continued) | LM3S9D | 96 GPIO Pin | Development Board Use | | | | | | |--------|-------------|-----------------------|----------------|---------------|---------------|--|--| | Number | Description | Default Function | Default Use | Alt. Function | Alternate Use | | | | 11 | PD1 | PD1 | LCD Data 1 | I2S0RXWS | I2S Audio In | | | | 12 | PD2 | PD2 | LCD Data 2 | EPI0S20 | EPI Breakout | | | | 13 | PD3 | PD3 | LCD Data 3 | EPI0S21 | EPI Breakout | | | | 97 | PD4 | PD4 | LCD Data 4 | I2SRXSD | I2S Audio In | | | | 98 | PD5 | PD5 | LCD Data 5 | I2SRXMCLK | I2S Audio In | | | | 99 | PD6 | PD6 | LCD Data 6 | | | | | | 100 | PD7 | PD7 | LCD Data 7 | | | | | | 74 | PE0 | EPI0S8 | SDRAM D8 | | EPI0S08 | | | | 75 | PE1 | EPI0S9 | SDRAM D9 | | EPI0S09 | | | | 95 | PE2 | PE2 | Touch XN | | EPI0S24 | | | | 96 | PE3 | PE3 | Touch YN | | EPI0S25 | | | | 6 | PE4 | I2STXWS | I2S Audio Out | | | | | | 5 | PE5 | I2STXSD | I2S Audio Out | | | | | | 2 | PE6 | ADC1 | ADC Touch XP | | | | | | 1 | PE7 | ADC0 | ADC Touch YP | | | | | | 47 | PF0 | PF0 | Flash CSn | | | | | | 61 | PF1 | I2STXMCLK | I2S Audio Out | | | | | | 60 | PF2 | LED1 | Green Enet LED | | | | | | 59 | PF3 | PF3 | User LED | LED0 | Yw Enet LED | | | | 42 | PF4 | EPI0S12 | SDRAM D12 | | | | | | 41 | PF5 | EPI0S15 | SDRAM D15 | | | | | | 19 | PG0 | EPI0S13 | SDRAM D13 | | | | | | 18 | PG1 | EPI0S14 | SDRAM D14 | | | | | | 36 | PG7 | EPI0S31 | SDRAM CLK | | | | | | 86 | PH0 | EPI0S06 | SDRAM D06 | | | | | | 85 | PH1 | EPI0S07 | SDRAM D07 | | | | | | 84 | PH2 | EPI0S01 | SDRAM D01 | | | | | | 83 | PH3 | EPI0S00 | SDRAM D00 | | | | | | 76 | PH4 | EPI0S10 | SDRAM D10 | | | | | | 63 | PH5 | EPI0S11 | SDRAM D11 | | | | | Table D-1. Microcontroller GPIO Assignments (Continued) | LM3S9D | 96 GPIO Pin | Development Board Use | | | | | | | |--------|-------------|-----------------------|-------------|---------------|---------------|--|--|--| | Number | Description | Default Function | Default Use | Alt. Function | Alternate Use | | | | | 62 | PH6 | EPI0S26 | LCD_WRn | EPI0S26 | EPI Breakout | | | | | 15 | PH7 | EPI0S27 | LCD_DC | EPI0S27 | EPI Breakout | | | | | 14 | PJ0 | EPI0S16 | SDRAM DQM | | | | | | | 87 | PJ1 | EPI0S17 | SDRAM DQM | | | | | | | 39 | PJ2 | EPI0S18 | SDRAM CAS | | | | | | | 50 | PJ3 | EPI0S19 | SDRAM RAS | | | | | | | 52 | PJ4 | EPI0S28 | SDRAM WEn | | | | | | | 53 | PJ5 | EPI0S29 | SDRAM CSn | | | | | | | 54 | PJ6 | EPI0S30 | SDRAM SDCKE | | | | | | | 55 | PJ7 | PJ7 | User Switch | | | | | | # Stellaris® LM3S9B96 Flash and SRAM Memory Expansion Board This document describes the Flash and SRAM memory expansion board (DK-LM3S9B96-EXP-FS8) plug-in for the Stellaris® LM3S9B96 and LM3S9D96 Development Boards. This expansion board works with the External Peripheral Interface (EPI) port of the Stellaris microcontroller and provides Flash memory, SRAM, and an improved performance LCD interface. # **Features** The DK-LM3S9B96-EXP-FS8 memory expansion board has the following features: - 8 Megabytes of Flash memory - 1 Megabyte of SRAM - Memory-mapped LCD I/F for improved LCD performance - 1 kilobit of I<sup>2</sup>C memory for storing configuration data - Power LED indicator # Installation To install the expansion board on the DK-LM3S9D96 development board, do the following: - 1. Remove the DK-LM3S9B96-EXP-FS8 memory expansion board from the antistatic bag. - 2. On the DK-LM3S9D96 board, remove any installed board on EPI connector J2. **3.** On the DK-LM3S9D96 board remove the shunt jumpers on JP16-JP31 and the JP39 headers as shown in Figure E-1 on page 41. Figure E-2. Removing EPI Board from DK-LM3S9D96 Development Board - 4. Install the two snap-in nylon standoffs on mounting holes above the EPI connector J2. - **5.** Place the expansion board on top of the DK-LM3S9D96 board and align the standoffs, the EPI connector, and the 2x17 J2 header. - **6.** Press firmly downward until the board snaps in, then verify that the board is firmly seated on the EPI connector, the 2x17 header, and the standoffs. - 7. When powering up the board, verify that the power indicator LED D1 is lit. # **Hardware Description** The Flash and SRAM memory expansion board is designed for use with the Stellaris EPI module configured in Host Bus 8 address/data multiplexed mode. This mode requires the use of an external 8-bit latch for storing the lower 8 address lines A[7:0] transmitted during the address phase of an EPI transfer. This latch can be seen on the expansion board block diagram shown in Figure E-3. Connector **D** Q MA[7:0] MAD[7:0] EPI[7:0] FLASH MA[27:8] EPI[27:8] MAD[7:0] 8MB EPI30 MA27 CS OEn EPI28 WRn EPI29 SRAM 1MB MA26 CE<sub>1</sub> MA27 CE2 OE LCD LCD Control DECODE LCD Data LCD FLASH/SRAM/LCD IF Board Connector Figure E-3. Flash/SRAM/LCD IF Expansion Board Block Diagram # **Functional Description** The Flash and SRAM memory expansion board schematics are described in this section. The first page of the schematics shows the memory devices and address latch part of the design. The second page shows the LCD I/F and regulator. #### Flash/SRAM (Schematic 1 on page 48) Page 1 of the schematics shows the EPI connector, address latch, and memory devices. #### **EPI Connector** The EPI connector J1 is a 50-pin receptacle with 0.5 mm pitch that plugs into the EPI header on the DK-LM3S9D96 board. The 32 EPI signals and the 2 I<sup>2</sup>C0 signals from the LM3S9D96 are provided on this connector. It also provides 5 V for the on-board DC regulator. Note that not all EPI signals are used in this design. #### 8-bit Latch This 8-bit latch is used to store the lower 8-bits of the address, which are transmitted during the address phase of an EPI transfer. The EPI must be configured in Host bus 8 mode 0 mode (HB8 ADMUX), with EPI30 configured as an Address Latch Enable (ALE) signal to control this latch. #### Flash Memory The Flash memory used is a 64 Mbit, 90-nsec Spansion S29GL064N90TFI040. This 8/16 bit memory is used in 8-bit mode. Note that MA27 is used as a chip select signal for this memory. #### **SRAM** The SRAM used is an 8 Mbit, 45 nsec Cypress Semiconductor CY62158EV30LL-45ZSX, which is an 8-bit memory. Note that MA27 and MA26 are used as chip selects for this memory. #### I<sup>2</sup>C Memory This I<sup>2</sup>C serial memory is used for storing configuration data. This is a 1 kilobit On-Semiconductor memory. # LCD I/F, Power (Schematic 2 on page 49) Page 2 of the schematics shows the LCD\_DECODE CPLD, LCD interface connector, and the 3.3 V regulator. #### LCD DECODE CPLD The LCD DECODE CPLD provides address latch and decode for the LCD interface. The LCD Command and Data registers are mapped on the EPI memory space to streamline access to these registers. The LCD panel control signals L\_RDn, L\_RWn, and L\_DC and the L\_D bus are controlled by decode logic on the CPLD with timing derived from EPI signals and do not require direct control from the microcontroller. The LCD latch register is provided to control the XN and YN signals used for the touchscreen and also the reset signal to the LCD. The LCD backlight signal L\_BL is controlled by the Stellaris GPIO PE2 (MA[24]). PE2 can be programmed as a GPIO for ON/OFF control of the LCD. A second option is to configure PE2 for use as CCP2 or CCP4 with a PWM output for brightness control. The TP1-TP4 testpoints connect to the CPLD JTAG signals and, along with TP5 and TP6, provide an interface for test and programming of the CPLD. #### **LCD Interface Connector** The LCD Interface Connector J2 is a 2x17 socket that connects to headers JP16-JP31 and JP39 on the DK-LM3S9D96. All signals previously driven to the LCD from the Stellaris MCU are replaced by equivalent signals driven from the LCD\_DECODE CPLD. #### **DC** Regulator DC regulator U4 receives 5 V from the EPI connector and provides 3.3 V for the board. LED D1 provides a power indicator and lights when the regulator is providing power to the board. # **Memory Map** The DK-LM3S9B96-EXP-FS8 expansion board memory map is shown in Table E-1 and Table E-2 shows the **LCD Latch** register. Table E-1. Flash and SRAM Memory Expansion Board Memory Map | Device | A[27:26] | A[2:0] | Description | Access | Base address | |--------|------------|--------|-----------------------------|-------------------|--------------| | FLASH | 0X | XXX | Flash memory (8 Megabytes) | R/W | 0x6000.0000 | | SRAM | 10 | XXX | SRAM (1 Megabyte) | R/W | 0x6800.0000 | | CPLD | 11 | 000 | LCD latch set | R/W | 0x6C00.0000 | | CFLD | 11 | 001 | LCD latch clear | R/W | 0x6C00.0001 | | LCD | 11 | 010 | LCD command port | R <sup>a</sup> /W | 0x6C00.0002 | | LOD | 11 | 011 | LCD data port | R <sup>a</sup> /W | 0x6C00.0003 | | LCD | 11 | 110 | LCD command port read start | R | 0x6C00.0006 | | LOD | .CD 11 111 | | LCD data port read start | R | 0x6C00.0007 | a. For reads to the LCD Command and Data Port registers, the corresponding LCD Port Read Start register must be read first, followed by a 500 nsec delay before reading this register. Table E-2. LCD Latch Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |---|----------|---|---|---|-----|-----|-----| | | Reserved | | | | | | XN | | 0 | 0 | 0 | 0 | 0 | R/W | R/W | R/W | The **LCD Latch** register is implemented as a set/clear register. To set a bit, the corresponding bit must be set when writing to the **LCD Latch Set** register. To clear a bit, the corresponding bit must be set when writing to the **LCD Latch Clear** register. - When clear, the $L_XN$ signal is set to clear. When set, the $L_XN$ signal is tri-stated. This signal is used for the X- input to the touchscreen. - YN When clear, the L\_YN signal is set to clear. When set, the L\_YN signal is tri-stated. This signal is used for the Y- input to the touchscreen. - When clear, the L\_RSTN signal is set to clear. When set, the L\_RSTN signal is reset. This signal is used to reset the LCD panel. # **Component Locations** Figure E-4 shows the details of the component locations. Figure E-4. Component Placement Plot for Top and Bottom # **Schematics** This section shows the schematics for the DK-LM3S9B96-EXP-FS8 memory expansion board: - Flash, SRAM on page 48 - LCD Interface on page 49 # Stellaris® LM3S9B96 FPGA Expansion Board This chapter describes the Flash and SRAM memory expansion board for the Stellaris® LM3S9B96 and LM3S9D96 Development Boards. The Flash and SRAM memory expansion board provides a quick start platform to evaluate the capabilities of the Stellaris External Peripheral Interface (EPI) using the highly integrated DK-LM3S9D96 development platform. This combination adds full-screen motion video to the powerful, easy-to-use StellarisWare® GUI tools. Figure F-1 shows a photo of the Flash and SRAM memory expansion board. Figure F-1. FPGA Expansion Board # **Features** The DK-LM3S9B96-EXP-FS8 memory expansion board has the following features: - Xilinx Spartan 3E FPGA with 100k system gates - 1/13" CMOS VGA (640 x 480) Color Camera Module - 1 MB of asynchronous 10 nsec SRAM for graphics/video buffers - Standard 1 x 6 and 2 x 5 JTAG headers for FPGA programming - 1 kilobit of I<sup>2</sup>C memory for storing configuration data - 8 FPGA test pads provide 5 inputs and 3 I/Os - All necessary power regulation The default FPGA image adds the following features: - EPI operation in GPM D16-A12 mode at 50 MHz, up to 100 MB/s - Graphical on-screen-display (OSD) overlaid on moving QVGA video - Widget-based touchscreen user interface - Screen capture to SDCard or USB stick in Windows bitmap (BMP) format - Brightness, saturation, tint/hue, and sharpness picture controls - Mirror/Flip/Normal Picture controls # Installation To install the expansion board on the DK-LM3S9D96 development board, do the following: - 1. Remove the DK-LM3S9B96-EXP-FS8 memory expansion board from the antistatic bag. - 2. On the DK-LM3S9D96 board, remove any installed board on EPI connector J2. - **3.** On the DK-LM3S9D96 board, remove the shunt jumpers on JP16-JP31 and the JP39 headers as shown in Figure F-1 on page 51. - **4.** Place the expansion board on top of the DK-LM3S9D96 board and press firmly downward until the board snaps in. - 5. Connect the the male EPI expansion connector on the bottom side of the Flash and SRAM memory expansion board to the female EPI expansion connector on the DK-LM3S9D96 development board (J2). The LCD header pins should fit through the holes on the PCB. - **6.** Use the included jumper wire to provide 5 V power to J5 from any of the three upper pins immediately below and to the right of the EXT+5V connector on the development board. - 7. When powering up the board, verify that the power indicator LED D1 is lit. Figure F-2. Removing EPI Board from DK-LM3S9D96 Development Board # **Hardware Description** The Flash and SRAM memory expansion board is designed for use with the Stellaris EPI module. Figure F-3 shows a simplified system block diagram. Components of the default FPGA board are shown in half-tone outline. Figure F-3. FPGA Expansion Board Block Diagram #### **FPGA** The Flash and SRAM memory expansion board features a Xilinx Spartan 3e FPGA, which interfaces to the Stellaris® microcontroller through its EPI port and acts as a crossbar to the rest of the peripherals. #### Camera The Omnivision OV7690 camera provides color VGA images at up to 30 frames per second to the FPGA over an 8-bit wide parallel interface. It is configured by the Stellaris microcontroller via I<sup>2</sup>C. #### **SRAM** The 1 MB, 8-bit wide, 10 ns SRAM is nominally used as a set of frame buffers. 16 bits of the 20-bit address space are latched and multiplexed with its data. Access time may be dependent on the previous address. # **Configuration PROM** A Xilinx standard configuration PROM holds the default FPGA image and automatically uploads it at power-on. # **Configuration Pushbutton** To reload the configuration PROM image to the FPGA, press the configuration pushbutton. This allows you to load a new image via JTAG without resetting the rest of the system. #### **Test Port** Eight uncommitted FPGA pins are brought to test pads. Five of the FPGA pins can only be used as inputs. The remaining three FPGA pins can be used as inputs or outputs. #### **Camera Connector** The camera is hosted by the FPC Connector P1 located to the left of the FPGA. To insert or remove the camera, first open the latch by grasping either side of the connector and gently lifting straight up. With the latch open, the camera moves easily; do not force. The camera faces away from the FPGA. Close the latch by pushing down on it gently before use. Caution – Handle the camera carefully when inserting or removing it from the board. Never force the camera into a different position, doing so could damage the camera. ## **5 V Power Pin** J5 is used to provide 5-V power to the Flash and SRAM memory expansion board's regulators. This must be connected for successful board operation. Connect the the male EPI expansion connector on the bottom side of the Flash and SRAM memory expansion board to the female EPI expansion connector on the DK-LM3S9D96 development board (J2). The LCD header pins should fit through the holes on the PCB. ## 24-MHz Oscillator The camera and the camera interface portion of the FPGA are clocked by a 24-MHz external oscillator. # **External Peripheral Interface (EPI) Module** The External Peripheral Interface (EPI) module provides a slave interface for use with the Stellaris microcontroller's EPI controller configured in general-purpose mode A12-D16. The direction of the signal allocation is in relation to the FPGA (for example, a signal labeled *In* is an input to the FPGA, a signal labelled *Out* is an output from the FPGA). See Table F-8 on page 66 for a list of the EPI signals. **NOTE:** Only 16-bit or 32-bit transfers are allowed for this interface. # **Using the Widget Interface** This section provides information about writing your own graphics using the widget interface for the Flash and SRAM memory expansion board. # **Writing Your Own Stellaris Application** The Stellaris microcontroller communicates with the default FPGA image through a memory-mapped interface. To get started, you must first configure the EPI port by doing the following: - 1. Configure the GPIO. - 2. Configure the EPI port and map it into memory at 0xA000.0000. Code Example F-1 Configuring the EPI Port ``` EPIModeSet(EPI0_BASE, EPI_MODE_GENERAL); //General Purpose mode EPIDividerSet(EPI0_BASE, 1); //Divide system clock by 2 EPIConfigGPModeSet(EPI0_BASE, (EPI_GPMODE_DSIZE_16 //16 Bit data | EPI_GPMODE_ASIZE_12 //12 Bit address EPI_GPMODE_WORD_ACCESS //Use Word Access Mode EPI_GPMODE_READWRITE //Use read and write strobe pins EPI_GPMODE_READ2CYCLE //Reads take two cycles EPI_GPMODE_CLKPIN //EPI outputs clock to peripheral EPI_GPMODE_RDYEN ), //Peripheral emits a ready signal Ο, //Not using frame signal, so ignore 0); //Not using clock enable, so ignore EPIAddressMapSet(EPI0_BASE, EPI_ADDR_PER_SIZE_64KB //64kB memory space | EPI_ADDR_PER_BASE_A); //EPI base address is 0xA0000000 ``` # **Memory Map** The DK-LM3S9B96-FPGA expansion board memory map is shown in Table F-1. The default Stellaris code maps this into the 0xA000.0XXX memory space. Detailed descriptions for each register are provide in "Register Descriptions" on page 57. **NOTE:** Ten bits are used for addressing, but the EPI controller allocates a 12-bit address space. The result is that 0x0A00.0000 is equivalent to 0x0A00.0400, 0x0A00.0800, and 0x0A00.0C00. | Table F-1. | EDC A | Evnancion | Roard | Momory | Man | |------------|-------|-----------|-------|--------|-----| | Table F-1. | FPGA | Expansion | Doard | wemory | wab | | Register | A[10:1] | Size | Register Name | Access | See Page | |----------|---------|--------|-------------------------------|--------|----------| | VERSION | 000 | [15:0] | Board and FPGA Design Version | R | 58 | | SYSCTRL | 002 | [15:0] | System Control | R/W | 58 | | IRQEN | 004 | [15:0] | Interrupt Enable | R/W | 59 | | IRQSTAT | 006 | [15:0] | Interrupt Status | R/W | 60 | | MEMPAGE | 800 | [10:0] | Memory Page | R/W | 60 | | TPAD | 00A | [7:0] | Test Pad | R/W | 61 | | LCTRL | 010 | [3:0] | LCD Control Set | R/W | 61 | | LOTIL | 012 | [3:0] | LCD Control Clear | R/W | 01 | | CHRMKEY | 022 | [15:0] | Chroma Key | R/W | 62 | Table F-1. FPGA Expansion Board Memory Map (Continued) | Register | A[10:1] | Size | Register Name | Access | See Page | |----------|---------|--------|----------------------------------------------|--------|----------| | VCRM | 026 | [8:0] | Video Capture Row Match | R/W | 62 | | VML | 030 | [15:0] | Video Memory Address Low | R/W | 62 | | VMH | 032 | [4:0] | Video Memory Address High | R/W | 62 | | VMS | 034 | [11:0] | Video Memory Stride | R/W | 62 | | LRM | 036 | [7:0] | LCD Row Match | R/W | 62 | | LVML | 040 | [15:0] | LCD Video Memory Address Low | R/W | 62 | | LVMH | 042 | [4:0] | LCD Video Memory Address High | R/W | 62 | | LVMS | 044 | [11:0] | LCD Video Memory Stride register (in bytes). | R/W | 62 | | LGML | 050 | [15:0] | LCD Graphics Memory Address Low | R/W | 62 | | LGMH | 052 | [4:0] | LCD Graphics Memory Address High | R/W | 63 | | LGMS | 054 | [11:0] | LCD Graphics Memory Stride | R/W | 63 | | MPNC | 056 | [9:0] | Memory Port Number of Columns | R/W | 63 | | MPR | 058 | [8:0] | Memory Port Current Row | R/W | 63 | | MPC | 05A | [9:0] | Memory Port Current Column | R/W | 63 | | MPML | 05C | [15:0] | Memory Port Address Low | R/W | 63 | | MPMH | 05E | [4:0] | Memory Port Address High | R/W | 63 | | MPMS | 060 | [11:0] | Memory Port Stride | R/W | 63 | | MPORT | 080 | [15:0] | Memory Port | R/W | 63 | | MEMWIN | 400 | [15:0] | Memory Window | R/W | 63 | # **Register Descriptions** This section provides the detailed register information for the Flash and SRAM memory expansion board. ## **Version Register** The **Version** register communicates the revision numbers of the PCB, the FPGA RTL, and the Stellaris silicon. A dummy write of 0x0000 to this register determines if the Stellaris silicon is revision C (or higher) and configures the EPI clocking circuit appropriately. This is required during initialization for proper operation. Table F-2. Version Register | | | | | | VER | SION: 0xA | 000.0000 | |----|----------|------------|----|----|----------|------------|----------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | | PCE | Board Ve | 0 | 0 | RevC | | | | R | R | R | R | R | R | R | R | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | RTL Majo | or Version | | | RTL Mind | or Version | | | R | R | R | R | R | R | R | R | Bit Name Description PCB Board Version: Revision level of the Flash and SRAM memory expansion board. RevC: This bit is high if the FPGA believes it is communicating with Revision C of the silicon (or higher). This bit is only valid after being initialized as described above. RTL Version Revision level of the code running in the Flash and SRAM memory expansion board. #### System Control Register The **System Control** register provides access to configuration bits for the video capture and display system. It is implemented as a read-modify-write register and includes LCD and capture modes. Table F-3. System Control Register SYSCTRL: 0xA000.0002 15 14 12 11 10 9 8 13 0 0 0 0 0 0 0 **PCBrA** R R R R R R R R/W 7 1 6 5 4 3 2 0 **VCTES VCQV VSCAL CMKE MPRI LGDEN LVDEN** VCEN Τ GΑ Ε Ν R/W R/W R/W R/W R/W R/W R/W R/W Bit Name Description | VCEN | Video capture DMA enable. Enables video capture to memory. Disabling this bit captures the remainder of the current frame, and then stops. | |--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LVDEN | LCD Video DMA enable. Enables DMA from the video memory region to the LCD. | | LGDEN | LCD Graphics DMA enable. Enables DMA from the graphics memory region to the LCD. | | CMKEN | Chroma key enable. | | VSCALE | Video scale control. Scales the video during output to the LCD. If set, the LCD DMA engine skips every other pixel and every other row during LCD video DMA output (Graphics DMA is not affected). As a result, the video object displays at ¼ its normal size. | | MPRI | Memory port row increment. If set to 0, any read or write to the memory port auto increments the MPC register at the end of the transfer by 1. If MPC is at the last column (MPNR-1), then it sets to 0 and the MPR increments by 1. If the end of the row is reached, then it increments by columns. If set to 1, any read or write increments by rows. | | VCQVGA | Video Capture is QVGA/VGA. If set to 0, the video capture controller assumes that the camera is configured for VGA capture. If set to 1, it assumes that the camera is configured for QVGA. This only affects video capture; the camera's I <sup>2</sup> C and LCD settings must be reconfigured manually. | | VCTEST | Video Capture Test. When set to 1, the incoming pixel stream is ignored and replaced with a test pattern. | | PCBrA | PCB is Revision A. An early internal revision of the PCB had a different pin configuration for the camera data port. Setting this bit to 1 provides backwards compatibility. | | | | # **Interrupt Enable Register** The **Interrupt Enable** register masks or enables interrupts from the FPGA to the Stellaris LM3S9D96 microcontroller. Masked interrupts will not assert the IRQ line, but they will still appear in the Interrupt Status Register. Table F-4. Interrupt Enable Register | | | | | | IF | RQEN: 0xA | 000.0004 | |----|----|-------|-------|-------|-------|-----------|----------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R | R | R | R | R | R | R | R | | | | Ī | | Ī | Ī | Ī | Ī | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0 | 0 | LRMIE | LTEIE | LTSIE | VRMIE | VCFEIE | VCFSIE | | R | R | R/W | R/W | R/W | R/W | R/W | R/W | | Bit Name | Description | |----------|---------------------------------------------| | VCFSIE | Video capture frame start interrupt enable. | | VCFEIE | Video capture frame end interrupt enable. | VRMIE Video capture row match interrupt enable. LTSIE LCD transfer start interrupt enable. LTEIE LCD transfer end interrupt enable. LRMIE LCD display row match interrupt enable. # **Interrupt Status Register** The **Interrupt Status** register reports and clears interrupts from the camera and LCD systems. An interrupt latches its corresponding bit high until cleared by writing a 1 to it. Table F-5. Interrupt Status Register | | | | | | IRC | QSTAT: 0xA | .000.0006 | |----|----|------|------|------|------|------------|-----------| | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R | R | R | R | R | R | R | R | | | | | | | | | | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | 0 | 0 | LRMI | LTEI | LTSI | VRMI | VCFEI | VCFSI | | R | R | R/W | R/W | R/W | R/W | R/W | R/W | | Bit Name | Description | |----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------| | VCFSI | Video capture frame start interrupt. Clear the interrupt by setting the corresponding bit to 1. Setting the bit to 0 has no effect. | | VCFEI | Video capture frame end interrupt. Clear the interrupt by setting the corresponding bit to 1. Setting the bit to 0 has no effect. | | VRMI | Video capture row match interrupt. Clear the interrupt by setting the corresponding bit to 1. Setting the bit to 0 has no effect. | | LTSI | LCD transfer start interrupt. Clear the interrupt by setting the corresponding bit to 1. Setting the bit to 0 has no effect. | | LTEI | LCD transfer end interrupt. Set to 1 to clear the corresponding bit. Clear the interrupt by setting the corresponding bit to 1. Setting the bit to 0 has no effect. | | LRMI | LCD display row match interrupt. Clear the interrupt by setting the corresponding bit to 1. Setting the bit to 0 has no effect. | ## **Memory Page Register** The **Memory Page** register selects to memory page to access. ## **Test PadRegister** The **Test Pad** register is used to access the on-board test pads TP1-TP8, which are connected to unused FPGA pins. Table F-6. Test Pad Register TXPAD: 0xA000.000A | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | |-----|-----|-----|-----|-----|-----|-----|-----| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | R | R | R | R | R | R | R | R | | | | 1 | | 1 | 1 | 1 | 1 | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | TP8 | TP7 | TP6 | TP5 | TP4 | TP3 | TP2 | TP1 | | R | R | R | R | R | R/W | R/W | R/W | Bit Name Description TP1-TP3 Test Pins 1-3. These are connected to FPGA I/O pins. Writing a 1 sets the corresponding test pin output to 1. Writing a 0 sets the corresponding test pint output to 0. Reading these bits returns the value at the corresponding test pin input. **NOTE:** The FPGA output driver for these signals is always enabled. TP4-TP8 Test Pins 4-8. These are connected to FPGA input pins. Writing these bits has no effect. Reading these bits returns the value at the corresponding test pin input. #### **LCD Control Register** The **LCD Control** register is implemented as a set/clear register and contains four bits for LCD panel control. To set a bit, set the corresponding bit to 1 when writing to the **LCD Control Set** register. To clear a bit, set the corresponding bit when writing to the **LCD Control Clear** register. Table F-7. LCD Control Register LCDCTRL: 0xA000.0012 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | | |----|----|----|----|----|-----|----|----|--| | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | R | R | R | R | R | R | R | R | | | | | | | | | | | | | 7 | 6 | 5 | 4 | 2 | 2 | 4 | • | | | | | | 4 | 3 | 2 | • | 0 | | | | ( | | 4 | BL | RST | YN | XN | | Bit Name Description ΧN LCD panel touchscreen X control. When set to 0, the LCD Xn signal is set to 0. When set to 1, the LCD Xn signal is tri-stated. YN LCD panel touchscreen Y control. When set to 0, the LCD Yn signal is set to 0. When set to 1, the LCD Yn signal is tri-stated. RST LCD panel reset control. When set to 0, the LCD RSTn signal is set to 0. When set to 1 the LCD RSTn signal is set to 1. BL LCD backlight control. When set to 0, the LCD panel backlight is turned off. When set to 1, the LCD panel backlight is turned on. #### **Chroma Key Register** The **CHRMKEY** register contains the RGB values to compare for graphics overlay operation. During LCD screen updates, data from graphics memory is compared with this register, if a match occurs, the corrsponding frame video pixel is sent to the output instead. ## **Video Capture Row Match Register** During video capture, at the start of a row, the current row value is compared with the **VCRM** register. A match generates an interrupt if enabled. ## **Video Memory Address Low Register** The **VML** register provides a pointer to the start of video capture memory and contains the lower 16-bits of the address. #### **Video Memory Address High Register** The **VMH** register provides a pointer to the start of video capture memory and contains the higher 16-bits of the address. ## Video Memory Stride Register The **VMS** register specifies the number of locations in video memory between successive array elements (stride) and is measured in bytes. Using stride enables better processing time. #### **LCD Row Match Register** During LCD display DMA output, at the start of each row, the current row value is compared with the **LRM** register. A match generates an interrupt if enabled. #### LCD Video Memory Address Low Register The **LVML** register provides a pointer to the start of video data for transfer to the LCD. This contains the lower 16-bits of the address. #### **LCD Video Memory Address High Register** The **LVMH** register provides a pointer to the start of video data for transfer to the LCD. This contains the higher 16-bits of the address. ## LCD Video Memory Stride Register The **LVMS** register specifies the number of bytes between the first pixels on adjacent rows in LCD video memory. Recommended to be either the length of a row (in bytes), or the next highest power of two. #### **LCD Graphics Memory Address Low Register** The **LGML** register provides a pointer to the start of graphics memory for output to the LCD and contains the lower 16-bits of the address. #### **LCD Graphics Memory Address High Register** The **LGMH** register provides a pointer to the start of graphics memory for output to the LCD and contains the higher 16-bits of the address. #### **LCD Graphics Memory Stride Register** The **LGMS** register specifies the number of bytes between the first pixels on adjacent rows in LCD graphics memory. Recommended to be either the length of a row (in bytes), or the next highest power of two. ## **Memory Port Number of Columns Register** The MPNC register specifies the number of columns (in pixels) of the memory port. ## **Memory Port Current Row Register** The MPR register identifies the selected row in the memory port. ## **Memory Port Current Column Register** The MPC register identifies the selected column in the memory port. #### **Memory Port Address Low Register** The **MPML** register contains the lower address bits of the memory region accessed by the memory port. #### **Memory Port Address High Register** The **MPMH** register contains the upper address bits of the memory region accessed by the memory port. ## **Memory Port Stride Register** The **MPMS** register specifies the number of bytes between the first pixels on adjacent rows in the memory port. Recommended to be either the length of a row (in bytes), or the next highest power of two. ## **Memory Port Register** The **MPORT** register allows sequential video/graphics memory plane access. A write (read) to this port generates a memory write (read) to the memory location calculated as follows: ``` Mem address = {MPH:MPL} + MPR x MPS + MPC. ``` After the transfer, if the MPC is not at the last pixel of the row, it automatically increments by 1. If the MPC is at the last pixel of the row, it sets to 0 and the MPR is incremented by MPS. ## Memory Window Register Use the MEMPAGE register to select the active page (1 Kbyte page). # Loading a New Image to the FPGA The FPGA can be re-imaged using any of the JTAG tool chains that support the Xilinx Spartan 3e XC3S100e. Two standard JTAG interfaces are provided with the Flash and SRAM memory expansion board: 2 x 7 with 2mm pitch and 1 x 6 with .1" pitch. Once connected, your JTAG scan chain should show an XC3S100e FPGA and an XCF01S PROM. **NOTE:** Images loaded into the PROM must be set to use CCLK as the startup clock. Images loaded direct to the FPGA may use either CCLK or JTAG CLK. Figure F-4. FPGA Boundary Scan **NOTE:** The DK-LM3S9B96-EXP-FS8 boots in JTAG mode, but transitions to serial mode once configured by the PROM. If your programmer is JTAG-only, you may need to clear the PROM and power cycle before you can directly program the FPGA via JTAG. This issue is rare since most tools support both modes. Check with your tool manufacturer for updates. # Installing the Software To install the software, do the following: 1. Plug the provided cable into J4 (on the right side of the board), taking care to ensure proper alignment and orientation. The silk-screened signal names should match, with the exception that 2.5 V corresponds to VDD. When correctly aligned, the "JTAG-SPI Full Speed" text should face in toward the FPGA. # Modifying the Default Image This section provides the descriptions for the default FPGA image blocks. # **Default FPGA Image Blocks** ## **Configuration Registers** The configuration registers are transparently mapped into the Stellaris microcontroller's memory, and are used to control the flow of the video streams. "Register Descriptions" on page 57 provides the detailed register maps. This is contained within the vregs.v file. ## **Memory Windower** The memory windower allows the Stellaris microcontroller to work with a rectangular portion of a frame buffer. For example, this can be used to pull macro-cells for JPEG compression. This is contained within the mport.v file. ## **Memory Arbiter** The memory arbiter negotiates access to the external SRAM. The camera capture block is given highest priority. This is contained within the arb.v file. ## **Video Compositor** The video compositor assembles the final image from the video and graphics frame buffers, and passes it directly to the LCD Interface. It also converts the camera's VGA resolution to the LCD's QVGA resolution by either downsampling. This is contained within the vlcd.v file. #### LCD I/F The LCD interface connects to the Kitronix 3.5" LCD display using an 8-bit parallel mode. This is usually driven by the Video Compositor, but can also be driven directly by the EPI interface. This is contained within the vregs.v file. #### Camera I/F The camera interface block captures pixel data from the Omnivision OV7690's 8-bit digital video port and synchronization signals. This is contained within vcapture.v #### Camera FIFO The Camera FIFO serves two main purposes: reclocking and flow control. The camera and camera interface run in their own 12-/24-MHz clock domain, whereas the rest of the system runs off of the EPI clock or twice the EPI clock. The FIFO bridges these difference clock domains. The camera does not support any flow control functions; once triggered, it proceeds through an entire image. In order to prevent loss of pixels, this FIFO is 64 elements deep. This is contained within the vcapture.v and async\_fifo\_64.v files. # **EPI Signal Descriptions** Table F-8 provides the EPI module's signal descriptions. Table F-8. EPI Signal Descriptions | EPI Signal | Port | FPGA Signal | Direction | Description | |--------------|-----------------------------------------------------------------------------|--------------|-----------|--------------------------------------------------| | EPIOS[31] | PG7 | CLK | In | EPI Clock | | EPIOS[30] | PJ6 | E_IRQn | Out | Interrupt Signal to Microcontroller <sup>a</sup> | | EPIOS[29] | PJ5 | E_RD | In | EPI Read Strobe | | EPIOS[28] | PJ4 | E_WR | In | EPI Write Strobe | | EPIOS[27] | PH7 | E_RDY | Out | EPI Ready Signal | | EPIOS[26] | PH6 | E_RSTn | In | FPGA Reset Signal <sup>b</sup> | | EPIOS[25:16] | PE3,PE2,PB4,<br>PB5,PD3,PD2,PJ3,<br>PJ2,PJ1,PJ0 | E_ADDR[10:1] | ln | EPI Address Bus | | EPIOS[15:0] | PF5,PG1,PG0,PF4,<br>PH5,PH4,PE1,PE0,<br>PH1,PH0,PC7,PC6,<br>PC5,PC4,PH2,PH3 | E_DATA[15:0] | I/O | EPI Data Bus | a. Configure as Stellaris GPIO input with negative level sensitive interrupts. During power up/reset is used for PLL lock status. b. Configure as Stellaris GPIO output. # **Component Locations** Figure F-5 shows the details of the component locations from the top view and Figure F-6 shows the details of the component locations from the bottom view. Figure F-5. Component Placement Plot for Top Figure F-6. Component Placement Plot for Bottom # **Schematics** This section shows the schematics for the DK-LM3S9B96-FPGA memory expansion board: - EPI, LCD, Camera I/F on page 70 - SRAM, Power, JTAG on page 71 # Stellaris® LM3S9B96 EM2 Expansion Board This document describes the Stellaris EM2 Expansion Board (DK-LM3S9B96-EXP-FS8) for the Stellaris® LM3S9B96 and LM3S9D96 Development Boards. The Flash and SRAM memory expansion board provides a transition between the Stellaris External Peripheral Interface (EPI) connector and the RF Evaluation Module (EM) connector. The DK-LM3S9B96-EXP-FS8 enables wireless application development using Low Power RF (LPRF) and RF ID evaluation modules on the Stellaris DK-LM3S9D96 platform. Figure G-1. EM2 Expansion Board ## **Features** The DK-LM3S9B96-EXP-FS8 expansion board has the following features: - 2 sets of EM connectors to support up to 2 RF evaluation modules - 1 kilobit of I<sup>2</sup>C memory for storing configuration data and Flash and SRAM memory expansion board detection - EM digital and analog audio signal headers - EM MOD1 SDIO connection headers - 32 Khz oscillator for slow clock source to primary Flash and SRAM memory expansion board connector ### Installation To install the Flash and SRAM memory expansion board on the DK-LM3S9D96 development board, do the following: - 1. On the DK-LM3S9D96 board (shown in Figure G-2 on page 74), remove any installed board on EPI connector J2 (A). - On the DK-LM3S9D96 board (shown in Figure G-2), confirm that shunt jumpers on JP16-JP31 (B) are installed to enable the LCD touch screen. JP39 (C), the leftmost jumper indicated, should remain uninstalled. Figure G-2. Removing EPI Board from DK-LM3S9D96 Development Board 3. Place the Flash and SRAM memory expansion board on top of the DK-LM3S9D96 board while aligning the male EPI expansion connector on the bottom side of the Flash and SRAM memory expansion board with the female EPI expansion connector on the DK-LM3S9D96 development board (J2). Figure G-3. EM2 Expansion Board **4.** Press firmly downward until the board snaps in place. Figure G-4. Assembled DK-LM3S9D96 Development Board with EM2 Expansion Board # Installation of EM Modules onto the EM2 Expansion Board The Flash and SRAM memory expansion board has a primary EM header (MOD1) and a secondary EM header (MOD2) as indicated on the silk screen (see Figure G-5). The secondary EM header is rotated 180 degrees from the primary EM header. There are many types of EM modules that can be installed onto the Flash and SRAM memory expansion board. See the README First document for the EM module you are installing to determine if there is a specific requirement or recommendation for which header the EM module should be installed in. If installing a single module and if there is no specific requirement or recommendation in the module's README First document indicating which slot it should be installed in, install the single module into the primary EM header (MOD1). To install an EM module into the primary module EM slot of the Flash and SRAM memory expansion board, do the following: - 1. Attach any supplied antennas to the EM module. - 2. Locate the two 20-pin sockets on the back side of the EM module. Note the tab on the side of each of the 20-pin sockets. This tab denotes pin 1 and aligns with the 20-pin headers on the Flash and SRAM memory expansion board that contain slots near pin 1 for the tab. See Figure G-5 for details. Figure G-5. Connecting an EM Module to the EM2 Expansion Board **3.** Align the two 20-pin sockets on the EM module over the 20-pin headers on the Flash and SRAM memory expansion board that are within the primary EM silkscreen. **4.** Use a slight pressure to seat the EM module firmly on the Flash and SRAM memory expansion board. See Figure G-6 on page 77 for fully assembled DK-LM3S9D96 board with Flash and SRAM memory expansion board and wireless EM module. Figure G-6. Fully Assembled DK-LM3S9D96 Board with EM2 Expansion Board and Wireless EM Module Follow these same steps for installing a second module into the secondary EM header location which will be oriented 180 degrees from the primary EM header location. **NOTE:** The secondary EM header should only be used when two EM modules are installed in the system or when specifically indicated in the EM module's README First document. ## **Hardware Description** The block diagram for the Flash and SRAM memory expansion board is shown in Figure G-7. Figure G-7. EM2 Expansion Board Block Diagram ## **Primary EM Header** The primary EM header should always be used when only one EM module is installed unless otherwise indicated in the README First document for the EM module you are installing. The primary EM header connects three buses to the EPI connector that are also shared with the secondary EM header. These buses are I<sup>2</sup>C, UART1, and SPI. **NOTE:** The primary and secondary EM headers have a unique SPI chip select signal, but share the data and clock signals. The primary EM header contains four GPIO connections to the EPI connector. These GPIOs can be used as inputs or outputs depending upon the EM module installed. In addition, four unique GPIOs are provided to each EM header. The primary EM header contains one GPIO connection used to shut down and/or reset the EM module. The actual function depends on the EM module installed. The MODx\_nSHUTD signal is pulled up to 3.3 V on the EM2 adapter. Each header has its own MODx\_nSHUTD signal. The primary EM header contains additional features not found on the secondary EM header including a 32-KHz oscillator input and a header for a 4-bit SDIO module. These features are not currently used by the EM modules available today but are available for future expansion. #### Secondary EM Header The secondary EM header should only be used when two EM modules are installed in the system or when specifically indicated in the EM module's README First document. #### CAT24C01 EEPROM The EM2 board contains a 1-Kbit I<sup>2</sup>C EEPROM which connects to an I<sup>2</sup>C bus separate from the one connected to the EM headers. This EEPROM contains data that is used by the software drivers to auto detect that the EM2 expansion board is installed in the system. The EEPROM is normally write-protected. To make the EEPROM writeable, install a jumper between pins 2 and 3 of JPS1. #### I<sup>2</sup>S Header The primary EM header and the secondary EM header each contain connections to separate 6-pin I<sup>2</sup>S headers J2 and J4 respectively. These headers connect to the EM modules only and are not connected to the EPI header which connects to the DK-LM3S9D96. See the EM module's documentation for more information on the functionality of this header. #### **Analog Audio Header** The primary EM header and the secondary EM header each contain connections to separate 4-pin analog audio headers J3 and J5 respectively. These headers connect to the EM modules only and are not connected to the EPI header which connects to the DK-LM3S9D96. See the EM module's documentation for more information on the functionality of this header. #### SDIO Header The primary EM header contains a connection to 8-pin SDIO header J1. This header connects to the EM modules only and is not connected to the EPI header which connects to the DK-LM3S9D96. See the EM module's documentation for more information on the functionality of this header. ## **EPI Signal Descriptions** Figure G-1 provides the EPI module's signal descriptions. Table G-1. EPI Signal Descriptions | LM3S9D96 Function | Port | EM2 Signal | Direction | Description | |-------------------|------|------------|-----------|-----------------------------------------| | PE1 | PE1 | SPI_CS1 | Out | SPI Chip Select for Primary EM Module | | PJ4 | PJ4 | SPI_CS2 | Out | SPI Chip Select for Secondary EM Module | | SSI1CLK | PH4 | SPI_CLK | Out | SPI Clock | | SSI1Rx | PF4 | SPI_MISO | In | SPI Receive | Table G-1. EPI Signal Descriptions (Continued) | LM3S9D96 Function | Port | EM2 Signal | Direction | Description | | |-------------------|------|--------------|-----------|-----------------------------------------------|--| | SSI1TX | PF5 | SPI_MOSI | Out | SPI Transmit | | | U1RX | PC6 | MOD_UART_TX | In | Modulator UART TX, LM3S9D96 RX | | | U1TX | PC7 | MOD_UART_RX | Out | Modulator UART RX, LM3S9D96 TX | | | U1RTS | PJ6 | MOD_UART_CTS | Out | Modulator UART CTS, LM3S9D96 RTS | | | U1CTS | PJ3 | MOD_UART_RTS | In | Modulator UART RTS, LM3S9D96 CTS | | | I2C1SCL | PJ0 | MOD_I2C_SCL | Out | I <sup>2</sup> C Bus to EM Modules | | | I2C1SDA | PJ1 | MOD_I2C_SDA | I/O | I <sup>2</sup> C Bus to EM Modules | | | I2C0SCL | PB2 | AD_I2C_SCL0 | Out | I <sup>2</sup> C Bus to Auto Discovery EEPROM | | | I2C0SDA | PB3 | AD_I2C_SDA0 | I/O | I <sup>2</sup> C Bus to Auto Discovery EEPROM | | | PC4 | PC4 | MOD1_nSHUTD | Out | Shutdown/Reset Signal for Primary EM Module | | | PH5 | PH5 | MOD2_nSHUTD | Out | Shutdown/Reset Signal for Secondary EM Module | | | PH0 | PH0 | MOD1_GPIO0 | I/O | GPIO for Primary EM Module | | | PH1 | PH1 | MOD1_GPIO1 | I/O | GPIO for Primary EM Module | | | PH2 | PH2 | MOD1_GPIO2 | I/O | GPIO for Primary EM Module | | | PH3 | PH3 | MOD1_GPIO3 | I/O | GPIO for Primary EM Module | | | PG0 | PG0 | MOD2_GPIO0 | I/O | GPIO for Secondary EM Module | | | PG1 | PG1 | MOD2_GPIO1 | I/O | GPIO for Secondary EM Module | | | PG7 | PG7 | MOD2_GPIO2 | I/O | GPIO for Secondary EM Module | | | PJ2 | PJ2 | MOD2_GPIO3 | I/O | GPIO for Secondary EM Module | | # **Component Locations** Figure G-8 shows the details of the component locations. Figure G-8. Component Placement Plot for Top and Bottom # **Schematics** This section shows the schematics for the Flash and SRAM memory expansion board: ■ EM2 Expansion Board on page 85 # References In addition to this document, the following references are included on the Stellaris DK-LM3S9D96 Development Kit Documentation and Software CD and are also available for download at <a href="https://www.ti.com/stellaris">www.ti.com/stellaris</a>: - Stellaris LM3S9D96 Microcontroller Data Sheet - Kitronix LCD Data Sheet - StellarisWare Driver Library - StellarisWare Driver Library User's Manual, publication number SW-DRL-UG #### Additional references include: - FT2232D Dual USB/UART FIFO IC Data sheet, version 0.91, 2006, Future Technology Devices International Ltd. - Texas Instruments TLV320AIC23BPM Audio CODEC Data Sheet - Information on development tool being used: - RealView MDK web site, www.keil.com/arm/rvmdkkit.asp - IAR Embedded Workbench web site, www.iar.com - Sourcery CodeBench development tools web site, www.codesourcery.com/gnu\_toolchains/arm - Code Red Technologies development tools web site, www.code-red-tech.com - Texas Instruments' Code Composer Studio™ IDE web site, www.ti.com/ccs #### IMPORTANT NOTICE Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment. TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed. TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards. TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI. Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions. Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements. TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications. TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use. TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements. Following are URLs where you can obtain information on other Texas Instruments products and application solutions: | Products | | Applications | | |-----------------------------|------------------------|----------------------------------|-----------------------------------| | Audio | www.ti.com/audio | Communications and Telecom | www.ti.com/communications | | Amplifiers | amplifier.ti.com | Computers and Peripherals | www.ti.com/computers | | Data Converters | dataconverter.ti.com | Consumer Electronics | www.ti.com/consumer-apps | | DLP® Products | www.dlp.com | Energy and Lighting | www.ti.com/energy | | DSP | dsp.ti.com | Industrial | www.ti.com/industrial | | Clocks and Timers | www.ti.com/clocks | Medical | www.ti.com/medical | | Interface | interface.ti.com | Security | www.ti.com/security | | Logic | logic.ti.com | Space, Avionics and Defense | www.ti.com/space-avionics-defense | | Power Mgmt | power.ti.com | Transportation and<br>Automotive | www.ti.com/automotive | | Microcontrollers | microcontroller.ti.com | Video and Imaging | www.ti.com/video | | RFID | www.ti-rfid.com | Wireless | www.ti.com/wireless-apps | | RF/IF and ZigBee® Solutions | www.ti.com/lprf | | | Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2011, Texas Instruments Incorporated e2e.ti.com **TI E2E Community Home Page**