24xx256シリーズ(24AA256, 24LC256, 24FC256)

24xx256シリーズ(24AA256, 24LC256, 24FC256)の概要と、24xx256シリーズ用OSS-ECALの提供についてご紹介いたします。24xx256シリーズは、Microchip Technology製の32,768words × 8 bitsのEEPROM(Electrically Erasable and Programmable Read-Only Memory) chipです。
MCUインタフェース:I2C

ご注意:このリソースの元の言語は英語です。 翻訳は概要を便宜的に提供するもので、機械翻訳を使用していることがあり、私たちは翻訳の正確性および妥当性につきましては一切保証いたしません。 また、実際の設計などの前には、必ず最新版Datasheetをご参照くださいますようお願いいたします。

24xx256

24xx256シリーズ(24AA256, 24LC256, 24FC256)

概要

Microchip Technology製24XX256は、32K×8(256Kbit)のシリアル電気的消去可能PROM(EEPROM)で、広い電圧範囲(1.7V~5.5V)で動作可能です。このデバイスは、個人通信やデータ収集などの高度な低消費電力アプリケーション向けに開発されました。また、このデバイスは最大64バイトのデータのページ書き込み機能を備えています。 このデバイスは、256K境界までのランダム・リードとシーケンシャル・リードの両方が可能です。 機能的なアドレス・ラインにより、同一バス上に最大8つのデバイスが存在し、最大2Mビットのアドレス空間が可能です。

型番Vcc範囲最大周波数温度範囲パッケージ
24AA2561.7~5.5V400kHz(1)I, ECS, MF, MS, P, SN, SM, MNY, ST
24LC2562.5~5.5V400kHzI, EMF, MS, P, SN, SM, MNY, ST
24FC2561.7~5.5V1Mhz(2)I, EMF, MS, P, OT, SN, SM, MNY, ST

Note
1: 100 kHz for Vcc < 2.5V
2: 400kHz for Vcc < 2.5V

特徴

  • 24AA256および24FC256デバイスは1.7Vまで、24LC256デバイスは2.5Vまで動作可能な単一電源
  • 低消費電力CMOS技術
    書き込み:最大 3mA
    スタンバイ電流:最大1μA(I-temp.)
  • 2線式シリアルインターフェース、I2C コンパチブル
  • カスケード接続可能な8つのデバイス
  • ノイズ抑制用シュミート・トリガー入力
  • ラウンドのバウンスをなくすための出力傾斜制御
  • 100 kHz、400 kHz、1 MHzコンパチビリティ
  • ページ書込み時間 最大5分
  • 自己タイミング消去/書き込みサイクル
  • 64バイト・ページ書き込みバッファ
  • ハードウェア・書込みプロテック
  • ESD保護 > 4000V
  • 100万回以上の消去/書き込みサイクル
  • データ保持 200年 以上
  • 工場プログラミング可能
  • RoHS対応
  • 温度範囲
    工業用(I) -40°C ~ + 85°C
    拡張 (E)  -40°C ~ +125°C
  • 自動車 AEC-0100 クオリファイ

OSS-ECAL仕様

API関数

etSTS o24xx256_BYTE_WRITE( etCMP cmp, uint16 mem_adr, uint8 val )

o24xx256_BYTE_WRITE関数は、24xx256シリーズ(24AA256, 24LC256, 24FC256)に対して指定したアドレスmem_adrにvalの値をWriteするAPI関数です。この関数は、書き込み完了までの時間(i24xx256_WRITE_TIME [ms])が経過するまで、戻り値eSTS_EXEを返します。

備考 :
i24xx256_WRITE_TIME [ms]経過計測は、この関数をコールするThread周期から計算するので、THREAD_OSS_ECAL_PERIOD [ms]にThread周期を設定してください。
この関数を使用する際には、o24xx256_WP_DIS関数でライトプロテクトを解除してからご利用ください。

戻り値etSTSOSS-ECALステータスコード
 eSTS_FIN
 eSTS_EXE
 eSTS_ERR_PARAMETER
 eSTS_ERR_I2C_OBJECT
 eSTS_ERR_OTHERS_RUN
 eSTS_ERR_HAL_OTHERS_RUN
 eSTS_ERR_HAL_I2C

