본문으로 건너뛰기

CAN 펌웨어 컴파일

컴파일 시작

펌웨어 컴파일 간단 가이드

주의사항

  • 네트워크: 상위 컴퓨터(라즈베리파이 등)가 인터넷에 연결되어 있는지 확인하세요.
  • 로그인 방식: 반드시 SSH를 통해 네트워크로 로그인하고, 시리얼 포트는 비활성화하세요.
  • 입력기: 키보드를 영문 반각 모드로 유지하세요.

SSH 로그인 및 사용자 전환

MobaXterm, PuTTY 등의 도구를 사용하여 상위 컴퓨터에 SSH로 로그인하세요.

사용자 전환:

  • 일반 시스템(라즈베리파이 공식 시스템 등)
    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 핀 선택, 입력:gpio17
    Loading...
  • Q 키를 누르면 Save configuration이 나타나고, 이때 Y 키를 누릅니다.
Loading...
  • 이제 설정이 저장되고 명령줄 인터페이스로 돌아갑니다.
  • 아래 명령어를 입력하여 컴파일을 시작합니다. 시간이 다소 걸립니다.
make -j4
Loading...
  • 마지막으로 아래 내용이 출력되면 컴파일 성공입니다.
  • Klipper 버전 문제로 인해 out/klipper.bin만 나타나도 성공을 의미합니다.
    Linking out/klipper.elf
    Creating bin file out/klipper.bin

케이블 연결 검색

  • 펌웨어 플래싱 전에 XT30 데이터 케이블을 사용하여 툴 보드를 UTOC 또는 브리지 펌웨어가 플래싱된 메인보드에 연결하세요. 아래는 참조 배선도입니다.

  • 디핀 스위치가 올바른 위치에 설정되었는지 확인하세요.

    Loading...
  • 전원이 차단된 상태에서 멀티미터를 사용하여 CAN H와 CAN L 간의 저항값이 60Ω 정도인지 확인하세요. 120Ω이라면 120Ω 점퍼를 연결하고, 40Ω 정도라면 점퍼를 제거하세요.

    Loading...
  • XT30 데이터 케이블을 사용하여 툴 보드를 UTOR 또는 USB-CAN 브리지가 플래싱된 메인보드에 연결하면, 메인보드의 LED가 깜빡입니다.

경고
  • LED가 깜빡이지 않으면 Katapult 펌웨어를 다시 플래싱하세요: Katapult 펌웨어 플래싱
  • LED가 깜빡이지 않으면 Katapult 펌웨어를 플래싱한 후 다음 단계를 진행하세요.

ID 검색 및 플래싱

CANBus UUID 조회

작업 전 주의사항
  • 인쇄 중이 아닌 상태에서 ID 조회 및 펌웨어 플래싱 작업을 수행하는 것이 좋습니다. 인쇄 과정에 간섭을 방지합니다.
  • 동일한 메인보드/툴보드의 Katapult(CANBoot) 펌웨어와 Klipper 펌웨어는 동일한 CAN ID를 사용합니다.
전제 조건

다음 조건을 충족해야 CAN ID를 정상적으로 검색할 수 있습니다:

  1. 상위 컴퓨터의 CAN 네트워크가 올바르게 구성되었습니다.
  2. 툴보드의 CAN 속도가 상위 컴퓨터와 완전히 일치합니다.(속도가 일치하지 않으면 통신할 수 없습니다.)
  3. 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 펌웨어가 플래싱된 메인보드/툴보드

  • 표시 효과: 하나의 CAN ID가 표시되며 Application: Klipper 라는 메시지가 나타납니다.
  • 설명: 장치가 이미 Klipper 펌웨어로 실행 중이며 바로 사용할 수 있습니다. 이 ID는 메인보드 ID일 수도 있고 툴보드 ID일 수도 있습니다.
  • 구분 방법: 툴보드의 CAN 연결선을 분리한 후 다시 검색합니다. 해당 ID가 사라지면 툴보드에 속한 것이고, ID가 여전히 있으면 메인보드에 속한 것입니다.
Loading...

상황 2: 메인보드 + 플래싱 대기 중인 툴보드

  • 표시 효과: 두 개의 CAN ID가 표시됩니다.
  • 설명: 메인보드는 Klipper 펌웨어로 실행 중이고, 툴보드는 CanBoot 펌웨어로 실행 중이며 플래싱을 기다리고 있습니다.
Loading...

상황 3: UTOC + 플래싱 대기 중인 툴보드

  • 표시 효과: UTOC 자체는 ID를 표시하지 않으며, 툴보드의 ID만 표시됩니다.
  • 설명: UTOC는 브리지 역할만 하며, 툴보드가 CanBoot 모드인지 확인해야 합니다.
Loading...

상황 4: ID 미표시

  • 표시 효과: 어떤 ID도 표시되지 않습니다.
  • 가능한 원인:
    1. CAN 버스가 Klipper에 의해 점유됨
    2. 상위 컴퓨터의 CAN0 속도 설정 오류
    3. 물리적 배선 이상
    4. 장치가 CanBoot 모드로 진입하지 않음
Loading...

중요 알림
  • 플래싱 대기 상태: 툴보드가 CanBoot 모드일 때 Application: CanBoot가 표시되고 펌웨어 LED가 깜빡이며 이때 펌웨어 플래싱을 수행할 수 있습니다.
  • ID 점유 처리: 장치가 이미 Klipper 펌웨어로 실행 중이고 ID가 설정 파일에 입력된 경우 ID는 표시되지 않습니다(Klipper에 의해 점유됨). 다시 표시하려면 설정에서 해당 ID를 차단하고 완전히 전원을 차단한 후 재부팅해야 합니다.
문제 해결

UUID를 조회할 수 없는 경우 다음 가이드를 참조하십시오: CAN 문제 해결 가이드

펌웨어 플래싱

플래싱 명령어

  1. 아래 명령어의 241696050c56를 실제 조회한 UUID로 바꾸십시오.
  2. 참고: -u 매개변수 뒤에 공백이 있어야 합니다.
python3 ~/klipper/lib/canboot/flash_can.py -u 241696050c56

플래싱 성공 확인

CAN Flash Success 메시지가 나타나면 플래싱 성공입니다:

Loading...

펌웨어 업데이트

업데이트 방법

펌웨어를 업데이트해야 할 때는 다음을 수행하십시오:

  1. 펌웨어를 다시 컴파일합니다.
  2. 장치의 CAN ID를 조회할 수 있는지(또는 Klipper가 장치에 연결되어 있는지) 확인합니다.
  3. 동일한 플래싱 명령어를 실행합니다.
python3 ~/klipper/lib/canboot/flash_can.py -u <MCU ID>

업데이트 성공 예시

Loading...

펌웨어 실행 확인

  • 펌웨어가 정상적으로 실행되면 LED가 켜집니다.
    Loading...
Loading...