Skip to content
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

Incomplete support for STM32G0xx MCUs #850

Closed
6 tasks done
mrfirmware opened this issue Dec 23, 2019 · 8 comments · Fixed by #857 or #825
Closed
6 tasks done

Incomplete support for STM32G0xx MCUs #850

mrfirmware opened this issue Dec 23, 2019 · 8 comments · Fixed by #857 or #825

Comments

@mrfirmware
Copy link

I have a fix.

  • Programmer/board type: Stlink/v2-onboard
  • Programmer firmware version: e.g STSW-LINK007 3.3.2 (FW V2J35M26)
  • Operating system: e.g Linux, Ubuntu 19.10
  • Stlink tools version and/or git commit hash: 3690de9
  • Stlink commandline tool name: st-util
  • Target chip (and optional board): e.g STM32G031K8 (STM32G0 Nucleo-32 board [MB1455])

A as-detailed description possible of the problem with debug output when available.
When trying to flash and debug my Nucleo-32 with the STM32G031K8 st-util failed to recognize the smaller 'G0 part with IDCODE[DEV_ID] = 0x466.

Output:

$ ./src/gdbserver/st-util
st-util 1.5.1-50-g3690de9
2019-12-23T14:03:25 INFO common.c: Loading device parameters....
2019-12-23T14:03:25 WARN common.c: unknown chip id! 0x10016466

Expected/description:
I got it to work with the following changes:

  1. First I renamed STLINK_CHIPID_STM32_G0X1 --> STLINK_CHIPID_STM32_G07X and added STLINK_CHIPID_STM32_G03X to better reflect the large vs. small chips. The larger G07X includes the 'G070, 'G071, and 'G080 while the smaller G03X includes the 'G030, 'G031, and 'G041.

  2. Then I updated the .description fields in stlink_chipid_params devices[].

  3. Then I added an entry to the devices[] array to match the G3X parameters.

  4. Then I added an OR to the sl->chip_id checks in stlink_write_option_bytes() to allow the new G03X part.

Now I get the following output:
$ src/gdbserver/st-util
st-util 1.5.1-50-g3690de9
2019-12-23T14:14:20 INFO common.c: Loading device parameters....
2019-12-23T14:14:20 INFO common.c: Device connected is: G030/G031/G041 device, id 0x10016466
2019-12-23T14:14:20 INFO common.c: SRAM size: 0x2000 bytes (8 KiB), Flash: 0x10000 bytes (64 KiB) in pages of 2048 bytes
2019-12-23T14:14:20 INFO gdb-server.c: Chip ID is 00000466, Core ID is 0bc11477.
2019-12-23T14:14:20 INFO gdb-server.c: Listening at *:4242...

and I can connect with arm-none-eabi-gdb --version
GNU gdb (GNU Tools for Arm Embedded Processors 8-2018-q4-major) 8.2.50.20181213-git

My ELF file gets flashed properly and I can set breakpoints, single-step, inspect variables, etc.

@mrfirmware
Copy link
Author

It looks like I cannot push a new branch so I cannot create a pull request.

@terrillmoore
Copy link

@mrfirmware Fork the repo, push the branch to your fork, then create a pull request from that branch against the upstream repo.

@mrfirmware
Copy link
Author

mrfirmware commented Dec 23, 2019

We don't use the fork-and-branch model at work; just branches so I'm not having any luck pushing to my forked, upstream repo. Here's what I have...

$ git remote -v
origin [email protected]:mrfirmware/stlink.git (fetch)
origin [email protected]:mrfirmware/stlink.git (push)
upstream [email protected]:mrfirmware/stlink.git (fetch)
upstream [email protected]:mrfirmware/stlink.git (push)

I created a branch 'stm32g0xx-improvements'

git push upstream stm32g0xx-improvements

times out with: fatal: Could not read from remote repository.

I love git vs. sccs, cvs, and svn but I also hate it.

@gdamjan
Copy link

gdamjan commented Jan 26, 2020

@mrfirmware you can also push to your repos master, doesn't need to be a branch.

(OTOH, that timeout might be your corporate firewall?)

@mrfirmware
Copy link
Author

I colleague at work showed me how to get past my authentication issue so I was able to create a PR for my small change set. Hopefully it is useful.

@benmartinek
Copy link

Any progress so far? I'm really hoping to be able to use the tools with G0 chips.

@mrfirmware
Copy link
Author

The PR is up.

This was linked to pull requests Mar 16, 2020
Nightwalker-87 added a commit that referenced this issue Mar 16, 2020
Improved support for STM32G0xx series parts to fix Issue #850
@Nightwalker-87
Copy link
Member

Closed by #825 and #857.

@stlink-org stlink-org locked as resolved and limited conversation to collaborators Apr 27, 2020
@Nightwalker-87 Nightwalker-87 moved this to Done in Release v1.6.1 Apr 7, 2023
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.