CAT24C512

CAT24C512は、onsemi製の65,536words × 8 bitsのEEPROM (Electrically Erasable Programmable Read-Only Memory) chipです。CAT24C512のOSS-ECAL(電子部品抽象化レイヤのオープンソースソフトウェア:Open Source Software for Electronic Components Abstraction Layer)を提供致します。
MCUインタフェース:I2C

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

CAT24C512

概要

CAT24C512は、EEPROM シリアル512Kb I2Cで、内部的には各8ビットの65,536ワードで構成しています。
128バイトのページ書き込みバッファを備え、Standard(100kHz)、Fast(400kHz)、Fast-Plus(1MHz)のI2Cプロトコルをサポートしています。
WPピンをHighにすることにより、書き込み動作を禁止することができます(これによりメモリ全体が保護されます)。
外部アドレス・ピンにより、同一バス上で最大8個のCAT24C512デバイスをアドレス指定できます。
オンチップECC(誤り訂正符号)は、デバイスを高信頼性アプリケーションに適しています。

特徴

  • Standard(100kHz)、Fast(400kHz)、Fast-Plus(1MHz)のI2Cプロトコルをサポート
  • 電源電圧範囲 1.8 V~5.5 V
  • 128バイト・ページ書き込みバッファ
  • メモリ全体のハードウェア書き込み保護
  • I2Cバス入力(SCLとSDA)のシュミットトリガとノイズ抑制フィルタ
  • 低消費電力CMOS技術
  • 1,000,000 プログラム/消去サイクル
  • 100年間データ保持
  • 工業用および拡張温度範囲
  • 8ピン、SOIC、TSSOP、8パッドUDFNおよび8ボールWLCSPパッケージ
  • これらのデバイスは鉛フリー、ハロゲンフリー/BFRフリーで、RoHSに準拠しています。

OSS-ECAL仕様

API関数

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

oCAT24C512_BYTE_WRITE関数は、CAT24C512に対して指定したアドレスmem_adrにvalの値をWriteするAPI関数です。この関数は、書き込み完了までの時間(iCAT24C512_WRITE_TIME [ms])が経過するまで、戻り値eSTS_EXEを返します。

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

戻り値etSTSOSS-ECALステータスコード
eSTS_FIN正常終了
eSTS_EXE実行中
eSTS_ERR_PARAMETERパラメータエラー(メモリアドレス)
eSTS_ERR_I2C_OBJECTI2Cオブジェクト選択エラー
eSTS_ERR_OTHERS_RUN他のコンポーネントが処理実行中
eSTS_ERR_HAL_OTHERS_RUN他のアプリケーションがHAL実行中
eSTS_ERR_HAL_I2CHAL I2Cエラー
引数 INetCMP cmpOSS-ECAL コンポーネントコード
uint16 mem_adrメモリアドレス0x0000 to 0xffff
uint8 val書き込むデータ
etSTS oCAT24C512_PAGE_WRITE( etCMP cmp, uint16 mem_adr, uint16 len, uint8* buf )

oCAT24C512_PAGE_WRITE関数は、CAT24C512に対して指定したアドレスmem_adrから順番にbuf[0]からbuf[len-1]の値をWriteするAPI関数です。この関数は、書き込み完了までの時間(iCAT24C512_WRITE_TIME [ms])が経過するまで、戻り値eSTS_EXEを返します。

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

戻り値etSTSOSS-ECALステータスコード
eSTS_FIN正常終了
eSTS_EXE実行中
eSTS_ERR_PARAMETERパラメータエラー(メモリアドレス)
eSTS_ERR_I2C_OBJECTI2Cオブジェクト選択エラー
eSTS_ERR_OTHERS_RUN他のコンポーネントが処理実行中
eSTS_ERR_HAL_OTHERS_RUN他のアプリケーションがHAL実行中
eSTS_ERR_HAL_I2CHAL I2Cエラー
引数 INetCMP cmpOSS-ECAL コンポーネントコード
uint16 mem_adrメモリアドレス0x0000 to 0xffff
uint16 len書き込むByte数 (Max 128)
uint8* buf書き込むデータバッファ
etSTS oCAT24C512_IMM_ADR_READ( etCMP cmp, uint8* rlt )

oCAT24C512_IMM_ADR_READ関数は、CAT24C512に対して前回のReadまたはWriteしたアドレス + 1から1Byte分の値をReadし、rltに保存するAPI関数です。

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

戻り値etSTSOSS-ECALステータスコード
eSTS_FIN正常終了
eSTS_ERR_I2C_OBJECTI2Cオブジェクト選択エラー
eSTS_ERR_OTHERS_RUN他のコンポーネントが処理実行中
eSTS_ERR_HAL_OTHERS_RUN他のアプリケーションがHAL実行中
eSTS_ERR_HAL_I2CHAL I2Cエラー
引数 INetCMP cmpOSS-ECAL コンポーネントコード
引数 OUTuint8* rlt読み込むデータ
etSTS oCAT24C512_SELECT_READ( etCMP cmp, uint16 mem_adr, uint8* rlt )

