#wch #ch32 #cli

bin+lib wchisp

A command-line implementation of WCHISPTool, for flashing ch32 MCUs

8 releases

0.2.2 Feb 20, 2023
0.2.1 Jan 28, 2023
0.2.0 Nov 13, 2022
0.1.4 Nov 13, 2022
0.1.3 May 14, 2022

#1596 in Embedded development

GPL-2.0 license

65KB
1.5K SLoC

wchisp - WCH ISP Tool in Rust

crates.io

Command-line implementation of the WCHISPTool in Rust, by the ch32-rs team.

This tool is a work in progress.

  • NOTE: CH32V003 does not have a USB ISP interface, use WCH-Link to program
  • NOTE: This tool is for USB ISP, not using with WCH-Link
    • Currently I'm working on a WCH-Link implementation

TODOs

  • chip detection, identification
    • wchisp probe
    • wchisp info
  • flash and verify code
    • ELF parsing
    • hex, bin, ihex support
    • skip erasing, verifying, resetting
  • chip config register dump
    • wchisp config
    • works for most chips, but not all. Issues and PRs are welcomed
  • write config registers
    • reset config registers to default(unprotected, debug-enabled state)
    • write config with friendly register names? like wchisp config set SRAM_CODE_MODE=1 ...
  • EEPROM dump
  • EEPROM erase
  • EEPROM write
  • select from multiple chips(using -d to select index) wchisp -d 0 info
  • ISP via UART or Net

Usage

> cargo install wchisp --git https://github.com/ch32-rs/wchisp

> wchisp info
14:51:24 [INFO] Chip: CH32V307VCT6[0x7017] (Code Flash: 256KiB)
14:51:24 [INFO] Chip UID: 30-78-3e-26-3b-38-a9-d6
14:51:24 [INFO] BTVER(bootloader ver): 02.60
14:51:24 [INFO] Code Flash protected: false
RDPR_USER: 0x9F605AA5
  [7:0] RDPR 0b10100101 (0xA5)
    `- Unprotected
  [16:16] IWDG_SW 0b0 (0x0)
    `- IWDG enabled by the software
  [17:17] STOP_RST 0b0 (0x0)
    `- Enable
  [18:18] STANDBY_RST 0b0 (0x0)
    `- Enable
  [23:21] SRAM_CODE_MODE 0b11 (0x3)
    `- CODE-228KB + RAM-32KB
DATA: 0x00FF00FF
  [7:0] DATA0 0b11111111 (0xFF)
  [23:16] DATA1 0b11111111 (0xFF)
WRP: 0xFFFFFFFF
  `- Unprotected

> wchisp flash ./path/to/firmware.{bin,hex,elf}

> wchisp config info

> wchisp config reset

Tested On

This tool should work on most WCH MCU chips. But I haven't tested it on any other chips.

  • CH32V307
    • VCT6
    • RCT6 #8
  • CH32V103
  • CH32F103
  • CH552
    • Works but might be buggy #10 #14
  • CH582
    • CH58xM-EVT
  • CH573
  • CH579
    • BTVER: 02.90 #18
  • CH559
    • CH559TL_MINIEVT_V20 by wch.cn
  • CH32V203
  • ... (feel free to open an issue whether it works on your chip or not)

Contribution

This project is under active development. If you have any suggestions or bug reports, please open an issue.

If it works for your devices, please open a pull request to modify this README page.

It it doesn't, please open an issue. Better provide the following information:

  • chip type (with variant surfix)
  • debug print of usb packets
  • correct usb packets to negotiate with the chip (via USBPcap or other tools)

Dependencies

~9–19MB
~243K SLoC