正常終了
実行中
パラメータエラー(メモリアドレス範囲外)
I2Cオブジェクト選択エラー
他コンポーネントが処理実行中
HALオブジェクト実行中
HAL I2Cエラー
引数 INetCMP cmp共通コンポーネントコードe24xx256 20007U
uint16 mem_adrメモリアドレス範囲 0x0000 to 0x7fff
uint8 val書き込むデータ範囲 0x00 to 0xff
etSTS o24xx256_PAGE_WRITE( etCMP cmp, uint16 mem_adr, uint16 len, uint8* buf )

o24xx256_PAGE_WRITE関数は、24xx256シリーズ(24AA256, 24LC256, 24FC256)に対して指定したアドレスmem_adrから順番にbuf[0]からbuf[len-1]の値をWriteするAPI関数です。この関数は、書き込み完了までの時間(i24xx256_WRITE_TIME [ms])が経過するまで、戻り値eSTS_EXEを返します。

備考 :
mem_adr + len > 0bXXXXXXXXX111111となった場合、アドレスはA6~A14を固定としてA0~A5を0bXXXXXXXXX000000にロールオーバします。
i24xx256_WRITE_TIME [ms]経過計測は、この関数をコールするThread周期から計算するので、THREAD_OSS_ECAL_PERIOD [ms]にThread周期を設定してください。
この関数を使用する際には、o24xx256_WP_DIS関数でライトプロテクトを解除してからご利用ください。

戻り値etSTSOSS-ECALステータスコード
 eSTS_FIN
 eSTS_EXE
 eSTS_ERR_PARAMETER
 eSTS_ERR_I2C_OBJECT
 eSTS_ERR_OTHERS_RUN
 eSTS_ERR_HAL_OTHERS_RUN
 eSTS_ERR_HAL_I2C

正常終了
実行中
パラメータエラー(メモリアドレス範囲外、書き込むByte数65以上)
I2Cオブジェクト選択エラー
他コンポーネントが処理実行中
HALオブジェクト実行中
HAL I2Cエラー
引数 INetCMP cmp共通コンポーネントコードe24xx256 20007U
uint16 mem_adrメモリアドレス範囲 0x0000 to 0x7fff
uint16 len書き込むByte数Max 64
uint8* buf書き込むデータバッファ配列の先頭アドレス
etSTS o24xx256_CURRENT_READ( etCMP cmp, uint8* rlt )

o24xx256_CURRENT_READ関数は、24xx256シリーズ(24AA256, 24LC256, 24FC256)に対して前回のReadまたはWriteしたアドレス + 1から1Byte分の値をReadし、rltに保存するAPI関数です。

備考 :
前回のReadまたはWriteしたアドレス + 1 > 0x7fffとなった場合、アドレスは0x0000にロールオーバします。

戻り値etSTSOSS-ECALステータスコード
 eSTS_FIN
 eSTS_ERR_I2C_OBJECT
 eSTS_ERR_OTHERS_RUN
 eSTS_ERR_HAL_OTHERS_RUN
 eSTS_ERR_HAL_I2C

正常終了
I2Cオブジェクト選択エラー
他コンポーネントが処理実行中
HALオブジェクト実行中
HAL I2Cエラー
引数 INetCMP cmp共通コンポーネントコードe24xx256 20007U
引数 OUTuint8* rlt読み込むデータを格納するアドレス
etSTS o24xx256_RANDOM_READ( etCMP cmp, uint16 mem_adr, uint8* rlt )

o24xx256_RANDOM_READ関数は、24xx256シリーズ(24AA256, 24LC256, 24FC256)に対して指定したアドレスmem_adrから1Byte分の値をReadし、rltに保存するAPI関数です。

備考 :

戻り値etSTSOSS-ECALステータスコード
 eSTS_FIN
 eSTS_ERR_PARAMETER
 eSTS_ERR_I2C_OBJECT
 eSTS_ERR_OTHERS_RUN
 eSTS_ERR_HAL_OTHERS_RUN
 eSTS_ERR_HAL_I2C

