-
-
Notifications
You must be signed in to change notification settings - Fork 3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Documentation: How to flash BlackPill, BluePill and other STM32 based boards with zmk #1711
Comments
You could use https://github.com/qmk/qmk_toolbox to simplify things a bit. You'll have to use the hardware reset buttons to start the bootloader mode on STM32 boards though (cf, #1086). |
There is also a port of the uf2 bootloader to STM32F3 and F4 boards you can flash through DFU anf then access using the normal double tap reset sequence https://github.com/adafruit/tinyuf2 |
Flashing instructions for boards supported in upstream Zephyr can be found in the Zephyr docs: see WeAct BlackPill F401, F411). It strikes me as a bad idea for ZMK to replicate this information, though some mention of upstream tooling and documentation would be appropriate. |
@ReFil if you can shade some light here,
|
Yes, just short reset to gnd twice in rapid succession Uf2 files |
Thank you for the update, I just found old thread on discord and Pete mentioned that Current Blackpill (STM32f4x1) code partition is upstream, Here. Any idea what kind of change I am looking for? &flash0 {
partitions {
compatible = "fixed-partitions";
#address-cells = <1>;
#size-cells = <1>;
boot_partition: partition@0 {
label = "mcuboot";
reg = <0x00000000 DT_SIZE_K(32)>;
read-only;
};
/*
* The flash starting at offset 0x00008000 and ending at
* offset 0x0001ffff (sectors 2 through 4) is reserved for
* use by the application.
*/
slot0_partition: partition@20000 {
label = "image-0";
reg = <0x00020000 DT_SIZE_K(128)>;
};
slot1_partition: partition@40000 {
label = "image-1";
reg = <0x00040000 DT_SIZE_K(128)>;
};
scratch_partition: partition@60000 {
label = "image-scratch";
reg = <0x00060000 DT_SIZE_K(128)>;
};
};
}; |
After being spoiled by how easy it is to flash nice!nanos, I was a little shocked by how hard it is for my new blackpill controller.
Even though these boards are not used much with zmk keyboards I think it would be good to improve the documentation.
In the meantime, hopefully this issue will start ranking on google.
How to flash a BlackPill, BluePill and other STM32 based boards
To flash them you need to install dfu-utils and then use these commands:
Here you should take note of the
alt=0
parameter of theInternal Flash
line. You will then use it in the next command to actually flash it with the-a 0
parameter.This is working for me on a BlackPill STM32F411CEU6 board.
If the STM32 doesn't show up in DFU mode on macOS
MacOS had trouble finding my blackpill in DFU mode. What helped was using the USB Probe app from the Apple Dev center to reset USB on macOS.
You can find more info about that here. And instructions on how and where to get the USB Probe app here.
Apparently you can also use this open source, command line renumerate utility to reset usb, but it requieres you to compile it yourself and I havent tried it.
The text was updated successfully, but these errors were encountered: