CANファームウェアのコンパイル
書き込み前の確認事項
現在のモードと操作手順の確認
- 重要:ツールボードが現在 Klipper-CANモード である場合、ファームウェアをコンパイルした後、コマンドで直接書き込むことができます。このコマンドは自動的に
Katapultにリセットして書き込みを完了します。 - 出荷時状態:ボードには CANモードの
Katapultファームウェアがプリインストールされており、速度は 1M です。 - 状態確認(LED確認):基板上の LED が点滅している場合(下図参照)、
Katapultモードであり、書き込みが可能です。Loading... - モード異常:LED が 点滅しない 場合、ファームウェアが
Katapultではないことを示します。以下のリンクの手順に従って再書き込みを行う必要があります。 Katapult ファームウェアを書き込む
ディップスイッチの設定と物理接続
-
ディップスイッチ設定:現在の状態に関わらず、まず基板上のディップスイッチを CAN モード に設定し、
120Ωスイッチをオンにしてください(下図参照)。Loading... -
デバイス接続:CANケーブルを使用して、ツールボードを UTOC またはブリッジファームウェアが書き込まれた メインボード に接続します。配線は下図を参照してください。
Loading... -
重要確認(ターミネータ抵抗): 完全に電源を切った 状態で、テスターを使用して CAN_H と CAN_L ピン間の抵抗を測定してください。
デバイス 操作説明 ツールボード 120Ωと表示されたジャンパピンを挿入します。メインボード メインボードに接続する場合、同様に 120Ωジャンパピンを挿入してください。UTOCモジュール 抵抗が内蔵されています。 確認方法:
- 完全に電源を切った状態を保ちます。
- テスターを使用して、ツールボードのCANポートの CAN-HとCAN-L 間の抵抗を測定します。
- 結果の判断:
- 約60Ω:正常です。両端の抵抗が正しく接続されています。
- 約140Ω:CAN-HとCAN-Lが逆接続されている可能性があります。
- 約120Ω:
120Ωが接続されていないか、断線しています。 - 約40Ω:余分な抵抗が接続されている可能性があります。中間ノードを確認してください。
コンパイルを開始
ファームウェアコンパイル簡易ガイド
注意事項
- ネットワーク: 上位機(Raspberry Piなど)がネットワークに接続されていることを確認してください。
- ログイン方法: SSH を使用してネットワーク経由でログインし、シリアルポートは無効にしてください。
- 入力方法: キーボードを英数半角モードに設定してください。
SSHログインとユーザー切り替え
MobaXterm、PuTTYなどのツールを使用してSSHで上位機にログインします。
ユーザー切り替え:
- 通常システム(Raspberry Pi公式システムなど)
rootの使用は禁止されています。一般ユーザーに切り替えてください:su <ユーザー名> - FLY上位機(FlyOS-FASTシステム)
rootユーザーでのみログイン可能です(パスワード:mellow)。
ファームウェアコンパイル操作ガイド
Klipperファームウェア設定画面ではキーボード操作のみサポートされており、マウスは使用できません。
| キー | 機能 |
|---|---|
| ↑ / ↓ | カーソルを上下に移動し、メニュー項目を選択 |
| Enter / スペース | 選択を確定、オプションをチェック、またはサブメニューに移動 |
| ESC | 前のメニューに戻る |
| Q | 設定画面を終了 |
| Y | 終了時に保存の確認があれば Y を押して設定を保存 |
ファームウェアのコンパイルを開始する
以下に、ファームウェアのコンパイル方法を説明します:
-
SSH接続後、以下のコマンドを入力してEnterキーを押してください:
cd ~/klipper && rm -rf ~/klipper/.config && rm -rf ~/klipper/out && make menuconfig -
ここで、
rm -rf ~/klipper/.config && rm -rf ~/klipper/outは以前のコンパイルデータとファームウェアを削除します -
make menuconfigはファームウェアをコンパイルするコマンドで、実行後は以下の画面が表示されるはずですLoading... -
Enable extra low-level configuration optionsを選択し、Enterキーを押してください
Loading... -
Micro-controller Architectureメニューに移動し、Raspberry Pi RP2040/RP235xを選択してEnterキーを押してください
Loading... -
Bootloader offsetを選択し、16KiB bootloaderを選択してください
Loading... -
Communication interfaceを選択し、CAN busを選択してください
Loading... -
(4) CAN RX gpio numberを選択し、4を削除して1を入力してください -
(5) CAN TX gpio numberを選択し、5を削除して0を入力してくださいLoading...
- マイクロコントローラ起動時に設定するGPIOピンを選択し、入力:
!gpio5注意英文入力モードで入力してください
!gpio5Loading...- 上図と照らし合わせて確認し、一致していることを確認してから次に進んでください
Qキーを押すと、Save configurationが表示されます。この状態でYキーを押してください
- これで設定が保存され、コマンドラインインターフェースに戻るはずです
- 以下のコマンドを入力してコンパイルを開始してください。時間がかかります
make -j4
- 最後に以下の内容が出力されれば、コンパイルは成功です
- Klipperのバージョンによっては、
out/klipper.binが表示されれば成功を意味しますLinking out/klipper.elf
Creating bin file out/klipper.bin
IDを検索して書き込み
CANBus UUIDのクエリ
- 非印刷状態でIDクエリとファームウェア書き込み操作を実行することを推奨します。印刷プロセスへの干渉を避けるためです。
- 同一のメインボード/ツールボードにおいて、Katapult (CANBoot) ファームウェアとKlipperファームウェアは同一のCAN IDを使用します。
以下の条件を満たしていることを確認してください。満たされていない場合、CAN IDを正常に検索できない可能性があります。
- ホストコンピュータのCANネットワークが正しく構成されている
- ツールボードのCAN通信速度がホストコンピュータと完全に一致している (速度が一致しないと通信できません)
lsusbコマンドを実行した後、1d50:606fデバイス (USB-CANアダプター) が表示される
検索コマンド (システムに応じて選択)
- 通常のホストコンピュータ用検索コマンド
~/klippy-env/bin/python ~/klipper/scripts/canbus_query.py can0 - FLYホストコンピュータ用検索コマンド
python3 ~/klipper/scripts/canbus_query.py can0
検索結果の説明
ケース1: Klipperファームウェアが書き込まれたメインボード/ツールボード
- 表示内容: 1つのCAN IDが表示され、
Application: Klipperと表示されます。 - 説明: デバイスはKlipperファームウェアで動作しており、直接使用できます。このIDはメインボードのIDである可能性も、ツールボードのIDである可能性もあります。
- 識別方法: ツールボードのCAN接続ケーブルを外してから再検索します。そのIDが消えた場合はツールボードのID、まだ残っている場合はメインボードのIDです。
ケース2: メインボード + 書き込み待ちツールボード
- 表示内容: 2つのCAN IDが表示されます。
- 説明: メインボードはKlipperファームウェアで動作しており、ツールボードはCanBootファームウェアで動作しており、書き込みを待っています。
ケース3: UTOC + 書き込み待ちツールボード
- 表示内容: UTOC自体はIDを表示せず、ツールボードのIDのみを表示します。
- 説明: UTOCはブリッジとして機能するのみで、ツールボードがCanBootモードにあることが必要です。
ケース4: IDが表示されない
- 表示内容: 何のIDも表示されません。
- 考えられる原因:
- CANバスがKlipperによって占有されている
- ホストコンピュータのCAN0速度設定が間違っている
- 物理的な配線に異常がある
- デバイスがCanBootモードに入っていない
- 書き込み待機状態: ツールボードがCanBootモードにあると、
Application: CanBootと表示され、ファームウェアLEDが点滅します。この状態でファームウェア書き込みが可能です。 - ID占有時の処理: デバイスがKlipperファームウェアで動作しており、そのIDが設定ファイルに既に記述されている場合、そのIDは表示されません (Klipperによって占有されています)。再表示させるには、設定ファイルでそのIDをコメントアウトし、完全に電源を切って再起動する必要があります。
UUIDをクエリできない場合は、以下を参照してください: CAN問題トラブルシューティングガイド
ファームウェア書き込み
書き込みコマンド
- 以下のコマンドの
241696050c56を、実際にクエリしたUUIDに置き換えてください。 - 注意:
-uパラメータの後にはスペースが必要です。
python3 ~/klipper/lib/canboot/flash_can.py -u 241696050c56
書き込み成功の確認
CAN Flash Success というメッセージが表示されれば、書き込み成功です:
ファームウェア更新
更新方法
ファームウェアを更新する必要がある場合は、以下の手順を実行します:
- ファームウェアを再コンパイルする
- デバイスのCAN IDをクエリできること (またはKlipperがデバイスに接続されていること) を確認する
- 同じ書き込みコマンドを実行する
python3 ~/klipper/lib/canboot/flash_can.py -u <MCU ID>
更新成功例
ファームウェアの起動確認
- ファームウェアが正常に起動するとLEDが点灯します。
Loading...