White Paper Using the MAX II altufm Megafunction I 2 C Interface

Similar documents
AN 547: Putting the MAX II CPLD in Hibernation Mode to Achieve Zero Standby Current

GT24C02. 2-Wire. 2Kb Serial EEPROM (Smart Card application)

DS1845 Dual NV Potentiometer and Memory

GT34C02. 2Kb SPD EEPROM

ORDERING INFORMATION. OPERATION Measuring Temperature A block diagram of the DS1621 is shown in Figure 1. DESCRIPTION ORDERING PACKAGE

GT24C256 2-WIRE. 256K Bits. Serial EEPROM

Excalibur Solutions Using the Expansion Bus Interface. Introduction. EBI Characteristics

GT24C WIRE. 1024K Bits. Serial EEPROM

User Flash Memory (ALTUFM) Megafunction User Guide

Using MAX II & MAX 3000A Devices as a Microcontroller I/O Expander

DS1855 Dual Nonvolatile Digital Potentiometer and Secure Memory

DS1682 Total-Elapsed-Time Recorder with Alarm

MAX 10 User Flash Memory User Guide

DS1625. Digital Thermometer and Thermostat FEATURES PIN ASSIGNMENT

DS WIRE INTERFACE 11 DECOUPLING CAP GND

SILICON MICROSTRUCTURES

FM24C02A 2-Wire Serial EEPROM

2-wire Serial EEPROM Smart Card Modules AT24C32SC AT24C64SC

Using the Nios Development Board Configuration Controller Reference Designs

ACE24C512C Two-wire serial EEPROM

Using MAX 3000A Devices as a Microcontroller I/O Expander

Two-wire Serial EEPROM Smart Card Modules 128K (16,384 x 8) 256 (32,768 x 8) AT24C128SC AT24C256SC. Features. Description VCC NC

FM24C02B/04B/08B/16B 2-Wire Serial EEPROM

Estimating Nios Resource Usage & Performance

Fremont Micro Devices, Inc.

Excalibur Solutions DPRAM Reference Design

DS1846 NV Tri-Potentiometer, Memory, and MicroMonitor

Intel MAX 10 User Flash Memory User Guide

AIRbus Interface. Features Fixed width (8-, 16-, or 32-bit) data transfers (dependent on the width. Functional Description. General Arrangement

Matrices in MAX II & MAX 3000A Devices

Two-wire Serial EEPROM Smart Card Modules 1K (128 x 8) 2K (256 x 8) 4K (512 x 8) 8K (1024 x 8) 16K (2048 x 8)

Using the Serial FlashLoader With the Quartus II Software

24C08/24C16. Two-Wire Serial EEPROM. Preliminary datasheet 8K (1024 X 8)/16K (2048 X 8) General Description. Pin Configuration

White Paper. Floating-Point FFT Processor (IEEE 754 Single Precision) Radix 2 Core. Introduction. Parameters & Ports

Nios II Embedded Design Suite 6.1 Release Notes

White Paper Configuring the MicroBlaster Passive Serial Software Driver

FM24C Kb FRAM Serial Memory Features

Active Serial Memory Interface

2-wire Serial EEPROM AT24C512. Preliminary. 2-Wire Serial EEPROM 512K (65,536 x 8) Features. Description. Pin Configurations.

Table 1 shows the issues that affect the FIR Compiler v7.1.

PCA9560 Dual 5-bit multiplexed 1-bit latched I 2 C EEPROM DIP switch

Nios Soft Core Embedded Processor

DDR and DDR2 SDRAM Controller Compiler User Guide

Stratix FPGA Family. Table 1 shows these issues and which Stratix devices each issue affects. Table 1. Stratix Family Issues (Part 1 of 2)

GT24C64 2-WIRE. 64K Bits. Serial EEPROM

DDR & DDR2 SDRAM Controller Compiler

altufm Megafunction 101 Innovation Drive San Jose, CA (408)

ZBT SRAM Controller Reference Design

DS1624 Digital Thermometer and Memory

DS1676 Total Elapsed Time Recorder, Erasable

Digital Thermometer and Thermostat

Introduction. Synchronous vs. Asynchronous Memory. Converting Memory from Asynchronous to Synchronous for Stratix & Stratix GX Designs

Preliminary Data MOS IC. Type Ordering Code Package SDA Q67100-H5092 P-DIP-8-1

FM24CL04 4Kb FRAM Serial Memory

Error Correction Code (ALTECC_ENCODER and ALTECC_DECODER) Megafunctions User Guide

2-Wire, 5-Bit DAC with Three Digital Outputs

Enhanced Configuration Devices

Stratix II FPGA Family

GT24C32A 2-WIRE. 32K Bits. Serial EEPROM

Simple Excalibur System

Digital Thermometer and Thermostat in SOT23

White Paper AHB to Avalon & Avalon to AHB Bridges

Designing with ESBs in APEX II Devices

TOP VIEW CLOCK GENERATOR A1 A2 GND CPU SPEED SELECT

FM24C16B-GTR. 16Kb Serial 5V F-RAM Memory. Features. Pin Configuration. Description. Ordering Information NC NC NC VSS VDD WP SCL SDA.

FM24C1024A. Apr Data Sheet. Data Sheet FM24C1024A 2-wrie Serial EEPROM Ver 1.1 1

Implementing LED Drivers in MAX and MAX II Devices. Introduction. Commercial LED Driver Chips

Preliminary Data MOS IC. Type Ordering Code Package SDA Q67100-H5096 P-DIP-8-1

DS Wire Digital Thermometer and Thermostat

DDR & DDR2 SDRAM Controller Compiler

DSP Builder. DSP Builder v6.1 Issues. Error When Directory Pathname is a Network UNC Path

DDR & DDR2 SDRAM Controller Compiler

E3 Mapper MegaCore Function (E3MAP)

DS 1682 Total Elapsed Time Recorder with Alarm

Legacy SDRAM Controller with Avalon Interface

Implementing PLL Reconfiguration in Stratix & Stratix GX Devices

2-wire Serial EEPROM AT24C01A AT24C02 AT24C04 AT24C08 AT24C16

Digital Thermometer and Thermostat

Design Verification Using the SignalTap II Embedded

DS75 Digital Thermometer and Thermostat

ACE24AC128 Two-wire Serial EEPROM

Cyclone II FPGA Family

ACE24AC64 Two-wire Serial EEPROM

DS1852 Optical Transceiver Diagnostic Monitor

DS1631/DS1631A/DS1731 High-Precision Digital Thermometer and Thermostat

FM24C16C-GTR. 16Kb Serial 5V F-RAM Memory. Features. Description. Pin Configuration NC NC NC VSS VDD WP SCL SDA. Ordering Information.

RapidIO MegaCore Function

LE24512AQF. Overview. Functions. CMOS IC Two Wire Serial Interface EEPROM (512k EEPROM)

On-Chip Memory Implementations

Introduction. Design Hierarchy. FPGA Compiler II BLIS & the Quartus II LogicLock Design Flow

Video and Image Processing Suite

PART IN+ IN- TX_DISABLE TX_FAULT BIAS SET BIASMAX 2 APCSET 2 MODSET 2 MOD SET PC_MON BS_MON

2-wire Serial EEPROM AT24C512

Implementing LED Drivers in MAX Devices

LE2464DXA 64 kb I 2 C CMOS Serial EEPROM

POS-PHY Level 4 MegaCore Function

2-wire Serial EEPROMs AT24C128 AT24C256. Features. Description. Pin Configurations. 128K (16,384 x 8) 256K (32,768 x 8)

ACE24AC16B Two-wire Serial EEPROM

BL24C02/BL24C04/BL24C08/BL24C16

POS-PHY Level 4 POS-PHY Level 3 Bridge Reference Design

Transcription:

White Paper Using the MAX II altufm Megafunction I 2 C Interface Introduction Inter-Integrated Circuit (I 2 C) is a bidirectional two-wire interface protocol, requiring only two bus lines; a serial data/address line (SDA), and a serial clock line (SCL). Each device connected to the I 2 C bus is software addressable by a unique address. The I 2 C bus is a multi-master bus where more than one integrated circuit (IC) capable of initiating a data transfer can be connected to it, which allows masters to function as transmitters or receivers. The altufm_i2c megafunction features a serial, 8-bit bidirectional data transfer up to 100 Kbits per second. With the altufm_i2c megafunction, the MAX II user flash memory (UFM) and logic can be configured as a slave device for the I 2 C bus. The altufm megafunction s I 2 C interface is designed to function similar to I 2 C serial EEPROMs. The Quartus II software supports three different memory sizes: (128 8) 1 Kbits (256 8) 2 Kbits (512 8) 4 Kbits f For more information on the MAX II UFM features, refer to the Using User Flash Memory in MAX II Devices chapter of the MAX II Handbook. I 2 C Protocol The following defines the characteristics of the I 2 C bus protocol: Only two bus lines are required; SDA and SCL. Both SDA and SCL are bidirectional lines which remain high when the bus is free. Data transfer may be initiated only when the bus is free. The data on the SDA line must be stable during the high period of the clock. The high or low state of the data line can only change when the clock signal on the SCL line is low. Any transition on the SDA line while the SCL is high is one such unique case which indicates a start or stop condition. Table 1 summarizes the altufm_i2c megafunction input and output interface signals. Table 1. altufm_i2c Interface Signals Pin Description Function SDA Serial Data/Address Line The bidirectional SDA port is used to transmit and receive serial data from the UFM. The output stage of the SDA port is configured as an open drain pin to perform the wired-and function. SCL Serial Clock Line The bidirectional SCL port is used to synchronize the serial data transfer to and from the UFM. The output stage of the SCL port is configured as an open drain pin to perform a wired-and function. WP Write Protect Optional active high signal that disables the erase and write function for read/write mode. The altufm_i2c megafunction gives you an option to protect the entire UFM memory or only the upper half of memory. A 2, A 1, A 0 Slave Address Input These inputs set the UFM slave address. The A 6, A 5, A 4, A 3 slave address bits are programmable, set internally to 1010 by default. WP-M212C012405-1.0 February 2005, ver. 1.0 1

START & STOP Condition The master always generates start (S) and stop (P) conditions. After the start condition, the bus is considered busy. Only a stop (P) condition frees the bus. The bus stays busy if the repeated start (Sr) condition is executed instead of a stop condition. In this occurrence, the start (S) and repeated start (Sr) conditions are functionally identical. A high-to-low transition on the SDA line while the SCL is high indicates a start condition. A low-to-high transition on the SDA line while the SCL is high indicates a stop condition. Figure 1 shows the start and stop conditions. Figure 1. Start & Stop Conditions SDA SDA SCL S P SCL Start Condition Stop Condition Acknowledge Acknowledged data transfer is a requirement of I 2 C. The master must generate a clock pulse to signify the acknowledge bit. The transmitter releases the SDA line (high) during the acknowledge clock pulse. The receiver (slave) must pull the SDA line low during the acknowledge clock pulse so that SDA remains a stable low during the clock high period, indicating positive acknowledgement from the receiver. If the receiver pulls the SDA line high during the acknowledge clock pulse, the receiver sends a not-acknowledge condition indicating that it is unable to process the last byte of data. If the receiver is busy (e.g., executing an internally-timed erase or write operation), it will not acknowledge any new data transfer. Figure 2 shows the acknowledge condition on the I 2 C bus. Figure 2. Acknowledge on the I 2 C Bus Data Output By Transmitter Data Output By Receiver Not Acknowledge Acknowledge SCL From Master S Start Condition Clock Pulse For Acknowledgement 2

Device Addressing After the start condition, the master sends the address of the particular slave device it is requesting. The four most significant bits (MSBs) of the 8-bit slave address are usually fixed while the next three significant bits (A 2, A 1, A 0 ) are device address bits and define which device the master is accessing. The last bit of the slave address specifies whether a read or write operation is to be performed. When this bit is set to 1, a read operation is selected. When set to 0, a write operation is selected. The four MSBs of the slave address (A 6, A 5, A 4, A 3 ) are programmable and can be defined on the Page 3 of the altufm MegaWizard Plug-In Manager. The default value for these four MSBs is 1010. The next three significant bits are defined using the three A 2, A 1, A 0 input ports of the altufm_i2c megafunction. You can connect these ports to input pins in the design file and connect them to switches on the board. The other option is to connect them to V CC and GND primitives in the design file, which conserves pins. Figure 3 shows the slave address bits. Figure 3. Slave Address Bits 1- or 2-Kbit Memory Size MSB 1 LSB 0 1 0 A 2 A 1 A 0 R/W 4-Kbit Memory Size MSB 1 LSB 0 1 0 A 2 A 1 a8 R/W Note to Figure 3: (1) For the 4-Kbit memory size, the A0 location in the slave address becomes the MSB (a8) of the memory byte address. After the master sends a start condition and the slave address byte, the altufm_i2c logic monitors the bus and responds with an acknowledge (on the SDA line) when its address matches the transmitted slave address. The altufm_i2c megafunction then performs a read or write operation to/from the UFM, depending on the state of the bit. Byte Write Operation The master initiates a transfer by generating a start condition, then sending the correct slave address (with the R/W bit set to 0) to the slave. If the slave address matches, the altufm_i2c slave acknowledges on the ninth clock pulse. The master then transfers an 8-bit byte address to the UFM, which acknowledges the reception of the address. The master transfers the 8-bit data to be written to the UFM. Once the altufm_i2c logic acknowledges the reception of the 8-bit data, the master generates a stop condition. The internal write from the MAX II logic array to the UFM begins only after the master generates a stop condition. While the UFM internal write cycle is in progress, the altufm_i2c logic ignores any attempt made by the master to initiate a new transfer. Figure 4 shows the Byte Write sequence. Figure 4. Byte Write Sequence S Slave Address R/W A Byte Address A Data A P S Start Condition P Stop Condition A Acknowledge "0" (write) From Master to Slave From Slave to Master 3

Altera Corporation A write operation is only possible on an erased UFM block or word location. The UFM block differs from serial EEPROMs requiring an erase operation prior to writing new data in the UFM block. A special erase sequence is required, as discussed in Erase Operation on page 4. Acknowledge Polling The master can detect whether the internal write cycle is completed by polling for an acknowledgement from the slave. The master can resend the start condition together with the slave address as soon as the byte write sequence is finished. The slave does not acknowledge if the internal write cycle is still in progress. The master can repeat the acknowledge polling and can proceed with the next instruction after the slave acknowledges. 1 Page write operation is not supported in the current version of the altufm_i2c megafunction, but will be supported in a future version. Write Protection The altufm_i2c megafunction includes an optional Write Protection (WP) port available on page 4 of the altufm MegaWizard Plug-In Manager (see Figure 14 on page 11). In the MegaWizard Plug-In Manager, you can choose the WP port to protect either the full or upper half memory. When WP is set to 1, the upper half or the entire memory array (depending on the memory size selected) is protected, and the write and erase operation is not allowed. In this case the altufm_i2c megafunction acknowledges the slave address and memory address. After the master transfers the first data byte, the altufm_i2c megafunction sends a not-acknowledge condition to the master to indicate that the instruction will not execute. When WP is set to 0, the write and erase operations are allowed. Erase Operation Commercial serial EEPROMs automatically erase each byte of memory before writing into that particular memory location during a write operation. However, the MAX II UFM block is flash based and only supports sector erase operations and not byte erase operations. When using read/write mode, a sector or full memory erase operation is required before writing new data into any location that previously contained data. The block cannot be erased when the altufm_i2c megafunction is in read-only mode. Data can be initialized into memory for read/write and read-only modes by including a memory initialization file (.mif) or hexidecimal file (.hex) in the altufm MegaWizard Plug-In Manager. This data is automatically written into the UFM during device programming by the Quartus II software or third-party programming tool. The altufm_i2c megafunction supports four different erase operation methods shown on page 4 of the altufm MegaWizard Plug-In Manager: Address Triggered) Sector Erase (A2 Triggered) No Erase These erase options only work as described if that particular option is selected in the MegaWizard Plug-In Manager before compiling the design files and programming the device. Only one option is possible for the UFM. Erase options are discussed in more detail in the following sections. 4

The full erase option uses the A 2, A 1, A 0 bits of the slave address to distinguish between an erase or read/write operation. This slave operation decoding occurs when the master transfers the slave address to the slave after generating the start condition. If the A 2, A 1, and A 0 slave address bits transmitted to the UFM slave equals 111 and the four remaining MSBs match the rest of the slave addresses, then the Full Erase operation is selected. If the A 6, A 5, A 4, A 3 A 2, A 1, and A 0 slave address bits transmitted to the UFM match its unique slave address setting, the read/write operation is selected and functions as expected. As a result, this erase option utilizes two slave addresses on the bus reserving A 6, A 5, A 4, A 3, 1, 1, 1 as the erase trigger. Both sectors of the UFM block will be erased when the Full Erase operation is executed. This operation requires acknowledge polling. The internal UFM erase function only begins after the master generates a stop condition. Figure 5 shows the full erase sequence triggered by using the slave address. If the memory is write-protected (WP = 1), the slave does not acknowledge the erase trigger slave address (A 6, A 5, A 4, A 3, 1, 1, 1) sent by the master. The master should then send a stop condition to terminate the transfer. The full erase operation will not be executed. Figure 5. Full Erase Sequence Triggered Using the Slave Address S Slave Address A 6 A 5 A 4 A 3 111 R/W A P S Start Condition P Stop Condition A Acknowledge '0' (write) From Master to Slave From Slave to Master This sector erase operation is triggered by defining an 8-bit byte address for each sector. The trigger address for each sector is entered on page 4 of the altufm MegaWizard Plug-In Manager, as shown in Figure 13 on page 10. When a write operation is executed targeting this special byte address location, the UFM sector that contains that byte address location is erased. This sector erase operation is automatically followed by a write of the intended write byte to that address. The default byte address location for UFM Sector 0 erase is address 0x00. The default byte address location for UFM Sector 1 erase is [(selected memory size)/2]. You can specify another byte location as the trigger-erase addresses for each sector. This sector erase operation supports up to eight UFM blocks or serial EEPROMs on the I 2 C bus. This sector erase operation requires acknowledge polling. Sector Erase (A 2 Triggered) This sector erase operation uses the received A 2 slave address bit to distinguish between an erase or read/write operation. This slave operation decoding occurs when the master transmits the slave address after generating the start condition. If the A 2 bit received by the UFM slave is 1, the sector erase operation is selected. If the A 2 bit received is 0, the read/write operation is selected. While this reserves the A 2 bit as an erase or read/write operation bit, the A 0 and A 1 bits still act as slave address bits to address the UFM. With this erase option, there can be up to four UFM slaves cascaded on the bus for 1-Kbit and 2-Kbit memory sizes. Only two UFM slaves can be cascaded on the bus for 4-Kbit memory size, since A 0 of the slave address becomes the ninth bit (MSB) of the byte address. After the slave acknowledges the slave address and its erase or read/write operation bit, the master can transfer any byte address within the sector that must be erased. The internal UFM sector erase operation only begins after the master generates a stop condition. Figure 6 shows the sector erase sequence using the A 2 bit of the slave address. 5

Altera Corporation Figure 6. Sector Erase Sequence Indicated Using the A2 Bit of the Slave Address S Slave Address A 2 = '1' R/W A Byte Address A P S Start Condition P Stop Condition A Acknowledge '0' (write) (1) From Master to Slave From Slave to Master Note to Figure 6: (1) A 2 = 0 indicates a read/write operation is executed in place of an erase. In this case, the R/W bit determines whether it is a read or write operation. If the altufm_i2c megafunction is write-protected (WP=1), the slave does not acknowledge the byte address (which indicates the UFM sector to be erased) sent in by the master. The master should then send a stop condition to terminate the transfer and the sector erase operation will not be executed. No Erase The no erase operation never erases the UFM contents. This method is recommended when UFM does not require constant re-writing after its initial write of data. For example, if the UFM data is to be initialized with data during manufacturing using I 2 C, you may not require writing to the UFM again. In that case, you should use the no erase option and save logic element (LE) resources from being used to create erase logic. Read Operation The read operation is initiated in the same manner as the write operation except that the R/W bit must be set to 1. Three different read operations are supported: Current Address Read (Single Byte) Random Address Read (Single byte) Sequential Read (Multi-Byte) After each UFM data has been read and transferred to the master, the UFM address register is incremented for all single and multi-byte read operations. Current Address Read This read operation targets the current byte location pointed to by the UFM address register. Figure 7 shows the current address read sequence. Figure 7. Current Address Read Sequence S Slave Address R/W A Data P S Start Condition P Stop Condition A Acknowledge 1 (read) From Master to Slave From Slave to Master 6