正常終了
パラメータエラー(メモリアドレス範囲外)
I2Cオブジェクト選択エラー
他コンポーネントが処理実行中
HALオブジェクト実行中
HAL I2Cエラー
引数 INetCMP cmp共通コンポーネントコードe24xx256 20007U
uint16 mem_adrメモリアドレス範囲 0x0000 to 0x7fff
引数 OUTuint8* rlt読み込むデータを格納するアドレス
etSTS o24xx256_SEQ_READ( etCMP cmp, uint16 mem_adr, uint16 len, uint8* buf )

o24xx256_SEQ_READ関数は、24xx256シリーズ(24AA256, 24LC256, 24FC256)に対して指定したアドレスmem_adrから順番にlen分のデータを読み込み、buf[0]からbuf[len-1]に保存するAPI関数です。

備考 :
mem_adr + len > 0x7fffとなった場合、アドレスは0x0000にロールオーバします。

戻り値etSTSOSS-ECALステータスコード
 eSTS_FIN
 eSTS_ERR_PARAMETER
 eSTS_ERR_I2C_OBJECT
 eSTS_ERR_OTHERS_RUN
 eSTS_ERR_HAL_OTHERS_RUN
 eSTS_ERR_HAL_I2C

正常終了
パラメータエラー(メモリアドレス範囲外、書き込むByte数65以上)
I2Cオブジェクト選択エラー
他コンポーネントが処理実行中
HALオブジェクト実行中
HAL I2Cエラー
引数 INetCMP cmp共通コンポーネントコードe24xx256 20007U
uint16 mem_adrメモリアドレス範囲 0x0000 to 0x7fff
uint16 len読み込むByte数Max 64
引数 OUTuint8* buf読み込むデータを格納するバッファ配列アドレス
etSTS o24xx256_WP_EN( etCMP cmp )

o24xx256_WP_EN関数は、24xx256シリーズ(24AA256, 24LC256, 24FC256)に対してWrite protect enable (write disable) = “Hi” 出力するAPI関数です。

備考 :

戻り値etSTSOSS-ECALステータスコード
eSTS_FIN正常終了
eSTS_ERR_GPIO_OBJECTGPIOオブジェクト選択エラー
引数 INetCMP cmpOSS-ECAL コンポーネントコード
etSTS o24xx256_WP_DIS( etCMP cmp )

o24xx256_WP_DIS関数は、24xx256シリーズ(24AA256, 24LC256, 24FC256)に対してWrite protect disable (write enable) = “Low” 出力するAPI関数です。

備考 :

戻り値etSTSOSS-ECALステータスコード
eSTS_FIN正常終了
eSTS_ERR_GPIO_OBJECTGPIOオブジェクト選択エラー
引数 INetCMP cmpOSS-ECAL コンポーネントコード

HALサポート

OSS-ECALのHAL対応は、次の通りです。(順次拡大中)尚、HAL対応は各電子部品のOSS-ECALページでご確認ください。尚、同じHALであってもVerやMCU、開発環境が異なると動作が合わない場合がありますので、ご注意ください。

メーカSDK/IDE ツールHAL名称VerHALNAMESupport
ArduinoArduino IDEArduino1.8.6ARDUINOX
ArmKeil MDK v6Mbed OS6.17.0MBEDX
DebianGNU/Linux10.3Linux
InfineonModusToolboxmtb-hal-cat12.4.3ModusToolboxX
NXPMCUXpresso SDKSDK_2.x_EVKB-IMXRT10502.16iMXRT1051B1052BX
NXPPlatformSDK_S32K1_2022_02AUTOSAR MCAL4.4MCAL
RenesasSynergy Software PackageHAL2.6.0SSP
STMicroelectronicsSTM32CubeSTM32CubeF4V1.28.1STM32F4X
開発環境

OSS-ECAL開発時のMCUおよび開発環境は、次の通りです。