oCAT24C512_SELECT_READ関数は、CAT24C512に対して指定したアドレスmem_adrから1Byte分の値をReadし、rltに保存するAPI関数です。

備考 :

戻り値etSTSOSS-ECALステータスコード
eSTS_FIN正常終了
eSTS_ERR_PARAMETERパラメータエラー(メモリアドレス)
eSTS_ERR_I2C_OBJECTI2Cオブジェクト選択エラー
eSTS_ERR_OTHERS_RUN他のコンポーネントが処理実行中
eSTS_ERR_HAL_OTHERS_RUN他のアプリケーションがHAL実行中
eSTS_ERR_HAL_I2CHAL I2Cエラー
引数 INetCMP cmpOSS-ECAL コンポーネントコード
uint16 mem_adrメモリアドレス0x0000 to 0xffff
引数 OUTuint8* rlt読み込むデータ
etSTS oCAT24C512_SEQ_READ( etCMP cmp, uint16 mem_adr, uint16 len, uint8* buf )

oCAT24C512_SEQ_READ関数は、CAT24C512に対して指定したアドレスmem_adrから順番にlen分のデータを読み込み、buf[0]からbuf[len-1]に保存するAPI関数です。

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

戻り値etSTSOSS-ECALステータスコード
eSTS_FIN正常終了
eSTS_ERR_PARAMETERパラメータエラー(メモリアドレス)
eSTS_ERR_I2C_OBJECTI2Cオブジェクト選択エラー
eSTS_ERR_OTHERS_RUN他のコンポーネントが処理実行中
eSTS_ERR_HAL_OTHERS_RUN他のアプリケーションがHAL実行中
eSTS_ERR_HAL_I2CHAL I2Cエラー
引数 INetCMP cmpOSS-ECAL コンポーネントコード
uint16 mem_adrメモリアドレス0x0000 to 0xffff
uint16 len読み込むByte数
引数 OUTuint8* buf読み込むデータバッファ
etSTS oCAT24C512_WP_EN( etCMP cmp )

oCAT24C512_WP_EN関数は、CAT24C512に対してWrite protect enable (write disable) = “Hi” 出力するAPI関数です。

備考 :

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

oCAT24C512_WP_DIS関数は、CAT24C512に対してWrite protect disable (write enable) = “Low” 出力するAPI関数です。

備考 :

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

File構成

フォルダ*ファイル概要
CAT24C512_HALNAME_VERSION/samplesample.c (.cpp)サンプル・アプリケーション・プログラム
sample.hサンプル・アプリケーション・ヘッダ
CAT24C512_HALNAME_VERSIONoCAT24C512.c (.cpp)CAT24C512用OSS-ECALプログラム
oCAT24C512.hCAT24C512用OSS-ECALヘッダ
CAT24C512_ARDUINO.inoArduino用サンプル・アプリケーション・プログラム
oss_ecal.hOSS-ECAL 共通ヘッダ (Ver 01.00.00以降、AUTOSARはVer01.01.07以降)
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対応表を参照してください。

HAL対応表

HALMCU*開発環境*HALNAME
Arduino 1.8.6ATmega2560
ATmega328P
Mega 2560 Rev3
Arduino Pro Mini 3.3V
ARDUINO
ARM Mbed 6.17.0STM32F401RESTM32 Nucleo-64 boardsMBED
Infineon ModusToolbox HAL Cat1 2.4.3CYBLE-416045-02CY8CPROTO-063-BLE PSoC 6 BLE Prototyping KitModusToolbox
NXP MCUXpresso SDK
iMXRT1051B_1052B
ksdk2_0
MIMXRT1052DVL6AIMXRT1050-EVKBiMXRT1051B1052B
Renesas SSP 2.4.0R7FS7G27H3A01CFCS7G2 SKSSP
STM STM32Cube FW_F4 V1.27.1STM32F401RESTM32 Nucleo-64 boardsSTM32F4
Debian(Linux) v2022.04TI AM335xBeagleBone Black – Rev CLinux

* 開発時のMCUおよび開発環境。
  同じHALであってもMCUや開発環境が異なると動作が合わない場合があります。

OSS-ECAL ダウンロード

ログインしてからダウンロードを行ってください。新規のユーザ登録は、こちらから行ってください。
本OSS-ECALは、サンプル版なのでユーザ登録せずにダウンロードできますが、OSS-ECAL利用条件は承諾後にダウンロードしてください。

Fileダウンロードできない場合、お問合せから型番およびHALの種類をご連絡ください。メール添付でお送りいたします。

組込み方法

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

Pin A0, A1, A2の設定は、user_setting.hの以下のコードで設定してください。
Renesas SSPでのI2C Device Address設定方法

// Device address Code bit2:A2, bit1:A1, bit0:A0
#define CAT24C512_1             0b00000111

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 oCAT24C512_PAGE_WRITE( etCMP cmp, uint16 mem_adr, uint16 len, uint8* buf )
etSTS oCAT24C512_SEQ_READ( etCMP cmp, uint16 mem_adr, uint16 len, uint8* buf )

ユーザプログラムにOSS-ECALを組み込む方法

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

ユーザプログラムに複数の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: コンテンツは保護されている