MAX6675の概要と、MAX6675用OSS-ECALの提供についてご紹介いたします。MAX6675は、Analog Devices(Maxim Integrated)製の温度センサIC ( ±0~+1024℃ )です。
MCUインタフェース:SPI
ご注意:このリソースの元の言語は英語です。 翻訳は概要を便宜的に提供するもので、機械翻訳を使用していることがあり、私たちは翻訳の正確性および妥当性につきましては一切保証いたしません。 また、実際の設計などの前には、必ず最新版Datasheetをご参照くださいますようお願いいたします。
MAX6675
概要
MAX6675は冷接点補償を行い、K型熱電対からの信号をデジタル化します。このコンバータは温度を0.25℃まで分解し、+1024℃までの読み取りが可能で、0℃から+700℃までの温度に対して8 LSBの熱電対精度を示します。 MAX6675は小型の8ピンSOパッケージで提供されます。
特徴
- K熱電対出力の直接デジタル変換
- 冷接点補償
- シンプルなSPI互換シリアルインターフェース
- 12ビット、0.25℃分解能
- オープン熱電対検出
用途
- インダストリアル
- 家電製品
- HVAC
OSS-ECAL仕様
API関数
etSTS oMAX6675( etCMD cmd, stMAX6675_O* rlt )
oMAX6675関数は、引数のコマンドcmdによってMAX6675の処理を実行するAPI関数です。
備考:
戻り値 | etSTS | OSS-ECALステータスコード | |
eSTS_FIN | 正常終了 | ||
eSTS_ERR_MIN | 最小温度エラー(rlt.temperatureは最小温度) | ||
eSTS_ERR_MAX | 最大温度エラー(rlt.temperatureは最大温度) | ||
eSTS_ERR_COMMAND_CODE | コマンド選択エラー | ||
eSTS_ERR_SPI_OBJECT | SPIオブジェクト選択エラー | ||
eSTS_ERR_OTHERS_RUN | 他のコンポーネントが処理実行中 | ||
eSTS_ERR_HAL_OTHERS_RUN | 他のアプリケーションがHAL実行中 | ||
eSTS_ERR_HAL_SPI | HAL SPIエラー | ||
引数 IN | etCMD cmd | OSS-ECALコマンドコード | |
eCMD_CONFIG | MCUのSPI 通信設定コマンド 1. MCUのSPI 通信設定する | ||
eCMD_READ | Registerの値を読み込み、Registerの値を変換してrltに保存するコマンド 1. Registerの値を読み込む 2. 読み込んだ値を rlt.dummy および rlt.ti、rlt.id、rlt.ste に保存する 3. 読み込んだ値を温度に変換する 温度 = (Register b14-b3) / Gain (Min, Max Limit) 4. 温度をrlt.temperature に保存する | ||
引数 OUT | stMAX6675_O* rlt | MAX6675からの受信データ | |
float32 temperature | Register b14-b3 to float 温度[℃] 0.0~1023.75℃ | ||
uint8 dummy | Register b15 to bit0 ダミー | ||
uint8 ti | Register b2 to bit0 THERMOCOUPLE | ||
uint8 id | Register b1 to bit0 DEVICE ID(only 0) | ||
uint8 ste | Register b0 to bit0 STATE |
etSTS oMAX6675_CONFIG(void)
oMAX6675_CONFIG関数は、MCUのSPI通信を設定するAPI関数です。
- MCUのSPI 通信設定する
備考:
戻り値 | etSTS | OSS-ECALステータスコード | |
eSTS_FIN | 正常終了 | ||
eSTS_ERR_SPI_OBJECT | SPIオブジェクト選択エラー | ||
eSTS_ERR_OTHERS_RUN | 他のコンポーネントが処理実行中 | ||
eSTS_ERR_HAL_OTHERS_RUN | 他のアプリケーションがHAL実行中 | ||
eSTS_ERR_HAL_SPI | HAL SPIエラー |
etSTS oMAX6675_READ( stMAX6675_O* rlt )
oMAX6675_READ関数は、MAX6675のRegisterの値を読み込み、Registerの値を変換してrltに保存するAPI関数です。
- Registerの値を読み込む
- 読み込んだ値を rlt.dummy および rlt.ti、rlt.id、rlt.ste に保存する
- 読み込んだ値を温度に変換する
温度 = (Register b14-b3) / Gain (Min, Max Limit) - 温度をrlt.temperature に保存する
備考:
戻り値 | etSTS | OSS-ECALステータスコード | |
eSTS_FIN | 正常終了 | ||
eSTS_EXE | 実行中 | ||
eSTS_ERR_MIN | 最小温度エラー(rlt.temperatureは最小温度) | ||
eSTS_ERR_MAX | 最大温度エラー(rlt.temperatureは最大温度) | ||
eSTS_ERR_SPI_OBJECT | SPIオブジェクト選択エラー | ||
eSTS_ERR_OTHERS_RUN | 他のコンポーネントが処理実行中 | ||
eSTS_ERR_HAL_OTHERS_RUN | 他のアプリケーションがHAL実行中 | ||
eSTS_ERR_HAL_SPI | HAL SPIエラー | ||
引数 OUT | stMAX6675_O* rlt | MAX6675からの受信データ | |
float32 temperature | Register b14-b3 to float 温度[℃] 0.0~1023.75℃ | ||
uint8 dummy | Register b15 to bit0 ダミー | ||
uint8 ti | Register b2 to bit0 THERMOCOUPLE | ||
uint8 id | Register b1 to bit0 DEVICE ID(only 0) | ||
uint8 ste | Register b0 to bit0 STATE |
HALサポート
OSS-ECALのHAL対応は、次の通りです。(順次拡大中)尚、同じHALであってもVerやMCU、開発環境が異なると動作が合わない場合がありますので、ご注意ください。
メーカ | SDK/IDE ツール | HAL名称 | Ver | HALNAME | Support |
---|---|---|---|---|---|
Arduino | Arduino IDE | Arduino | 1.8.6 | ARDUINO | X |
Arm | Keil MDK v6 | Mbed OS | 6.17.0 | MBED | X |
Debian | – | GNU/Linux | 10.3 | Linux | X |
Infineon | ModusToolbox | mtb-hal-cat1 | 2.4.3 | ModusToolbox | X |
NXP | MCUXpresso SDK | SDK_2.x_EVKB-IMXRT1050 | 2.16 | iMXRT1051B1052B | X |
NXP | PlatformSDK_S32K1_2022_02 | AUTOSAR MCAL | 4.4 | MCAL | – |
Renesas | Synergy Software Package | HAL | 2.6.0 | SSP | X |
STMicroelectronics | STM32Cube | STM32CubeF4 | V1.28.1 | STM32F4 | X |
開発環境
OSS-ECAL開発時のMCUおよび開発環境は、次の通りです。
HALNAME | メーカ | 開発ボード | MCU | IDE |
---|---|---|---|---|
ARDUINO | Arduino | 1.Mega 2560 Rev3 2.Arduino Pro Mini 3.3V | ATmega2560 ATmega328P | Arduino IDE 2.3.3 |
MBED | STMicroelectronics | STM32 Nucleo-64 boards | STM32F401RETx | Arm Keil Studio Cloud |
Linux | BeagleBoard | BeagleBone Black | TI AM335x | – |
ModusToolbox | Infineon | CY8CPROTO-063-BLE PSoC 6 BLE Prototyping Kit | CYBLE-416045-02 | ModusToolbox |
iMXRT1051B1052B | NXP | IMXRT1050-EVKB | i.MX RT1050 | MCUXpresso IDE |
MCAL | STMicroelectronics | S32K144EVB-Q100 | S32K144 | S32 Design Studio for S32 Platform |
SSP | Renesas | S7G2 SK | R7FS7G27H3A01CFC | e² studio for Renesas Synergy |
STM32F4 | STMicroelectronics | STM32 Nucleo-64 boards | STM32F401RETx | STM32CubeIDE |
File構成
フォルダ* | ファイル | 概要 |
---|---|---|
MAX6675_HALNAME_VERSION/sample | sample.c (.cpp) | サンプル・アプリケーション・プログラム |
sample.h | サンプル・アプリケーション・ヘッダ | |
MAX6675_HALNAME_VERSION | oMAX6675.c (.cpp) | MAX6675用OSS-ECALプログラム |
oMAX6675.h | MAX6675用OSS-ECALヘッダ | |
MAX6675_ARDUINO.ino | Arduino用サンプル・アプリケーション・プログラム | |
oss_ecal.h | OSS-ECAL 共通ヘッダ (Ver 01.00.00以降、AUTOSARはVer01.01.07以降) | |
oTypes.h | AUTOSAR用typedefヘッダファイル | |
user_setting.c (.cpp) | ユーザ設定定数・テーブル | |
user_setting.h | ユーザ設定ヘッダ | |
oHAL_i2c_stm32f4.c | STM32Cube FW_F4用HALプログラム | |
oHAL_i2c_stm32f4.h | STM32Cube FW_F4用HALヘッダ | |
readme.md | Readme | |
OSS-ECAL Terms of Use.txt | OSS-ECAL利用条件 |
* HALNAMEはHAL対応表を参照してください。
OSS-ECAL ダウンロード
OSS-ECALのダウンロードは、英語版OSS-ECALサイトからお願いいたします。なお、ダウンロードを行う際は、英語版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 イベント割込み(優先順位高)で圧力取込み