2025-01-11 09:59 AM
Hello, I'm trying to communicate with a STM32G070CBT6 bootloader, with mixed success. I've forced the chip into bootloader mode by writing a 0xDBFFE1AA to the FLASH option register (by default it was DFFFE1AA). I've verified that this value "stuck", and that the chip is booting up into bootloader mode.
Using AN4221 as a guide, and using the I2C interface, I am able to sucessfully execute the "get version" command, which returns 0x12 (bootload version 1.2).
However, all longer commands are failing. Here is a capture and protocol decode (with my annotations) of the "GET" command (command 0), The first 2 bytes of response is corect, however everything following that is 0x1F
Here's a zoom-on of the first 0x1F response:
Solved! Go to Solution.
2025-01-11 01:02 PM
Ok, I have found the issue: I was reading every response byte as a new frame... If I read the rest of the bytes after byte#1this command works.
#get
i2ctransfer -f -y 2 w2@0x51 0x00 0xff #write command
i2ctransfer -f -y 2 r1@0x51 #read ACK
i2ctransfer -f -y 2 r20@0x51 #read the rest of the bytes, must be one frame
2025-01-11 10:52 AM
Hi,
I understand your question, but I don't really understand what are you looking trough the bootloader mode.
Because the bootloader allow to exchange informations with the MCU, all commands work under a formatted protocol, and different interfaces.
I2C is a state protocol interface initially design to exchange datas with small peripherals, it works very well and allow to communicate with a two wires interface. The protocol used is based on state machine mechanism, the overflow of the datas address space routing to the start address.
In case of uploading executable binary, this ask more records of datas, and others interfaces should be better, I know spi and usart which re more currently used in this case.
But the question is, if you want to work with the bootloader, which enables in fact to read configuration datas and upload firmware; you need a software to do that. This software can exists may be with software packages from the ST Partners first, or by an application you have to write. The usual way to boot in bootloader mode being by hardware by a hard reset, and the correct configuration as described in AN2606, taking of the level of bootpin (usually boot 0).
Regards
Butterfly
2025-01-11 12:13 PM
Hello butterfly and thanks for the quick answer.
I am using i2c because i2c is the interface on the PCB I'm trying to write the DFU update code for :), so I don't really have a choice over the inerface. That being said though, I don't see why I2c wouldn't work for this application.
Per my message, I am already booting the chip into bootloader mode (via setting the Flash OPTION byte), and can sucessfully use the simplest bootloader command (getversion)
Here's an overview of the PCB
|imx8 SOM|<------------(i2c bus)------------->|STM32G0 micro|
2025-01-11 01:02 PM
Ok, I have found the issue: I was reading every response byte as a new frame... If I read the rest of the bytes after byte#1this command works.
#get
i2ctransfer -f -y 2 w2@0x51 0x00 0xff #write command
i2ctransfer -f -y 2 r1@0x51 #read ACK
i2ctransfer -f -y 2 r20@0x51 #read the rest of the bytes, must be one frame
2025-01-12 10:15 PM
Hi sgordon777,
Thanks for your feed-back.
I read quickly the AN4221. I'm glad you found the solution to use the i2c. You use a software utilitiy dedicated to check quickly the connection. The question maybe, how industrialise application.
You coded in fact the Get command (0x000xFF), the Get version command (0x01, 0xFE) is the next one. An interesting point with the protocole, the answer is framed between ACK, opening the checking of the answered frame on a array base.
Regards.
Butterfly