Random Address Read Random address read operation allows the master to select any byte location for a read operation. The master first performs a dummy write operation by sending the start condition, slave address, and byte address of the location it wishes to read. After the altufm_i2c megafunction acknowledges the slave and byte address, the master generates a repeated start condition, the slave address, and the R/W bit is set to 1. The altufm_i2c megafunction then responds with acknowledge and sends the 8-bit data requested. The master then generates a stop condition. Figure 8 shows the random address read sequence. Figure 8. Random Address Read Sequence S Slave Address R/W A Byte Slave Address A Sr Address R/W A Data P 0 (write) 1 (read) S Start Condition Sr Repeated Start P Stop Condition A Acknowledge From Master to Slave From Slave to Master Sequential Read Sequential read operation can be initiated by either the current address read operation or the random address read operation. Instead of sending a stop condition after the Slave has transmitted one byte of data to the master, the master acknowledges that byte and sends additional clock pulses (on SCL line) for the slave to transmit data bytes from consecutive byte addresses. The operation is terminated when the master generates a stop condition instead of responding with an acknowledge. Figure 9 shows the sequential read sequence. Figure 9. Sequential Read Sequence S Slave Address R/W A Byte Slave Address A Sr Address R/W A Data A Data P 0 (write) 1 (read) Data (n - bytes) + Acknowledgment (n - 1 bytes) S Start Condition Sr Repeated Start P Stop Condition A Acknowledge From Master to Slave From Slave to Master 7