HALNAMEメーカ開発ボードMCUIDE
ARDUINOArduino1.Mega 2560 Rev3
2.Arduino Pro Mini 3.3V
ATmega2560
ATmega328P
Arduino IDE 2.3.3
MBEDSTMicroelectronicsSTM32 Nucleo-64 boardsSTM32F401RETxArm Keil Studio Cloud
LinuxBeagleBoardBeagleBone BlackTI AM335x
ModusToolboxInfineonCY8CPROTO-063-BLE PSoC 6 BLE Prototyping KitCYBLE-416045-02ModusToolbox
iMXRT1051B1052BNXPIMXRT1050-EVKBi.MX RT1050MCUXpresso IDE
MCALSTMicroelectronicsS32K144EVB-Q100S32K144S32 Design Studio for S32 Platform
SSPRenesasS7G2 SKR7FS7G27H3A01CFCe² studio for Renesas Synergy
STM32F4STMicroelectronicsSTM32 Nucleo-64 boardsSTM32F401RETxSTM32CubeIDE

File構成

フォルダ*ファイル概要
24xx256_HALNAME_VERSION/samplesample.c (.cpp)サンプル・アプリケーション・プログラム
sample.hサンプル・アプリケーション・ヘッダ
24xx256_HALNAME_VERSIONo24xx256.c (.cpp)24xx256シリーズ用OSS-ECALプログラム
o24xx256.h24xx256シリーズ用OSS-ECALヘッダ
oss_ecal.hOSS-ECAL 共通ヘッダ (Ver 01.00.00以降、AUTOSARはVer01.01.07以降)
24xx256_ARDUINO.inoArduino用サンプル・アプリケーション・プログラム
user_setting.c (.cpp)ユーザ設定定数・テーブル
user_setting.hユーザ設定ヘッダ
oHAL_i2c_stm32f4.cSTM32Cube FW_F4用HALプログラム
oHAL_i2c_stm32f4.hSTM32Cube FW_F4用HALヘッダ
readme.mdReadme
OSS-ECAL Terms of Use.txtOSS-ECAL利用条件

* HALNAMEは、HALサポートを参照してください。

イメージ:24xx256_IMXRT1050_010000

OSS-ECAL ダウンロード

OSS-ECALのダウンロードは、英語版OSS-ECALサイトからお願いいたします。なお、ダウンロードを行う際は、英語版OSS-ECALサイトにログインしてから操作してください。

組込み方法

下記を参考にユーザプログラムにAPI関数を組み込んでください。

Pin A2の設定は、user_setting.hの以下のコードで設定してください。

// Device address Code bit2:A2 bit1:A1 bit0:A0
#define M24xx256_1              0b00000000

Infineon ModusToolbox HALの場合は、I2C Timeoutの設定をuser_setting.hの以下のコードで設定してください。
詳しくは、cyhal_i2c_master_write(), cyhal_i2c_master_read() Parameters timeoutを参照してください。

#define I2C_TIMEOUT             10U     // Timeout[ms] 

STM32Cube FW_F4 HALの場合、I2C Timeout時間は25msです。

注意:
次のコマンドAPI関数は、Read/Writeのデータ長 len によって、Timeoutの時間が異なります。
etSTS o24xx256_PAGE_WRITE( etCMP cmp, uint16 mem_adr, uint16 len, uint8* buf )
etSTS o24xx256_SEQ_READ( etCMP cmp, uint16 mem_adr, uint16 len, uint8* buf )

OSS-ECAL組み込む方法

OSS-ECAL組み込む方法(複数同じ電子部品)

ユーザプログラムに複数のOSS-ECAL(異なるMCU機能の電子部品)を組み込む方法

ユーザプログラムに複数同じ電子部品を組み込む方法

電子部品の入れ替えによるユーザプログラムへの影響低減方法

注意事項

サンプル版OSS-ECALは、優先順位の異なるThread(Task)や割込みで用いることを前提としていません。下記の例のような使い方はしないでください。

例)同じADCグループに各センサーが割り当てられ、優先順位が異なる処理でOSS-ECAL APIを実行すると、正しい値を取得できない場合があります。
ADC Gr0 Ch0 温度センサ AD22100A 100ms周期 Thread(優先順位低)で温度取込み
ADC Gr0 Ch1 圧力センサ MPX5999D イベント割込み(優先順位高)で圧力取込み

OSS-ECAL Japanese
error: コンテンツは保護されている