forked from mfulz_github/qmk_firmware
125 lines
5.2 KiB
Markdown
125 lines
5.2 KiB
Markdown
# 刷写键盘固件
|
||
|
||
<!---
|
||
original document: 0.15.12:docs/newbs_flashing.md
|
||
git diff 0.15.12 HEAD -- docs/newbs_flashing.md | cat
|
||
-->
|
||
|
||
在自定义的固件文件构建出来后,可以刷写到键盘中了。
|
||
|
||
## 将键盘调至DFU(Bootloader)模式
|
||
|
||
在你将自定义固件刷写到键盘前,键盘必须处于特有的刷写模式下。此时,键盘会处于不会响应点击等常规操作的状态,并且一定留意不要打断刷写工作,刷写固件过程中不可以把键盘拔下来。
|
||
|
||
不同的键盘进入刷写模式的方法都是不同的,如果你的键盘运行的是QMK、TMK或PS2AVRGB(Bootmapper客户端)且没有写明特别的操作说明的话,可以依次尝试以下操作:
|
||
|
||
* 按住两边的Shift键,点击Pause
|
||
* 按住两边的Shift键,点击B
|
||
* 拔出键盘,同时按住“空格”键及B键,再插上键盘,等两秒后松开
|
||
* 拔出键盘,按住键盘左上或左下的按键(一般来讲是Escape或左Control),在插上键盘
|
||
* 按重置按键(Reset),一般在PCB背面
|
||
* 在PCB上寻找导出的 `RESET` 和 `GND` 引脚,在插电的情况下短接一下
|
||
|
||
如果上面的方法没有用,且键盘主板上的芯片是 `STM32` 系列,情况要复杂一些。通常在[Discord](https://discord.gg/Uq7gcHh)上寻求帮助是最好的办法,并且很可能需要你提供一些键盘主板的照片 —— 所以如果你能提前准备好,我们沟通起来会快得多。
|
||
|
||
如果没有遇到什么问题,你会在QMK工具箱的输出信息里找到类似下面的黄色文字的信息:
|
||
|
||
```
|
||
*** DFU device connected: Atmel Corp. ATmega32U4 (03EB:2FF4:0000)
|
||
```
|
||
|
||
已进入bootloader状态的设备也可以在设备管理器、系统信息或 `lsusb` 中看到。
|
||
|
||
## 使用QMK工具箱刷写固件
|
||
|
||
使用[QMK工具箱](https://github.com/qmk/qmk_toolbox/releases)刷写固件是最简单的方案。
|
||
|
||
然而该工具箱仅支持Windows及macOS,如果你在使用Linux环境(或是希望用命令行刷写固件),请参阅[在命令行中刷写固件](#使用命令行刷写固件)一节。
|
||
|
||
### 加载固件到QMK工具箱
|
||
|
||
打开QMK工具箱,在Finder或文件管理器中找到固件文件。键盘固件文件名后缀通常是 `.hex` 或 `.bin`,QMK工具箱会尝试将正确的文件拷贝到qmk根目录 `qmk_firmware` 中。
|
||
|
||
在Windows或macOS上,使用下面的指令可以快速打开当前目录。
|
||
|
||
<!-- tabs:start -->
|
||
|
||
#### ** Windows **
|
||
|
||
```
|
||
start .
|
||
```
|
||
|
||
#### ** macOS **
|
||
|
||
```
|
||
open .
|
||
```
|
||
|
||
<!-- tabs:end -->
|
||
|
||
固件文件的文件名格式为:
|
||
|
||
```
|
||
<keyboard_name>_<keymap_name>.{bin,hex}
|
||
<键盘名>_<键映射名>.{bin,hex}
|
||
```
|
||
|
||
例如, `planck/rev5` 的 `default` 键映射对应的文件名是:
|
||
|
||
```
|
||
planck_rev5_default.hex
|
||
```
|
||
|
||
找到固件文件后,将其拖拽至QMK工具箱的"Local file"框,或点击“Open”并定位至固件文件。
|
||
|
||
### 刷写到键盘
|
||
|
||
点击QMK工具箱的`Flash`,将看到如下输出信息:
|
||
|
||
```
|
||
*** DFU device connected: Atmel Corp. ATmega32U4 (03EB:2FF4:0000)
|
||
*** Attempting to flash, please don't remove device
|
||
>>> dfu-programmer.exe atmega32u4 erase --force
|
||
Erasing flash... Success
|
||
Checking memory from 0x0 to 0x6FFF... Empty.
|
||
>>> dfu-programmer.exe atmega32u4 flash "D:\Git\qmk_firmware\gh60_satan_default.hex"
|
||
Checking memory from 0x0 to 0x3F7F... Empty.
|
||
0% 100% Programming 0x3F80 bytes...
|
||
[>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>] Success
|
||
0% 100% Reading 0x7000 bytes...
|
||
[>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>] Success
|
||
Validating... Success
|
||
0x3F80 bytes written into 0x7000 bytes memory (56.70%).
|
||
>>> dfu-programmer.exe atmega32u4 reset
|
||
|
||
*** DFU device disconnected: Atmel Corp: ATmega32U4 (03EB:2FF4:0000)
|
||
```
|
||
|
||
## 使用命令行刷写固件
|
||
|
||
现在已经没有以前那样繁琐了,在编译固件后需要刷写时,打开终端输入如下刷写指令:
|
||
|
||
qmk flash
|
||
|
||
如果未通过命令行工具配置过键盘/键映射名,或有多个目标键盘,可以指定目标键盘和键映射:
|
||
|
||
qmk flash -kb <键盘名> -km <键映射名>
|
||
|
||
QMK将核查键盘配置,并尝试使用合适的bootloader进行刷写。也就是说,你不用关注应该使用什么bootloader,这些重活儿让qmk指令去承担就好。
|
||
|
||
但是,先决条件是键盘配置中已经设置了bootloader,如果未配置,或你的键盘板子不支持配置的刷写方式,你会看到这些错误信息:
|
||
|
||
WARNING: This board's bootloader is not specified or is not supported by the ":flash" target at this time.
|
||
|
||
此时,只能退回到需要指定bootloader的方法,具体参见[刷写固件](zh-cn/flashing.md)指引。
|
||
|
||
## 上手试试键盘吧!
|
||
|
||
恭喜你,你的自定义固件成功刷写到键盘中了,快去试试吧!
|
||
|
||
运气不差的话一切都会是正常工作的,如果不幸遇到了些问题,有一些参考方案可以帮助你排查问题原因。
|
||
键盘测试就简单直接了,依次按一下各按键,检查它是不是发送了正确的输入。可以使用[QMK配置器](https://config.qmk.fm/#/test/)中的测试模式进行测试,即便你的键盘并不运行QMK。
|
||
|
||
还是不行吗?参阅一下FAQ或[通过Discord和我们聊聊](https://discord.gg/Uq7gcHh)吧。
|