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

Add initial support for CH559 (WIP/RFC) #29

Merged
merged 5 commits into from
Apr 11, 2022

Conversation

Tonymac32
Copy link
Contributor

The CH559 is a USB microcontroller based on the MCS-51 architecture.

This chip requires a custom upload protocol, I have placed the framework for that in main.py, I am not clear on how to have platformIO grab the necessary python upload tool automagically from here: https://github.com/MarsTechHAN/ch552tool

This tool depends on libusb as well.

Once these details are figured out/solved I can follow with board definitions for the remainder of the CH55x family.

Add uploader to support CH55x MCS-51 USB chips
change f_cpu to match reset state, per data sheet:

After reset, Fosc = 12MHz, Fpll = 288MHz, Fusb4x = 48MHz, Fsys = 12MHz.
Now working with manual placement of ch55xtool.py in project folder
@Tonymac32 Tonymac32 mentioned this pull request Jun 30, 2020
@maxgerhardt
Copy link

maxgerhardt commented Apr 2, 2021

Great PR! This allowed be to create a blinky firmware and flash it on the device using https://github.com/LoveMHz/vnproch55x. (for me, ch55xtool.py has a bug (MarsTechHAN/ch552tool#16) and can't find my device at all, while other tools can find it).

There is also a forked Arduino core based on SDuino (for STM8 devices) available at https://github.com/DeqingSun/ch55xduino, and it works greatly! They also use the vnproch55x flasher per above.

The nice thing with the core is is that once any ch55xduino firmware has been flashed, it exposes a USB serial port that supports the standard reset-to-bootloader mechanism via opening it at 1200 baud. That way one doesn't even have to manually reboot the device by holding a button and switching power on and off.

I'll see if I can get the Arduino core implementation to work and the other uploader based on your work! 👍

am not clear on how to have platformIO grab the necessary python upload tool automagically

The tool has to uploaded into the PIO package repository via pio package publish, then you can reference the package in the platform.json and use a bit of code to tell PIO that you need the pacakge, then use functions like platform.get_package_dir() to get the path to the installed package.

Edit: I've just published the framework-arduinoch55x package and the Win, Linux and Mac versions of tool-vnproch55x and hope they'll be approved soon for usage.

@Tonymac32
Copy link
Contributor Author

@maxgerhardt nice! The upload tool did not fare so well against some of the newer bootloader revisions on the CH55x devices, I wound up making this PR because I designed a Pi 0 form factor dev board and was hopeful to provide some decent support. After a very extended silence I'd all but forgotten about it. 👀

I'll take a look at the arduino platform, it has been a while since I tried it out.

@ivankravets
Copy link
Member

@Tonymac32 could make a board file name in uppercase? We keep TARGET DEVICES in their original form (typically upper case).

@maxgerhardt what do we need to merge this PR?

builder/main.py Outdated
UPLOADERFLAGS=[
"-f"
],
UPLOADCMD="python3 $UPLOADER $UPLOADERFLAGS $BUILD_DIR/${PROGNAME}.bin")
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please replace python3 by $PYTHONEXE

@Tonymac32
Copy link
Contributor Author

I can take another run at this starting next week, I'm unfortunately in the middle of moving and don't have access to my build system until I set it back up. Thanks for the review!

@ivankravets ivankravets merged commit 81bf8cc into platformio:develop Apr 11, 2022
@ivankravets
Copy link
Member

The PR has been merged, the latest version of tool-vnproch55x has been published to the registry. Please re-test with the latest dev-platform:

  1. Upgrade PIO Core to the latest dev version pio upgrade --dev
  2. Use the GIT version of dev-platform in platformio.ini => platform = https://github.com/platformio/platform-intel_mcs51.git
  3. Open the system terminal, change the directory to the project folder, and type pio pkg update.

Does it work now?

@maxgerhardt
Copy link

maxgerhardt commented Apr 11, 2022

Ah but the upload tool used in this PR is https://github.com/MarsTechHAN/ch552tool, not https://github.com/LoveMHz/vnproch55x (which I was using on the command line), which package you've uploaded.

Also a note on the original issue with ch552tool, this was related to the libusb backend file missing or being a buggy version (I think v1.0.25). Maybe it was fixed with the fresh new release put out a few hours ago, but it was buggy for a really long time. For the Python tool to use libusb devices one needs to have the libusb-1.0.dll in the Python interpreter folder or the program folder. Or use WinUSB drivers with Zadig, I have not tested that.

I have the chip and can test later in the evening.

@ivankravets
Copy link
Member

I used these tools (they were recently updated) https://github.com/DeqingSun/ch55xduino/tree/ch55xduino/ch55xduino/tools

Checked on mac OS, and it works. Are they broken?

@maxgerhardt
Copy link

Yes ch55xduino uses vnproch55x.exe but this PR calls into ch55xtool.py. I think the binary releases of vnproch55.exe worked fine for me and this is where I had the binaries from.

@ivankravets
Copy link
Member

Sorry, I removed your package to avoid duplicates. Let's summarize - should we make any changes regarding this PR?

I found some time for the OSS dev-platforms, I'm not sure that I can back to this repo in the next months. I would be great to merge all PRs and re-test them. Thanks!

@maxgerhardt
Copy link

maxgerhardt commented Apr 11, 2022

I think we

  • either have to upload the package that has ch55xtool.py and reference it as uploader in platform.json, keep uploader code the same
  • or slightly rewrite the upload code to use tool-vnproch55x, i.e. call into vnproch55x.exe

Or have both upload methods available. I can take a look at this today, but right now it should be non-working.

@maxgerhardt
Copy link

Ah, I see you have already done the second point in 6402cc7, so it should actually be working.

@KenwoodFox
Copy link

Great PR! This allowed be to create a blinky firmware and flash it on the device using LoveMHz/vnproch55x. (for me, ch55xtool.py has a bug (MarsTechHAN/ch552tool#16) and can't find my device at all, while other tools can find it).

There is also a forked Arduino core based on SDuino (for STM8 devices) available at DeqingSun/ch55xduino, and it works greatly! They also use the vnproch55x flasher per above.

The nice thing with the core is is that once any ch55xduino firmware has been flashed, it exposes a USB serial port that supports the standard reset-to-bootloader mechanism via opening it at 1200 baud. That way one doesn't even have to manually reboot the device by holding a button and switching power on and off.

I'll see if I can get the Arduino core implementation to work and the other uploader based on your work! +1

am not clear on how to have platformIO grab the necessary python upload tool automagically

The tool has to uploaded into the PIO package repository via pio package publish, then you can reference the package in the platform.json and use a bit of code to tell PIO that you need the pacakge, then use functions like platform.get_package_dir() to get the path to the installed package.

Edit: I've just published the framework-arduinoch55x package and the Win, Linux and Mac versions of tool-vnproch55x and hope they'll be approved soon for usage.

Did this every go through? Sorry to bump an old thread but I'm trying to get PIO working with the CH552! If ch55xduino got in there i should be good to target that slightly different board?

@danielkucera
Copy link

ch55xduino is "not there"
This is how I got my board working just recently:
https://github.com/danielkucera/ch552-hid/

@KenwoodFox
Copy link

KenwoodFox commented May 17, 2023

ch55xduino is "not there" This is how I got my board working just recently: danielkucera/ch552-hid

Wow.. i am amazed at how exactly similar my current project looks to that.. i even have the commented out link_medium.py

Thank you haha! if i learn anything more ill lyk

What version of SDCC are you using?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants