

# **External Memory Interface (EMIF)**

1.10

### **Features**

- 8-, 16-, 24-bit address bus width
- 8-, 16-bit data bus width
- Supports external synchronous memory
- Supports external asynchronous memory
- Supports custom interface for memory
- Supports a range of speeds of external memories (from 5 to 200 ns)
- Supports external memory power-down, sleep, and wakeup modes





# **General Description**

The EMIF component enables access by the CPU or DMA to memory ICs external to the PSoC 3. It facilitates setup of the EMIF hardware, as well as UDBs and GPIOs as required. The EMIF can control synchronous and asynchronous memories without the need to configure any UDBs in synchronous and asynchronous modes. In UDB mode, UDBs must be configured to generate external memory control signals.

#### When to Use an EMIF

The EMIF is used to expand available memory space. This allows for expanded data storage in off-chip memory devices. External memory ICs connected to a PSoC 3 are typically intended to hold large arrays of data, such as text, audio, or video content. Other expected applications include data logging and use as a buffer for external LCD pixel data.

# **Input/Output Connections**

This section describes the various input and output connections for the EMIF. An asterisk (\*) in the list of I/Os states that the I/O may be hidden on the symbol under the conditions listed in the description of that I/O.

### udb\_ready - Input\*

Signal from external logic, indicating to PHUB that the AHB bus transaction is complete (active high). This input is visible when the **External Memory Type** parameter is set to **Custom**.

#### xmem\_wr - Output\*

Generic write signal to custom interface (active high). Signal from external logic, indicating to PHUB that the AHB bus transaction is complete (active high). This output is visible when the **External Memory Type** parameter is set to **Custom**.

#### xmem\_rd - Output\*

Generic read signal to custom interface (active high). This output is visible when the **External Memory Type** parameter is set to **Custom**.

#### cen - Output\*

Chip enable to external memory (active low). This output is visible when the **External Memory Type** parameter is set to **Synchronous** or **Asynchronous**.

### wen - Output\*

Write enable to external memory (active low). This output is visible when the **External Memory Type** parameter is set to **Synchronous** or **Asynchronous**.

# oen - Output\*

Output enable to external memory (active low). This output is visible when the **External Memory Type** parameter is set to **Synchronous** or **Asynchronous**.

### mem\_clk - Output\*

Clock to external synchronous memory. This output is visible when the **External Memory Type** parameter is set to **Synchronous**.

# adscn - Output\*

Address strobe to external synchronous memory (active low). This output is visible when the **External Memory Type** parameter is set to **Synchronous**.



### mem\_sleep - Output\*

Sleep signal to external synchronous memory sleep pin (active high). This output is visible when the **External Memory Type** parameter is set to **Synchronous**.

### **Schematic Macro Information**

By default, the PSoC Creator Component Catalog contains schematic macro implementations for the EMIF component. These macros contain already connected output pins. Schematic macros are available both for asynchronous External Memory Interface and synchronous External Memory Interface.

Figure 1. Asynchronous External Memory Interface Schematic Macro



Figure 2. Synchronous External Memory Interface Schematic Macro





Document Number: 001-67707 Rev. \*B Page 3 of 15

# **Component Parameters**

Drag an EMIF onto your design and double click it to open the **Configure** dialog.

Figure 3. Configure EMIF Dialog



The EMIF provides the following parameters:

# **External Memory Type**

Determines external memory type. Default external memory type is **Asynchronous**.

# Address Width (bits)

Determines the number of bits in the address bus for external memory. The default address bus width is **24 bits**.

### Data Width (bits)

Determines the number of bits in the data bus for external memory. The default data bus width is **16 bits**.



Page 4 of 15 Document Number: 001-67707 Rev. \*B

### **External Memory Speed (ns)**

Determines external memory speed in ns. The default external memory speed is 30 ns.

### **Bus Clock Frequency**

Shows the selected Bus Clock frequency in megahertz.

### **Memory Transactions**

- Write Cycle Length Shows the write cycle length in nanoseconds. The Bus Clock frequency cycles are shown in parentheses.
- **Read Cycle Length** Shows the read cycle length in the nanoseconds. The Bus Clock frequency cycles are shown in parentheses.
- Signal wen Pulse Width (Twel) Shows the Twel parameter (write enable signal pulse width) in nanoseconds. See the DC and AC Electrical Characteristics section for details.
- Signal oen Pulse Width (Toel) Shows the Toel parameter (write enable signal pulse width) in nanoseconds. See the DC and AC Electrical Characteristics section for details.

# **Application Programming Interface**

Application Programming Interface (API) routines allow you to configure the component using software. The following table lists and describes the interface to each function. The subsequent sections cover each function in more detail.

By default, PSoC Creator assigns the instance name "EMIF\_1" to the first instance of a component in a given design. You can rename it to any unique value that follows the syntactic rules for identifiers. The instance name becomes the prefix of every global function name, variable, and constant symbol. For readability, the instance name used in the following table is "EMIF."

| Function            | Description                                                                                                                                |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| EMIF_Start()        | Calls EMIF_Init() and EMIF_Enable().                                                                                                       |
| EMIF_Stop()         | Disables the EMIF block. Returns all associated I/O ports and pins to HI-Z mode                                                            |
| EMIF_Init()         | Initializes or restores the EMIF configuration to the current customizer state                                                             |
| EMIF_Enable()       | Enables the EMIF hardware block, associated I/O ports and pins                                                                             |
| EMIF_ExtMemSleep()  | Sets the external memory sleep signal high; note that depending on the type of external memory IC used, the signal may need to be inverted |
| EMIF_ExtMemWakeup() | Sets the external memory sleep signal low; note that depending on the type of external memory IC used, the signal may need to be inverted  |
| EMIF_SaveConfig()   | Saves the user configuration of the EMIF nonretention registers. This routine is called                                                    |



Document Number: 001-67707 Rev. \*B Page 5 of 15

| Function             | Description                                                                                                                                                           |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | by EMIF_Sleep() to save the component configuration before entering sleep                                                                                             |
| EMIF_Sleep()         | Stops the EMIF operation and saves the user configuration along with the enable state of the EMIF                                                                     |
| EMIF_RestoreConfig() | Restores the user configuration of the EMIF nonretention registers. This routine is called by EMIF_Wakeup() to restore the component configuration when exiting sleep |
| EMIF_Wakeup()        | Restores the user configuration and restores the enable state                                                                                                         |

### void EMIF\_Start(void)

**Description:** This is the preferred method to begin component operation. EMIF\_Start() calls the

EMIF\_Init() function, and then calls the EMIF\_Enable() function.

Parameters: None
Return Value: None
Side Effects: None

### void EMIF\_Stop(void)

**Description:** Disables the EMIF block. Returns all associated I/O ports and pins to HI-Z mode

Parameters: None
Return Value: None
Side Effects: None

### void EMIF\_Init(void)

**Description:** Initializes or restores the component according to the customizer Configure dialog settings. It

is not necessary to call EMIF\_Init() because the EMIF\_Start() routine calls this function and

is the preferred method to begin component operation.

Parameters: None
Return Value: None
Side Effects: None



### void EMIF\_Enable(void)

Description: Activates the hardware and begins component operation. It is not necessary to call

EMIF\_Enable() because the EMIF\_Start() routine calls this function, which is the preferred

method to begin component operation.

Parameters: None
Return Value: None
Side Effects: None

### void EMIF\_ExtMemSleep(void)

**Description:** Sets the 'mem\_pd' bit in the EMIF\_PWR\_DWN register. This sets the external memory sleep

signal high. Depending on the type of external memory IC used, the signal may need to be

inverted.

Parameters: None
Return Value: None
Side Effects: None

### void EMIF ExtMemWakeup(void)

**Description:** Resets the 'mem\_pd' bit in the EMIF\_PWR\_DWN register. This sets the external memory

sleep signal low. Depending on the type of external memory IC used, the signal may need to

be inverted

Parameters: None
Return Value: None
Side Effects: None

# void EMIF\_SaveConfig(void)

**Description:** This function saves the component configuration. This will save nonretention registers. This

function will also save the current component parameter values, as defined in the Configure dialog or as modified by appropriate APIs. This function is called by the EMIF Sleep()

function.

Parameters: None
Return Value: None
Side Effects: None



### void EMIF\_Sleep(void)

**Description:** This is the preferred routine to prepare the component for sleep. The EMIF\_Sleep() routine

saves the current component state. Then it calls the EMIF\_Stop() function and calls

EMIF\_SaveConfig() to save the hardware configuration.

Call the EMIF\_Sleep() function before calling the CyPmSleep() or the CyPmHibernate() function. Refer to the PSoC Creator *System Reference Guide* for more information about

power management functions.

Parameters: None
Return Value: None
Side Effects: None

### void EMIF\_RestoreConfig(void)

**Description:** This function restores the component configuration. This will restore nonretention registers.

This function will also restore the component parameter values to what they were prior to

calling the EMIF Sleep() function.

Parameters: None Return Value: None

Side Effects: Calling this function without first calling the EMIF\_Sleep() or EMIF\_SaveConfig() function

may produce unexpected behavior.

### void EMIF\_Wakeup(void)

**Description:** This is the preferred routine to restore the component to the state when EMIF Sleep() was

called. The EMIF\_Wakeup() function calls the EMIF\_RestoreConfig() function to restore the configuration. If the component was enabled before the EMIF\_Sleep() function was called,

the EMIF Wakeup() function will also re-enable the component.

Parameters: None Return Value: None

Side Effects: Calling the EMIF\_Wakeup() function without first calling the EMIF\_Sleep() or

EMIF SaveConfig() function may produce unexpected behavior.

#### **Defines**

**CYDEV EXTMEM BASE –** Convenience macro for locating parameters in external memory.



# **External memory interface Address Map**

PSoC3 External memory interface XDATA Data Address Map

Address Range:

0×800000 - 0×FFFFF

**PSoC 5LP External memory interface Memory Address Map** 

Address Range:

0x60000000 - 0x61FFFFF

# **Sample Firmware Source Code**

PSoC Creator provides numerous example projects that include schematics and example code in the Find Example Project dialog. For component-specific examples, open the dialog from the Component Catalog or an instance of the component in a schematic. For general examples, open the dialog from the Start Page or **File** menu. As needed, use the **Filter Options** in the dialog to narrow the list of projects available to select.

Refer to the "Find Example Project" topic in the PSoC Creator Help for more information.

# **Functional Description**

This component, and PSoC Creator in general, does not provide any direct support for locating code, variables, structures, or arrays in external memory. However, there is nothing in either this component or in PSoC Creator that prevents an advanced user from creating or modifying source code, a linker script, or any other source file, for that purpose.

Initialized variables should not be placed in external memory. Do not locate code, variables, structures, and arrays autogenerated by PSoC Creator in external memory.

The PSoC 3 EMIF hardware and associated GPIO ports support up to a 24-bit address bus, and an 8-bit or 16-bit data bus.

External memories require up to six GPIO ports to connect address, data, and control lines: one to three ports for address, one to two for data, and one for control. For address and data, the entire port must be selected. Unused pins in the control port are still available as GPIOs.

When an EMIF component is placed onto the project schematic, it is important that I/O port designations be set for address and data. Designation of address and data ports is not done on the symbol or schematic; instead, it is done in the Pins tab of the Design-Wide Resources window. Control signals are shown on the component symbol as terminals; the terminals should be routed to Pin components in the usual manner.



Document Number: 001-67707 Rev. \*B Page 9 of 15

There are three EMIF types – asynchronous, synchronous, or (rarely used) custom. The type selected determines the size of the symbol, the number of terminals in the symbol, and some of the text in the symbol. The custom version of the component is the only one with an input terminal, udb\_ready. It is expected that the xmem\_wr and xmem\_rd signals will be tied to UDB-based logic which will both generate appropriate control signals to the external IC, and provide a feedback signal back to the PHUB via the udb\_ready terminal. It is up to you to determine appropriate timing for custom mode signals.

#### Resources

The External Memory Interface (EMIF) is a dedicated piece of hardware in the PSoC 3 and PSoC 5LP that is used in conjunction with UDBs to allow connection to external memory devices.

# **API Memory Usage**

The component memory usage varies significantly, depending on the compiler, device, number of APIs used and component configuration. The following table provides the memory usage for all APIs available in the given component configuration.

The measurements have been done with the associated compiler configured in Release mode with optimization set for Size. For a specific design the map file generated by the compiler can be analyzed to determine the memory usage.

|               | PSoC 3 (Keil_PK51) |               | PSoC 5 (GCC)   |               | PSoC 5LP (GCC) |               |
|---------------|--------------------|---------------|----------------|---------------|----------------|---------------|
| Configuration | Flash<br>Bytes     | SRAM<br>Bytes | Flash<br>Bytes | SRAM<br>Bytes | Flash<br>Bytes | SRAM<br>Bytes |
| Asynchronous  | 168                | 2             | N/A            | N/A           | 204            | 5             |
| Synchronous   | 185                | 2             | N/A            | N/A           | 236            | 5             |
| Custom        | 154                | 2             | N/A            | N/A           | 188            | 5             |

# DC and AC Electrical Characteristics

Specifications are valid for  $-40~^{\circ}\text{C} \le T_{A} \le 85~^{\circ}\text{C}$  and  $T_{J} \le 100~^{\circ}\text{C}$ , except where noted. Specifications are valid for 1.71 V to 5.5 V, except where noted.

CYPRESS

Page 10 of 15 Document Number: 001-67707 Rev. \*B

Figure 4. Asynchronous Read Cycle Timing



| Symbol | Description                         | Conditions               | Min    | Тур | Max    | Unit |
|--------|-------------------------------------|--------------------------|--------|-----|--------|------|
| Т      | EMIF clock period                   | V <sub>DDA</sub> ≥ 3.3 V | 30.3   | -   | -      | ns   |
| Tcel   | EM_CEn low time                     |                          | 2T – 5 | -   | 2T + 5 | ns   |
| Taddrv | EM_CEn low to EM_Addr valid         |                          | -      | -   | 5      | ns   |
| Taddrh | Address hold time after EM_WEn high |                          | Т      | -   | -      | ns   |
| Toel   | EM_OEn low time                     |                          | 2T – 5 | -   | 2T + 5 | ns   |
| Tdoesu | Data to EM_OEn high setup time      |                          | T + 15 | -   | -      | ns   |
| Tdoeh  | Data hold time after EM_OEn high    |                          | 3      | -   | -      | ns   |



Document Number: 001-67707 Rev. \*B Page 11 of 15

Figure 5. Asynchronous Write Cycle Timing



| Symbol | Description                         | Conditions               | Min   | Тур | Max   | Unit |
|--------|-------------------------------------|--------------------------|-------|-----|-------|------|
| Т      | EMIF clock period                   | V <sub>DDA</sub> ≥ 3.3 V | 30.3  | -   | -     | ns   |
| Tcel   | EM_CEn low time                     |                          | T – 5 | -   | T + 5 | ns   |
| Taddrv | EM_CEn low to EM_Addr valid         |                          | -     | -   | 5     | ns   |
| Taddrh | Address hold time after EM_WEn high |                          | Т     | -   | -     | ns   |
| Twel   | EM_WEn low time                     |                          | T – 5 | -   | T + 5 | ns   |
| Tdcev  | EM_CEn low to data valid            |                          | -     | -   | 7     | ns   |
| Tdweh  | Data hold time after EM_WEn high    |                          | Т     | 1   | ı     | ns   |



Page 12 of 15 Document Number: 001-67707 Rev. \*B

Figure 6. Synchronous Read Cycle Timing



| Symbol  | Description                      | Conditions               | Min     | Тур | Max | Unit |
|---------|----------------------------------|--------------------------|---------|-----|-----|------|
| Т       | EMIF clock period                | V <sub>DDA</sub> ≥ 3.3 V | 30.3    | ı   | ı   | ns   |
| Tcp/2   | EM_Clock pulse high              |                          | T/2     | ı   | ı   | ns   |
| Tceld   | EM_CEn low to EM_Clock high      |                          | 5       | -   | -   | ns   |
| Tcehd   | EM_Clock high to EM_CEn high     |                          | T/2 – 5 | -   | -   | ns   |
| Taddrv  | EM_Addr valid to EM_Clock high   |                          | 5       | ı   | ı   | ns   |
| Taddriv | EM_Clock high to EM_Addr invalid |                          | T/2 – 5 | ı   | ı   | ns   |
| Toeld   | EM_OEn low to EM_Clock high      |                          | 5       | ı   | ı   | ns   |
| Toehd   | EM_Clock high to EM_OEn high     |                          | Т       | -   | -   | ns   |
| Tds     | Data valid before EM_OEn high    |                          | T + 15  | -   | -   | ns   |
| Tadscld | EM_ADSCn low to EM_Clock high    |                          | 5       | ı   | -   | ns   |
| Tadschd | EM_Clock high to EM_ADSCn high   |                          | T/2 – 5 | ı   | -   | ns   |



Document Number: 001-67707 Rev. \*B Page 13 of 15

Figure 7. Synchronous Write Cycle Timing



| Symbol  | Description                      | Conditions               | Min     | Тур | Max | Unit |
|---------|----------------------------------|--------------------------|---------|-----|-----|------|
| Т       | EMIF clock period                | V <sub>DDA</sub> ≥ 3.3 V | 30.3    | -   | -   | ns   |
| Tcp/2   | EM_Clock pulse high              |                          | T/2     | -   | -   | ns   |
| Tceld   | EM_CEn low to EM_Clock high      |                          | 5       | -   | -   | ns   |
| Tcehd   | EM_Clock high to EM_CEn high     |                          | T/2 – 5 | -   | -   | ns   |
| Taddrv  | EM_Addr valid to EM_Clock high   |                          | 5       | -   | -   | ns   |
| Taddriv | EM_Clock high to EM_Addr invalid |                          | T/2 – 5 | -   | -   | ns   |
| Tweld   | EM_WEn low to EM_Clock high      |                          | 5       | -   | -   | ns   |
| Twehd   | EM_Clock high to EM_WEn high     |                          | T/2 – 5 | -   | -   | ns   |
| Tds     | Data valid before EM_Clock high  |                          | 5       | -   | -   | ns   |
| Tdh     | Data invalid after EM_Clock high |                          | Т       | -   | -   | ns   |
| Tadscld | EM_ADSCn low to EM_Clock high    |                          | 5       | -   | -   | ns   |
| Tadschd | EM_Clock high to EM_ADSCn high   |                          | T/2 – 5 | -   | -   | ns   |



Page 14 of 15 Document Number: 001-67707 Rev. \*B

# **Component Changes**

| Version | Description of Changes                            | Reason for Changes / Impact |
|---------|---------------------------------------------------|-----------------------------|
| 1.10 b  | Updated EMIF data sheet with EMIF memory map info |                             |
| 1.10    | Added PSoC 5LP support.                           |                             |

© Cypress Semiconductor Corporation, 2012. The information contained herein is subject to change without notice. Cypress Semiconductor Corporation assumes no responsibility for the use of any circuitry other than circuitry embodied in a Cypress product. Nor does it convey or imply any license under patent or other rights. Cypress products are not warranted nor intended to be used for medical, life support, life saving, critical control or safety applications, unless pursuant to an express written agreement with Cypress. Furthermore, Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress products in life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges.

CyDesigner™, Programmable System-on-Chip™, and PSoC Express™ are trademarks and PSoC® is a registered trademark of Cypress Semiconductor Corp. All other trademarks or registered trademarks referenced herein are property of the respective corporations.

Any Source Code (software and/or firmware) is owned by Cypress Semiconductor Corporation (Cypress) and is protected by and subject to worldwide patent protection (United States and foreign), United States copyright laws and international treaty provisions. Cypress hereby grants to licensee a personal, non-exclusive, non-transferable license to copy, use, modify, create derivative works of, and compile the Cypress Source Code and derivative works for the sole purpose of creating custom software and or firmware in support of licensee product to be used only in conjunction with a Cypress integrated circuit as specified in the applicable agreement. Any reproduction, modification, translation, compilation, or representation of this Source Code except as specified above is prohibited without the express written permission of Cypress.

Disclaimer: CYPRESS MAKES NO WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, WITH REGARD TO THIS MATERIAL, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. Cypress reserves the right to make changes without further notice to the materials described herein. Cypress does not assume any liability arising out of the application or use of any product or circuit described herein. Cypress does not authorize its products for use as critical components in life-support systems where a malfunction or failure may reasonably be expected to result in significant injury to the user. The inclusion of Cypress' product in a life-support systems application implies that the manufacturer assumes all risk of such use and in doing so indemnifies Cypress against all charges.

Use may be limited by and subject to the applicable Cypress software license agreement.



Document Number: 001-67707 Rev. \*B Page 15 of 15