Компиляция прошивки CAN
Начало компиляции
Краткое руководство по компиляции прошивки
Примечания
- Сеть: Убедитесь, что хост-компьютер (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-пинов для установки при запуске микроконтроллера, ввод: gpio17
Loading...
- Нажмите клавишу
Q, появится Save configuration, затем нажмите клавишуY.
- Теперь конфигурация должна быть сохранена, и вы вернетесь в командную строку.
- Введите следующую команду для начала компиляции. Это займет некоторое время.
make -j4
- Если в конце появится следующий вывод, компиляция прошла успешно.
- В зависимости от версии Klipper, достаточно появления
out/klipper.bin, чтобы считать компиляцию успешной.Linking out/klipper.elfCreating bin file out/klipper.bin
Поиск подключения
-
Перед прошивкой подключите плату инструмента с помощью кабеля XT30 к UTOC или материнской плате с прошивкой моста. Ниже представлена схема подключения для справки.
-
Убедитесь, что переключатели DIP установлены в правильные положения.
Loading... -
Убедитесь, что сопротивление между CAN H и CAN L при отключенном питании составляет около
60 Омс помощью мультиметра. Если оно составляет120 Ом, необходимо установить перемычку120 Ом. Если оно около40 Ом, перемычку нужно удалить.Loading... -
После подключения платы инструмента к UTOR или материнской плате с прошивкой USB-моста CAN с помощью кабеля XT30, на плате начнет мигать светодиод.
- Если светодиод не мигает, перепрошейте прошивку Katapult: Прошивка Katapult
- Если светодиод не мигает, после прошивки Katapult переходите к следующему шагу.
Поиск ID и прошивка
Запрос UUID CAN-шины
- Рекомендуется выполнять запрос 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
- Отображение: Отображается один CAN ID с указанием
Application: Klipper - Пояснение: Устройство работает под управлением прошивки Klipper, можно использовать напрямую. Этот ID может принадлежать как основной плате, так и инструментальной плате.
- Способ различения: Отключите CAN-кабель инструментальной платы и выполните поиск снова. Если этот ID исчезнет, он принадлежит инструментальной плате; если ID останется, он принадлежит основной плате.
Случай 2: Основная плата + инструментальная плата, ожидающая прошивки
- Отображение: Отображаются два CAN ID
- Пояснение: Основная плата работает под управлением прошивки Klipper, инструментальная плата работает под управлением прошивки CanBoot, ожидает прошивки.
Случай 3: UTOC + инструментальная плата, ожидающая прошивки
- Отображение: Сам UTOC не отображает ID, отображается только ID инструментальной платы
- Пояснение: UTOC выступает только в качестве моста, необходимо убедиться, что инструментальная плата находится в режиме CanBoot.
Случай 4: ID не отображается
- Отображение: Никакие ID не отображаются
- Возможные причины:
- Шина CAN занята Klipper
- Ошибка конфигурации скорости CAN0 на верхнем компьютере
- Неисправность физического подключения
- Устройство не вошло в режим CanBoot
- Состояние ожидания прошивки: Если инструментальная плата находится в режиме CanBoot, будет отображаться
Application: CanBoot, а светодиод прошивки будет мигать. В этом состоянии можно выполнять прошивку. - Обработка занятости ID: Если устройство уже работает под управлением прошивки Klipper и ID указан в конфигурационном файле, ID не будет отображаться (занят Klipper). Для повторного отображения необходимо заблокировать этот ID в конфигурации и выполнить полное отключение и перезапуск.
Если не удается найти UUID, обратитесь к: Руководство по устранению неисправностей CAN
Прошивка
Команда прошивки
- Замените
241696050c56в команде ниже на фактически найденный UUID - Примечание: После параметра
-uдолжен быть пробел
-
FlyOS-FAST 1.3.8 и выше или системы, обновлявшие Klipper после 9 апреля 2026 года, используйте новую команду:
python3 ~/klipper/lib/katapult/flashtool.py -u 241696050c56 -
Старые версии системы (FAST до 1.3.8 или Klipper не обновлялся до 9 апреля 2026 года), используйте старую команду:
python3 ~/klipper/lib/canboot/flash_can.py -u 241696050c56
Подтверждение успешной прошивки
Появление сообщения CAN Flash Success означает успешную прошивку:
Обновление прошивки
Метод обновления
Для обновления прошивки необходимо:
- Перекомпилировать прошивку
- Убедиться, что CAN ID устройства доступен для запроса (или Klipper подключен к устройству)
- Выполнить ту же команду прошивки
-
FlyOS-FAST 1.3.8 и выше или системы, обновлявшие Klipper после 9 апреля 2026 года:
python3 ~/klipper/lib/katapult/flashtool.py -u <MCU ID> -
Старые версии системы (FAST до 1.3.8 или Klipper не обновлялся до 9 апреля 2026 года):
python3 ~/klipper/lib/canboot/flash_can.py -u <MCU ID>
Пример успешного обновления
Проверка запуска прошивки
- Если прошивка запущена нормально, светодиод загорится.
Loading...