t SU:STA t HD:STA t HD:DAT t SU:DAT tsu:sto t BUF Altera Corporation ALTUFM I2C Interface Timing Specification Figure 10 shows the timing waveform for the altufm_i2c megafunction read/write mode. Figure 10. Timing Waveform for the altufm_i2c Megafunction SDA SCL t HIGH t SCLSDA t LOW Tables 2 through 4 list the timing specification needed for the altufm_i2c megafunction read/write mode. Table 2. I2C Interface Timing Specification Symbol Parameter Min Max Units F SCL SCL clock frequency 100 khz t SCL:SDA SCL going low to SDA data out 15 ns t BUF Bus free time between a stop and start condition 4.7 µs t HD:STA (Repeated) start condition hold time 4 µs t SU:STA (Repeated) start condition setup time 4.7 µs t LOW SCL clock low period 4.7 µs t HIGH SCL clock high period 4 µs t HD:DAT SDA data in hold time 0 ns t SU:DAT SDA data in setup time 20 ns t SU:STO STOP condition setup time 4 ns Table 3. UFM Write Cycle Time Parameter Min Max Units Write Cycle Time 110 µs Table 4. UFM Erase Cycle Time Parameter Min Max Units Sector Erase Cycle Time 501 ms Full Erase Cycle Time 1,002 ms 8

Instantiating the I 2 C Interface Using the Quartus II altufm Megafunction Figure 11 shows the altufm megafunction symbol for a I 2 C interface instantiation in the Quartus II software. Figure 11. altufm Megafunction Symbol For the I 2 C Interface Instantiation in the Quartus II Software You can instantiate the UFM block using the MegaWizard Plug-In Manager dialog box (Tools menu). Select MAX II from the drop-down list as the device family. Select Flash Memory under the Memory Compiler directory. This selection starts the altufm megafunction wizard pages. Figure 12 shows the altufm megafunction selection (Flash Memory) in the MegaWizard Plug-In Manager. Figure 12. Page 2a of the altufm MegaWizard Plug-In Manager Figure 13 shows page 3 of the altufm MegaWizard Plug-In Manager when selecting I 2 C as the interface. On this page, you can choose whether to implement the read/write mode or read-only mode for the UFM. You also have an option to choose the memory size for the altufm_i2c megafunction as well as defining the four MSBs of the slave address (default 1010). 9

Altera Corporation 1 The UFM block's internal oscillator is always running when the altufm_i2c megafunction is instantiated for both read-only and read/write interfaces. Figure 13. Page 3 of the altufm MegaWizard Plug-In Manager (I 2 C) 10

Figure 14 shows page 4 of the altufm MegaWizard Plug-In Manager. You can select the optional write protection and erase operation methods on this page. Figure 14. Page 4 of the altufm MegaWizard Plug-In Manager (I 2 C) 11

