🚀 DAY 5 OF LAUNCH WEEK: Introducing Socket Firewall Enterprise.Learn more
Socket
Book a DemoInstallSign in
Socket

@mchp-mcc/data-eeprom-emulation

Package Overview
Dependencies
Maintainers
10
Versions
3
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@mchp-mcc/data-eeprom-emulation

- Download & Install [nodejs](https://nodejs.org/en/download/) - Download & Install npm - Setup node & npm in enviroment path

latest
npmnpm
Version
1.1.0
Version published
Maintainers
10
Created
Source

MCC Melody Data EEPROM Emulation

Emulating Data EEPROM for dsPIC33A Digital Signal Controllers

DATA EEPROM EMULATION INTRODUCTION

Microchip Technology Inc. has expanded its product portfolio to include a wide variety of cost-effective PIC® Microcontrollers (MCUs) without an internal data EEPROM.

Many applications store nonvolatile information in the Flash program memory using table read and write operations. Applications that need to frequently update this data may have greater endurance requirements than the specified Flash endurance for the MCU/Digital Signal Controller (DSC) devices.

The alternate solution of using an external, serial EEPROM device may not be appropriate for cost-sensitive or pin-constrained applications.

This document presents another alternative that addresses these issues. This algorithm features an interface similar to an internal data EEPROM, which uses available program memory and can effectively improve endurance typically by a factor as high as 500 or more.

Definition of Terms

Page – The minimum amount of program memory affected by an erase operation.

Row – The maximum amount of program memory that can be written in one attempt.

Bank - Bank is a logical entity that signifies a group of addresses. Each EEPROM bank can have a maximum of 255 addresses.

Erase/Write Cycle – The number of erase and write operation pairs.

Endurance – A specification indicating the maximum number of erase/write cycles and associated conditions.

Retention – A specification indicating the minimum time and associated conditions for the retention of data in Flash program memory.

Effective Endurance – The improved endurance of the emulated data EEPROM as a result of using an efficient programming algorithm.

Current (Active) Page – A page in program memory that is being written and read by the data EEPROM emulation algorithm.

Packed Page – The new current page after the pack routine (this routine is not exposed) is complete.

Page Status – Program memory locations at the beginning of the current page that store data EEPROM emulation status. The dsPIC33A devices use one location (address).

Maximum Data EE Size Per Bank - Maximum addresses per bank or Maximum addresses that can be stored in a flash page.

THEORY OF OPERATION

The algorithm in this application note supports selectable, multiple emulated data EEPROM banks with a total size of up to multiples of "Maximum Data EE Size" locations, with a single address space, ranging from 0 to the total size of the emulated data EEPROM’s minus one (see the below note).

For example, if the implemented size of the data EEPROM is five, and two data EEPROMs are used, only the addresses in the range, 0 to 9, are available.

Note: dsPIC33A implementation support multiple EEPROM banks. Each EEPROM can have a maximum of 255 addresses(This is not always true , please check the value of Maximum Data EE Size Per Bank for the given device). Therefore, the total addresses are from 0 to N x 255 – 1, where N = the number of EEPROM banks.

dsPIC33A DATA EEPROM INFORMATION FORMAT IN PROGRAM MEMORY

Each DEE Address stores 32 bit of DEE Data.

Table 1

Bits 31-24Bits 23-16Bits 15-8Bits 7-0
XXXDEE Address
DEE Data
0xFFFFFFFF
0xFFFFFFFF

Note: X denotes dont care(unused!) and 0xFFFFFFFF denotes unused

USE CASE

To understand how the algorithm works, a simple case example for the dsPIC33A devices is described in this section.

After the first page of each EEPROM bank is initialized, the first location is reserved for the page status information. This indicates whether a page is active or expired, and how many erase/write cycles have been performed. This information is not directly accessible by the user but is used by the algorithm to find the available pages and update status flags. After initialization, the first page is designated as the active page.

In this example, a write operation has been performed to store a data value of 0x0202 to data EEPROM address, 0x10. As provided in Table 2, this information is stored in the first available location in the page. As more writes are performed, the algorithm continues to write the information, similarly, as provided in Table 3 through Table 5.

In this example, the data EEPROM address 0x20 is written with 0x0707, 0x10 is updated to 0x2222 and address 0x30 is written with 0x0A0A.

In Table 6, the last location in the page is written with a rewrite to address 0x20 to 0x7777. The data EEPROM information will move to the next available page because the currently active page is full. This new page is referred to as the packed page. The pack routine performs this task. Since only the most current data for each data EEPROM address is needed, the amount of information decreases.

After the data is moved, this page is designated as the current page. If the current page has incremented through all allocated pages in program memory, the erase/write count is incremented as provided in Table 7. The page is now ready to store more information through write operations.

Table 2

Page AddressBits 31-24Bits 23-16Bits 15-8Bits 7-0
Page+0XPage Status<23:16>0
Page+0x10XXX0x10
Page+0x140x202
Page+0x200xFFFFFFFF
Page+0x240xFFFFFFFF
Page+0x300xFFFFFFFF
Page+0x340xFFFFFFFF
.....
.....
Page+0x3F00xFFFFFFFF
Page+0x3F40xFFFFFFFF

Table 3

Page AddressBits 31-24Bits 23-16Bits 15-8Bits 7-0
Page+0XPage Status<23:16>0
Page+0x10XXX0x10
Page+0x140x202
Page+0x20XXX0x20
Page+0x240x707
Page+0x300xFFFFFFFF
Page+0x340xFFFFFFFF
.....
.....
Page+0x3F00xFFFFFFFF
Page+0x3F40xFFFFFFFF

Table 4

Page AddressBits 31-24Bits 23-16Bits 15-8Bits 7-0
Page+0XPage Status<23:16>0
Page+0x10XXX0x10
Page+0x140x202
Page+0x20XXX0x20
Page+0x240x707
Page+0x30XXX0x10
Page+0x340x2222
.....
.....
Page+0x3F00xFFFFFFFF
Page+0x3F40xFFFFFFFF

Table 5

</tbody>
Page AddressBits 31-24Bits 23-16Bits 15-8Bits 7-0
Page+0XPage Status<23:16>0
Page+0x10XXX0x10
Page+0x140x202
Page+0x20XXX0x20
Page+0x240x707
Page+0x30XXX0x10
Page+0x340x2222
Page+0x40XXX0x30
Page+0x440x0A0A
.....
.....
Page+0x3F00xFFFFFFFF
Page+0x3F40xFFFFFFFF

Table 6

Page AddressBits 31-24Bits 23-16Bits 15-8Bits 7-0
Page+0XPage Status<23:16>0
Page+0x10XXX0x10
Page+0x140x202
Page+0x20XXX0x20
Page+0x240x707
Page+0x30XXX0x10
Page+0x340x2222
Page+0x40XXX0x30
Page+0x440x0A0A
.....
.....
Page+0x3F0XXX0x20
Page+0x3F40x7777

Table 7

Page AddressBits 31-24Bits 23-16Bits 15-8Bits 7-0
Page+0XPage Status<23:16>0x0001
Page+0x10XXX0x10
Page+0x140x2222
Page+0x20XXX0x20
Page+0x240x7777
Page+0x30XXX0x30
Page+0x340x0A0A
Page+0x400xFFFFFFFF
Page+0x440xFFFFFFFF
.....
.....
Page+0x3F00xFFFFFFFF
Page+0x3F40xFFFFFFFF

Only one erase/write cycle is consumed for the page as each location within the page is programmed once prior to the page erase. As a result, the algorithm multiplicatively improves the emulated data EEPROM's effective endurance.

The previously filled page is erased only after the latest information has been programmed into the next available page and successfully verified. Through this process, the information is always stored in nonvolatile memory, which minimizes the effects of an unexpected loss of power.

As the program memory page is filled sequentially from beginning to end, the algorithm assumes the most current data EEPROM information is the closest instance to the end of the page. To simplify the read operation, the search begins at the end of the current program memory page and works toward the start of the page – looking for the specified data EEPROM address.

When a match is found, the associated data is returned for the first instance of the provided address. If the address is not found, the return value of all ones, 0xFF or 0xFFFFFFFF, is returned to emulate the result of an unwritten address in an independent data EEPROM.

DATA EEPROM EMULATION MCC MODULE

The Data EEPROM emulation MCC module provides a simple GUI for the user to configure the EEPROM emulation algorithm and generates the code for the Data EEPROM emulation.

This module avoids the users from making the above configuration manually, instead users have to provide 2 parameters i.e. the number of 32 bit data users want to store and the required endurance for their application/data.

Based on the users input all the required parameters which are mentioned in the previous section are automatically calculated by the module.

Note: Application by default uses the highest flash memory area excluding the configuration settings area for the emulated structure. If the uses want to provide the start address for the emulated data structure they can do so by disabling the Use Highest Flash Memory Area for Emulated EEPROM Data Structure button.

This module also provides the following useful information to the users

  • Calculated Total Effective endurance: The achieved endurance is not exactly same as the requested endurance, the algorithm will always achieve the requested endurance. This parameter provides the actual endurance achieved using this algorithm.

    Calculated Total Effective endurance = (Page Size – Page Status Size – Maximum Data EE Size Per Bank) x Number of Pages Flash Pages Per EEPROM Bank x Requested Total Effective Endurance.

    If the device has ECC, the hardware has one ECC per four instruction words , but DEE operate at 2 instructions word level, one instruction to store DEE address and one instruction to store DEE Data. So for devices with ECC and quadword instruction write, DEE effectively uses only one instruction to store the data , So effective Page size would be one fourth of the actual page size.

    Page Status Size is 1(size of the status info).

  • Maximum Data EE Size Per Bank: This is the maximum EE data that can be stored in a bank i.e. this will decide the number of EE addresses per flash page. The maximum value is 255.

  • Maximum number of EEPROM Data user can store: The memory allocated in terms of banks, so the actual memory allocation always would be multiple of Maximum Data EE Size Per Bank. If the user wants to store 255, then if the value of Maximum Data EE Size Per Bank is 255 then only one bank will be allocated and maximum number of EEPROM data users can store would be 255. If the user wants to store 256 data elements then, 2 banks are needed and maximum number of EEPROM data users can store would be 510.

  • Number of EEPROM Banks: This tells the number of EEPROM banks required to store the user data. EEPROM data bank is a logical entity. The maximum size of a bank is 255 i.e. in a flash page maximum of 255 addresses and their data will be stored.
  • Number of Flash Pages per bank: This tells the number of flash pages allocated per bank to achieve the required endurance.

  • Minimum Flash Cell Endurance: This is the minimum endurance of the flash cell in the given device.

  • End Flash Address of Emulated EEPROM data structure: This is the end address of the emulated data structure.

  • Flash Size of Emulated EEPROM data structure (Instruction words): This gives the actual size in Instruction Words occupied by the emulated data structure in the flash. 1 Instruction word = 3 Bytes.

DATA EEPROM Emulation Interface Functions:

INITIALIZATION OPERATION(DEE_Init()):

The initialization routine, DEE_Init(), must be called before any other data EEPROM operation can occur. This initializes all of the EEPROM banks. If the routine determines that program memory has not been initialized for emulation, it will find the first allocated page of program memory and initialize its status information. Thereafter, the read and write functions may be called as needed.

The routine may also determine whether data EEPROM emulation is already underway. If so, one of three scenarios may occur:

• If only one active page is found, the routine assumes a Reset occurred. No action is taken and the routine exits normally. Any read/write operation that may have been active during the Reset should be repeated.

• If two active pages are found, the routine assumes that an unexpected Reset occurred during a pack operation. The routine will erase the newest active page and call the pack routine to permit the refresh to complete.

• If more than two active pages are found, the routine assumes program memory has been corrupted by the application code and sets the pageCorrupt flag(Status Flags).

It is important to monitor the page status bits, as well as the RCON and NVMCON, the application can respond appropriately to Resets and supply voltage changes.

DEE_Init Flow Chart

READ OPERATION(DEE_Read()):

The DEE_Read() function is used to retrieve data EEPROM information. It returns the data associated with the data EEPROM address. If the provided address is equal to or greater than the amount of defined data EEPROM, the illegalAddress flag(Status Flags) is set and a value of all ‘1’s is returned. This return value mimics the response of dedicated data EEPROM, where an unwritten address returns an erased value.

The routine then searches for the active page in the EEPROM bank corresponding to the address. Once located, the active page is searched for an address match, starting from the last location in the page. For details on how data EEPROM information is stored in program memory, refer to Table 1.

If an active page is not found, the pageCorrupt flag(Status Flags) is set. A flowchart of the read operation is illustrated in the following figure.

DEE_Read Flow Chart

WRITE OPERATION(DEE_Write()):

To write emulated data EEPROM, the application uses the DEE_Write() function. Like the read function, it verifies that the data EEPROM address is between 0 and one less than the size of the emulated data EEPROM. If an unimplemented address is supplied, the illegalAddress flag(Status Flags) is set and write operation is aborted.

The routine then searches for the active page of the EEPROM bank corresponding to the address. After the active page is located, a read operation is performed. To minimize the number of erase/write cycles, the value is programmed only if it has changed.

If an active page is not found, the pageCorrupt flag is set and a non-zero value is returned.

A forward search of the active page returns the offset for the next available address. If the next available address is equal to, or greater than, the last address in the page, the packSkipped flag is set and the write operation is aborted. Otherwise, the data EEPROM information is written to the next available address in the page.

If the information does not verify, the writeError flag(Status Flags) is set and a non-zero value is returned. The user can attempt to rewrite the data or respond as needed.

The algorithm is designed to maintain at least one available location in the active page for the next write operation. After a successful verification of the write operation, the pack routine is called if no available locations remain.

After the routine completes successfully, a zero value is returned.

A flowchart of the write operation is illustrated in following Figure.

DEE_Write Flow Chart

PERFORMANCE:

Effective Endurnace

Determining effective endurance is not a trivial calculation because it is dependent on many factors. Traditionally, endurance is defined as the number of times a single address can be safely written. This definition does not apply to emulated data EEPROM for a few different reasons.

First, writing a data EEPROM address five times does not mean five erase/write cycles of endurance were consumed. From the perspective of the program memory, five writes were made to five different program memory addresses. These five writes will not cost any additional endurance cycles until the page is filled and the pack routine is called.

Second, calculating effective endurance is more than simply multiplying program memory page size and the size of the emulated data EEPROM. The entire page is not available for emulation. The page status information is stored in the beginning of the page, which is one location of program memory. In addition, more locations will be consumed after the pack routine depending on how many data EEPROM addresses were written. As a result, writing an address once has a significant impact to endurance because one less location is available after the array is packed.

Based on the discussion to this point, a simplified equation (see equation1) can be made for total effective endurance. For more information on the terms, refer to “Definition of Terms”.

Working through an example for the dsPIC33AK128MP106, this device has a 1024-word page. The minimum write size is 4 insructions words i.e QUADWORD. Out of these 4 instructions words one instruction word is used to store the DEE Address, one instuction word is used to store the actual DEE data , remaining 2 instructions are unused. The effective page size would be 256. The algorithm reserves one location for page status.

equation 2 provides the formula for calculating two pages of program memory, 10 locations of emulated data EEPROM and the typical endurance limit.

An average effective endurance can be calculated by dividing the total effective endurance by the size of the emulated data EEPROM bank, but this does not tell the whole story. It assumes that every data EEPROM address is updated at the same rate. In most applications, this is not true. Some data, such as calibration data or user information, may be rarely updated, while sensor information can be written more frequently. Addresses written more often will consume a greater amount of program memory endurance. Therefore, how writes are distributed across the data EEPROM addresses significantly affects effective endurance. Ratios could be assigned to each address to create a more accurate calculation, but this is still only an approximation. It is difficult to predict how often each address will be written during an application’s lifetime.

EQUATION 1: EFFECTIVE ENDURANCE

Calculated Total Effective endurance = (Page Size – Page Status Size – Maximum Data EE Size Per Bank) x Number of Pages Flash Pages Per EEPROM Bank x Requested Total Effective Endurance.

EQUATION 2: EFFECTIVE ENDURANCE CALCULATION EXAMPLE

Calculated Total Effective endurance = (256 – 1 – 10) x 2 x 1000 = 490,000 Cycles

Note: In devices with ECC and quadword write, the flash page size to be used for calculation should be (flash page size /4) because the hardware has one ECC per four instruction words, but DEE operate at a single instruction word level. So for devices with quadword write and ECC, DEE uses only one instruction word only.

STATUS FLAGS:

flags have been provided to indicate whether an error or warning condition occurs during the emulation process. These indicators are accessed in the Data EEPROM Flags register; all flags are active-high. The status bits and return values are defined as follows:

• addrNotFound(0xFF/0xFFFF) – A read operation occurred on a previously unwritten data EEPROM address.

• expiredPage(0x1) – The program memory erase/write cycle count has exceeded the user-defined limit. The algorithm will attempt to execute the write operation.

• packBeforePageFull(0x2) – The pack routine was called before the currently active page was full. The routine will attempt to move the latest data EEPROM information to the packed page, even though the active page is not full.

• packBeforeInit(0x3) – The pack routine was executed before the initialization routine. The pack operation was aborted.

• packSkipped(0x4) – A page was written beyond the page boundary. This may be a result of the pack routine not being executed properly. The pack operation was aborted.

• illegalAddress(0x5) – There was an attempt to write/read with a data EEPROM address equal to or greater than the size of data EEPROM. The read/write operation was aborted.

• pageCorrupt(0x6) – The page status information was corrupted. The current operation was aborted. • writeError(0x7) – The information that was written into program memory failed the verification. The current operation was aborted.

The status flags differ in severity and how they are serviced. The informational status flags are expected to occur during normal processing and are serviced by simply clearing the flag with the associated macro. These include: addrNotFound, packBeforePageFull and illegalAddress flags.

Warning status flags indicate a condition has been exceeded but processing will continue. This includes the expiredPage status flag. With this flag set, the algorithm will attempt to process read and write requests, but the flag will be set after each operation.

The most severe flags are the system error status flags. These imply either the integrity of the data EEPROM information has been compromised and/or the algorithm cannot continue until the offending condition has been resolved. These include packBeforeInit, pageCorrupt and writeError flags.

To avoid a packBeforeInit event, ensure the initialization routine, DEE_Init, is called before performing any other emulation routine. Since this routine accesses the current state of the emulation process, it will take action only if it is required. Therefore, it can be called at any time during data EEPROM emulation.

The pageCorrupt and writeError flags indicate that a write operation failed to verify and the current operation was aborted. If this occurs, the integrity of the data EEPROM information has been compromised. No further emulation operations should be attempted. The memory reserved for data EEPROM emulation and attempt to reinitialize them.

Macros are available to retrieve and clear the status flag values. Status flags are cleared only by the user. No operation is affected by the value of any flag, but the flag’s value will indicate.

POWER FAILURE/RESET SCENARIOS

  • What if there is power failure during DEE Initialization: If there are no active pages , DEE_Init() routine will continue to initialize DEE pages , if there is only one active page, then routine exits normally assuming there was a reset during DEE_Init() or DEE_Write(). No user data will be lost.

  • What if there is power failure during DEE Write: If the write is completed before the power failure then there is no problem , if not the last data will be lost.

  • What if there is power failure during Pack operation: If there is a reset during pack operation , the DEE_Init() routine will find 2 active pages during initialization and the DEE_Init() routine will erase the newer active page and call the pack operation on first page. Also page status is written after writing all the data. If there is a power reset before writing the page status pack operation will be performed in the next iteration during DEE_Init(). No user data will be lost.

Changelog

All notable changes to this project will be documented in this file.

[1.1.0] - 2025-08-19

New Features

  • CC16SCRIP-9862 :- Add Data EEPROM Emulation support to dsPIC33AK512MPS512(Dual Panel Devices)

Bug Fixes

  • CC16SCRIP-9845 :- DEE generated code has build errors for dsPIC33AK512MPS512 device

[1.0.1] - 2025-02-06

Bug Fixes

  • CC16SCRIP-9667 :- DEE_Write() issue with 32 bit data write

[1.0.0] - 2024-10-01

New Features

  • CC16SCRIP-9588 :- dsPIC33A Data EEPROM Emulation support

FAQs

Package last updated on 21 Aug 2025

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts