1. はじめに
どうも、私が、いままで、いろいろなプロジェクトで使っていた、mbed LPC1768 (以後、LPC1768)のボードが生産されなくなっているようです(主要な電子部品販売店では、在庫0となっています。2024年5月時点)。それで、2017年?頃から出てきた、L-Tek FF LPC546XX (以後 LPC546XX)ボードに移行しようとしています。とりあえず、LPC1768で動いていたプロジェクトの1つが、LPC546XXで動きそうなので、どのように移行したのか、記録を残したいと思います。
2. 背景
我々は、Wiki IoT/Bot Computing と名付けた IoTシステムを開発中です。これは、Raspberry Pi をエッジシステム(Bot)とし、PukiWiki ページをサーバシステム(C & C サーバ)としたIoTシステムです。Wiki IoT/Bot Computing はWiki(PukiWiki)によって、人とBotの共同作業を容易にしよう、と思っています。Wiki Iot/Bot Computing では、エッジシステムの先に、TWE-Liteを使った無線センサネットワーク(WSN)を接続することも可能になっていて、WSNの端末として、TWE-LiteとLPC1768を組み合わせたものを使っていました。
また、我々はProject TESLAと名付けたプロジェクトを実施中です。このプロジェクトは、規格化した部品を使って組み立てられた「物」の構造・機能・状態の情報を外部に吸出し、その情報を遠隔地に転送し、遠隔地でその情報を受信し、遠隔地にある規格化した部品を使って、送信元の「物」と同じ、構造・機能・状態を持つ「物」を組み立てることにより、形だけでなく、内部構造や機能も含めて、遠隔地への転送を実現しようとするものです。現在、規格化した部品の例として、正6面体のテスラダイスと名付けた部品を開発中です。このテスラダイスも、中に LPC1768を組み込んで使っていました。
以下がLPC1768の端子割り当て図です。
ところが、2020年頃から、主要な電子部品販売店から、LPC1768の在庫が無くなってきているようです。また、LPC1768で使っていたオンラインコンパイラが、2022年12月より、使えなくなってしまいました。
そこで、オンラインコンパイラで開発していたプロジェクトを、 Keil Studio Cloud に移したのですが、mbed OS (mbed OS2)がdeprecatedになってしまい、mbed OS5に移行せざるをえなくなってしまいました。 LPC1768で mbed OS 2 から mbed OS 5に移行を試みているのですが、簡単にはできず、いまだにエラーが消えないプロジェクトが残っています。
以下、苦労している書き換え必要か所です。
- SD
https://qiita.com/TwDaiki/items/3370cb777d0c2dd3396e - UART(Serial)
https://kajiyaken.hatenablog.jp/entry/2021/08/17/014810 - タイマー割込み(ticker)
https://forums.mbed.com/t/mbed-os-5-ticker/16357
現時点で、以下のような修正を行って、一部のプロジェクトのコンパイルは通るようになりました。
- 今までのSerial を、RawSerialに書き換える
- Ticker の attach を attach_us に書き換える
これは他のmbedのボードでも同じではあるのですが、どうせmbed OSの ver. up をするためにプログラムを書き換えるのであれば、LPC1768以外のボードに移行した方が良さそうです。
また2024年5月時点で、USB Cable で LPC1768 を Windows 11のPCと接続して、USBのUARTのterminalを開こうとすると、com port が見つからなくなりました。driver を update しようとしても、update できませんでした。
3. ということで L-Tek FF LPC546XX
LPC1768はもう使えなくなりそう、ということでMbed のboardのページを見ていたところ、LPC1768によく似たボードが見つかりました。これがL-Tek FF LPC546XX です。
端子割り当て図もLPC1768とよく似ています。一見、Serial (UART) が1つ少ないくらいです。RAMもLPC1768が32kBだったのが200kBと大分増えて、使いやすそうです。
4. ところが (その1)
コンパイル時に、以下のような"list index out of range"というエラーが出てコンパイルが止まりました。
オンラインのkeil mbed cloud ではこのようなエラーは出ていませんでした。
どこでエラーが出ているか、ソースコードの一部をコメントアウトしたりしながら、探ると、どうも、漢字(日本語)が入ったコメントがあるとエラーが出ているらしいことがわかりました。コメントを英数字に書き直すことでこのエラーが出なくなりました。
5. ところが (その2)
RAMをちょっと沢山使うプログラムをLPC1768からLPC546XXに、新しく使い始めた、Keil Studio Cloud 上で移植しようとしたところ、コンパイルは通るのだけど、実行時に動かない現象が発生しました。コンパイル結果を見ると、200kBあるはずのRAMが20KBになっていました。
この問題を解決するためには、設定ファイルのheap領域の宣言文を書き換える必要があることを教えていただきました。しかしながら、オンラインのKeil Studio Cloudでは書き換えることができず、オフラインのmbed studio で書き換える必要がある、ということでした。
そこで、手元のPCにmbed studioをinstall し、
以下のページなどを参考にしてプログラムを作成しました。このとき、OSを、mbed OS 5.15.9 (2024年5月時点)としています。そして、プロジェクトディレクトリの、
[ < workspace > ] > [ < project > ] > mbed-os >
targets > TARGET_NXP > TARGET_MCUXpresso_MCUS >
TARGET_MCU_LPC546XX>device > TOOLCHAIN_ARM_STD >
LPC54682J512.sct
の #define Heap_Size 0x00400 を、例えば#define Heap_Size 0x1F000 に変更して、RAMの容量を増やすことができました。
6. ところが(その3)
コンパイル(コンパイル)は通るのですが、実行を行うと、以下のような"pinmap not found" というエラーが出ました。
Webで検索するなどして調べると、どうも、端子(Pin)の番号と、それに割り当てた
役割が異なると出てくるエラーのようです。
以下はLPC1768(左)とLPC546XX(右)の端子配置図を並べた図です。赤い丸で囲んだ部分と、右にP0_xxとP1_xxがついているのと、USBコネクタが違うことはすぐに分かります。
もう一度、端子の割り当ての左右の図を、よく見くらべると、上の、赤い丸印で囲った部分の他にも異なる部分があるのがわかりました。
これを拡大したのが以下の図です。左がLPC1768、右がLPC546XXです。
LPC1768とLPC546XXでは、rxとtxの割り当てが逆であることがわかります。
ということで、Serial(UART) の rx と tx を交換して、動くようになりました。
7. ところが (その4)
LPC546XXのpinoutの図のちょっと下に、
p15:
supports analog input for measuring 4-20 mA
supports digital input only in pull down mode
does not support digital output
という記述がありました。p15をデジタル入力として使おうと思っていたのですが、つねに、pull down であるのと、いろいろ実験をしてみると、この pull down 抵抗が結構小さいことが分かりました(どうも、電流計測をするためのpin なので、当たり前ではありますね)。それと、まだ仕様書からは読み切れていないのですが、p20 は、どうも、つねに、pull up されているように思えます。
ということで、デジタル値の入力を行う部分で、p15とp20 を避けるように配置することで、入力ができるようになりました。
もう一つ、p29 と p30 は入れ替わっているように思います。
8. ところが (その5)
LPC1768を使ったTesla Project では、GPIOのうち、6つをデジタル入力とし、赤外線フォトトランジスタ、L-31ROPT1Cのコレクタを3.3V、エミッタに47KΩの抵抗をつないで、GNDと接続し、エミッタと抵抗の接続箇所をこのデジタル入力に設定したGPIOに接続して赤外線の検知を行っていました。ところが、LPC1768をLPC546XXに置き換えると、光が当たっていない時にLow になるはずの入力が High になっています。真っ暗だと、Low になることもわかりました。いろいろ実験をしていると、なぜか、ちゃんと動くときもあります。それでオシロスコープで入力波形を見ると、矩形波になるはずの入力電圧が、のこぎり波になっていました。L-31ROPT1Cのデータシートをよく読みなおすと、Rise/Fall Time が 15μ sec なのですが、このときの抵抗が1KΩとなっていました。また、フォトトランジスタの特性について記述した以下のようなページも見つかりました。
そこで、エミッタにつないだ47KΩの抵抗を10KΩに変更したところ、うまく動くようになりました。どうも、LPC1768の入力のPullNoneの時の抵抗が、LPC546XXのときと比べて、ずっと小さかったようです。
9. 終わりに
なんとか、Project TESLAのテスラダイスが使っているチップは、LPC1768からLPC546XXに移行できそうです。
LPC546XXは、日本の主要部品屋さんでは扱っていないみたいです。扱ってくれると嬉しいです。
現時点で買うのは日本では私だけかもしれないですが。(Raspberry Pi Pico に移行した方が速い?)
LPC546XXの利用者が増えて便利になると嬉しいです。
10. 謝辞
-
https://forums.mbed.com/
で丁寧に私の質問について調べて答えていただいた皆様に感謝します。 - この記事は、2024年5月23日の、IoTLT vol.111のLTの内容に一部加筆・修正した物です。いつもお世話になっているIoTLTの関係者の皆様に感謝します。
- この活動(研究)の一部は科研費 基盤研究(C) 21K11858 の補助を受けています。