Altera Corporation Figure 15 shows page 5 of the altufm MegaWizard Plug-In Manager. Figure 15. Page 5 of the altufm MegaWizard Plug-In Manager (I 2 C) Creating Memory Content File You can initialize the content of the UFM through a memory content file. The Quartus II software supports two types of initial memory content file formats; MIF and HEX. Memory Initialization for the altufm_i2c Megafunction The MAX II UFM physical memory block contains a 16-bit wide and 512 deep (9-bit address) array. The altufm_i2c megafunction uses the following smaller array sizes: an 8-bit wide and 128 deep (7-bit address) mapping for 1 Kbit memory size an 8-bit wide and 256 deep (8-bit address) mapping for 2 Kbits memory size an 8-bit wide and 512 deep (9-bit address) mapping for 4 Kbits memory size. Altera recommends that you pad the MIF or HEX file for both address and data width to fill the physical memory map for the UFM block and ensure the MIF/HEX file represents a full 16-bit word size and a 9-bit address space. Memory Map for 1-Kbit Memory Initialization Figure 16 shows the memory map initialization for the altufm_i2c megafunction of 1-Kbit memory size. The altufm_i2c megafunction byte address location of 00h to 3Fh is mapped to the UFM block address location of 000h to 03Fh. The altufm_i2c megafunction byte address location of 40h to 7Fh is mapped to the UFM block address location of 1C0h to 1FFh. Altera recommends that you pad the unused address locations of the UFM block with all ones. 12

Figure 16. Memory Map for 1-Kbit Memory Initialization MIF or HEX File Contents to represent the actual data and address size for the UFM block 1-Kbit altufm_i2c Megafunction Logical Memory Contents Upper Half Addresses 40h to 7Fh 7Fh 1FFh 1C0h 1BFh Address 40h in logical memory maps to 1C0h in the MIF/HEX file. Address 7Fh in logical memory maps to 1FFh in the MIF/HEX file, and all data in between follows the order in the logical memory 40h 3Fh This section of the UFM is unused the MIF/HEX file contents should be set to all '1' for addresses 040h to 1BFh Lower Half Addresses 00h to 3Fh 00h 040h 03Fh Address 00h in logical memory maps to address 000h in the MIF/HEX file. Address 3Fh in logical memory maps to 03Fh in the MIF/HEX file, and all data in between follows the order in the logical memory 000h Memory Map for 2-Kbit Memory Initialization Figure 17 shows the memory map initialization for the altufm_i2c megafunction of 2 Kbits of memory. The altufm_i2c megafunction byte address location of 00h to 7Fh is mapped to the UFM block address location of 000h to 07Fh. The altufm_i2c megafunction byte address location of 80h to FFh is mapped to the UFM block address location of 180h to 1FFh. Altera recommends that you pad the unused address location of the UFM block with all ones. Figure 17. Memory Map for 2 Kbits Memory Initialization MIF or HEX File Contents to represent the actual data and address size for the UFM block 2-Kbit altufm_i2c Megafunction Logical Memory Contents Upper Half Addresses 80h to FFh FFh 1FFh Address 80h in logical memory maps to 1FFh in the MIF/HEX file. Address 1FFh in logical memory maps to 1FFh in the MIF/HEX file, and all data in between follows the order in the logical memory 180h 80h 7Fh 17Fh This section of the UFM is unused the MIF/HEX file contents should be set to all '1' for addresses 080h to 17Fh Lower Half Addresses 00h to 7Fh 00h 080h 07Fh 000h Address 00h in logical memory maps to address 000h in the MIF/HEX file. Address 7Fh in logical memory maps to 07Fh in the MIF/HEX file, and all data in between follows the order in the logical memory 13

Altera Corporation Memory Map for 4-Kbit Memory Initialization Figure 18 shows the memory map initialization for the altufm_i2c megafunction of 4-Kbit memory. The altufm_i2c megafunction byte address location of 00h to FFh is mapped to the UFM block address location of 000h to 0FFh. The altufm_i2c megafunction byte address location of 100h to 1FFh is mapped to the UFM block address location of 100h to 1FFh. Figure 18. Memory Map for 4-Kbit Memory Initialization 4-Kbit altufm_i2c Megafunction Logical Memory Contents Upper Half Addresses 100h to 1FFh Lower Half Addresses 00h to FFh 1FFh 100h FFh 00h 100h 0FFh 000h MIF or HEX File Contents to represent the data and address size for the UFM block 1FFh Address 100h in logical memory maps to 100h in the MIF/HEX file. Address 1FFh in logical memory maps to 1FFh in the MIF/HEX file, and all data in between follows the order in the logical memory Address 00h in logical memory maps to 000h in the MIF/HEX file. Address FFh in logical memory maps to 0FFh in the MIF/HEX file, and all data in between follows the order in the logical memory Padding Data into Memory Map The altufm_i2c megafunction uses the upper 8 bits of the UFM 16-bit word, therefore the 8 least significant bit (LSB) should be padded with 1, as shown in Figure 19. Figure 19. Padding Data into Memory Map 1 0 1 0 1 0 1 0 1 1 1 1 1 1 1 1 8-bit valid data to be placed in the upper byte Pad the lower byte with eight '1's UFM Operations During In-System Programming During any event, in-system programming can overwrite the UFM address register and cause it to incur an invalid address location for the altufm_i2c megafunction. Therefore, executing a current address read operation right after in-system programming can result in reading from an invalid address. f For more information on the MAX II UFM operations during in-system programming, refer to the In-System Programmability Guidelines for MAX II Devices chapter of the MAX II Handbook. Conclusion The altufm_i2c megafunction is a user-friendly, ready-to-use I 2 C slave interface that provides significant flexibility in its interface with the MAX II UFM block. With the altufm megafunction, You can use MAX II devices to incorporate logic and memory devices on a design board, eliminating chip-to-chip delays, minimizing board space, and reducing total system cost. 14

Appendix A: MAX II LE Usage for the altufm_i2c Megafunction Table 5 shows the MAX II LE and UFM block usage for the altufm_i2c megafunction with different features and functions. Table 5. The MAX II LE And UFM Block Usage For The altufm_i2c Megafunction (Sheet 1 of 3) Memory Size Feature UFM Utilized LE Usage 1 Kbit Read-only Yes 116 Upper Half Write Protection Yes 168 Yes 158 Sector Erase (A 2 Triggered) Yes 153 No Erase Yes 146 Full Write Protection Yes 164 Yes 155 Sector Erase (A 2 Triggered) Yes 151 No Erase Yes 144 No Write Protection Yes 164 Yes 155 Sector Erase (A 2 Triggered) Yes 151 No Erase Yes 144 15

Altera Corporation Table 5. The MAX II LE And UFM Block Usage For The altufm_i2c Megafunction (Sheet 2 of 3) Memory Size Feature UFM Utilized LE Usage 2 Kbits Read-only Yes 118 Upper Half Write Protection Yes 168 Yes 157 Sector Erase (A 2 Triggered) Yes 153 No Erase Yes 147 Full Write Protection Yes 164 Yes 155 Sector Erase (A 2 Triggered) Yes 152 No Erase Yes 145 No Write Protection Yes 164 Yes 155 Sector Erase (A 2 Triggered) Yes 152 No Erase Yes 145 16

Table 5. The MAX II LE And UFM Block Usage For The altufm_i2c Megafunction (Sheet 3 of 3) Memory Size Feature UFM Utilized LE Usage 4 Kbits Read-only Yes 71 Upper Half Write Protection Yes 118 Yes 120 Sector Erase (A 2 Triggered) Yes 105 No Erase Yes 100 Full Write Protection Yes 117 Yes 119 Sector Erase (A2 Triggered) Yes 105 No Erase Yes 99 No Write Protection Yes 117 Yes 119 Sector Erase (A 2 Triggered) Yes 103 No Erase Yes 99 101 Innovation Drive San Jose, CA 95134 (408) 544-7000 http://www.altera.com Copyright 2005 Altera Corporation. All rights reserved. Altera, The Programmable Solutions Company, the stylized Altera logo, specific device designations, and all other words and logos that are identified as trademarks and/or service marks are, unless noted otherwise, the trademarks and service marks of Altera Corporation in the U.S. and other countries. All other product or service names are the property of their respective holders. Altera products are protected under numerous U.S. and foreign patents and pending applications, maskwork rights, and copyrights. Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera Corporation. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services. 17