From 6254494f92b211f0454730dce67d9de8201f471a Mon Sep 17 00:00:00 2001 From: Vincent DEFERT <20.100@defert.com> Date: Fri, 2 Jun 2023 09:55:36 +0200 Subject: [PATCH] Updated documentation and fixed a few details --- doc/USAGE.md | 34 +++++++++++++++++++++++----------- doc/zh_CN/USAGE.md | 28 +++++++++++++++++++--------- stcgal/frontend.py | 4 ++-- stcgal/protocols.py | 2 +- 4 files changed, 45 insertions(+), 23 deletions(-) diff --git a/doc/USAGE.md b/doc/USAGE.md index 089f78b..31148c9 100644 --- a/doc/USAGE.md +++ b/doc/USAGE.md @@ -4,13 +4,13 @@ Usage Call stcgal with ```-h``` for usage information. ``` -usage: stcgal.py [-h] [-a] [-r RESETCMD] - [-P {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,usb15,auto}] - [-p PORT] [-b BAUD] [-l HANDSHAKE] [-o OPTION] [-t TRIM] [-D] - [-V] - [code_image] [eeprom_image] +usage: stcgal [-h] [-e] [-a] [-A {dtr,rts}] [-r RESETCMD] + [-P {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,stc8d,stc8g,usb15,auto}] + [-p PORT] [-b BAUD] [-l HANDSHAKE] [-o OPTION] [-t TRIM] [-D] + [-V] + [code_image] [eeprom_image] -stcgal 1.5 - an STC MCU ISP flash tool +stcgal 1.7 - an STC MCU ISP flash tool (C) 2014-2018 Grigori Goronzy and others https://github.com/grigorig/stcgal @@ -18,16 +18,19 @@ positional arguments: code_image code segment file to flash (BIN/HEX) eeprom_image eeprom segment file to flash (BIN/HEX) -optional arguments: +options: -h, --help show this help message and exit + -e, --erase only erase flash memory -a, --autoreset cycle power automatically by asserting DTR + -A {dtr,rts}, --resetpin {dtr,rts} + pin to hold down when using --autoreset (default: DTR) -r RESETCMD, --resetcmd RESETCMD shell command for board power-cycling (instead of DTR assertion) - -P {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,usb15,auto}, --protocol {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,usb15,auto} + -P {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,stc8d,stc8g,usb15,auto}, --protocol {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,stc8d,stc8g,usb15,auto} protocol version (default: auto) -p PORT, --port PORT serial port device - -b BAUD, --baud BAUD transfer baud rate (default: 19200) + -b BAUD, --baud BAUD transfer baud rate (default: 115200) -l HANDSHAKE, --handshake HANDSHAKE handshake baud rate (default: 2400) -o OPTION, --option OPTION @@ -40,6 +43,12 @@ optional arguments: Most importantly, ```-p``` sets the serial port to be used for programming. +### Transfer baud rate + +The default value of 115200 Baud is supported by all MCU starting with +the STC15 family, and at least the STC12C5A56S2 before that. For older +MCU, you might have to use ```-b 19200``` for correct operation. + ### Protocols STC MCUs use a variety of related but incompatible protocols for the @@ -49,12 +58,15 @@ and MCU series is as follows: * ```auto``` Automatic detection of UART based protocols (default) * ```stc89``` STC89/90 series +* ```stc89a``` STC89/90 series (BSL 7.2.5C) * ```stc12a``` STC12x052 series and possibly others * ```stc12b``` STC12x52 series, STC12x56 series and possibly others * ```stc12``` Most STC10/11/12 series * ```stc15a``` STC15x104E and STC15x204E(A) series * ```stc15``` Most STC15 series -* ```stc8``` STC8 series +* ```stc8``` STC8A8K64S4A12 and STC8F series +* ```stc8d``` All STC8 and STC32 series +* ```stc8g``` STC8G1 and STC8H1 series * ```usb15``` USB support on STC15W4 series The text files in the doc/reverse-engineering subdirectory provide an @@ -242,4 +254,4 @@ STC15W4 series have an USB-based BSL that can be optionally used. USB support in stcgal is experimental and might change in the future. USB mode is enabled by using the ```usb15``` protocol. The port (```-p```) flag as well as the baudrate options are ignored for -the USB protocol. RC frequency trimming is not supported. \ No newline at end of file +the USB protocol. RC frequency trimming is not supported. diff --git a/doc/zh_CN/USAGE.md b/doc/zh_CN/USAGE.md index 3643252..e566924 100644 --- a/doc/zh_CN/USAGE.md +++ b/doc/zh_CN/USAGE.md @@ -14,13 +14,13 @@ Last modified time: June 8, 2020 使用 ```-h``` 调用stcgal以获取使用信息。('//'后面是翻译,实际使用过程中没有后面内容) ``` -usage: stcgal.py [-h] [-a] [-r RESETCMD] - [-P {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,usb15,auto}] - [-p PORT] [-b BAUD] [-l HANDSHAKE] [-o OPTION] [-t TRIM] [-D] - [-V] - [code_image] [eeprom_image] +usage: stcgal [-h] [-e] [-a] [-A {dtr,rts}] [-r RESETCMD] + [-P {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,stc8d,stc8g,usb15,auto}] + [-p PORT] [-b BAUD] [-l HANDSHAKE] [-o OPTION] [-t TRIM] [-D] + [-V] + [code_image] [eeprom_image] -stcgal 1.5 - an STC MCU ISP flash tool +stcgal 1.7 - an STC MCU ISP flash tool (C) 2014-2018 Grigori Goronzy and others https://github.com/grigorig/stcgal @@ -31,13 +31,15 @@ positional arguments: optional arguments: -h, --help show this help message and exit //显示此帮助消息并退出 -a, --autoreset cycle power automatically by asserting DTR//断言DTR自动重启电源 + -A {dtr,rts}, --resetpin {dtr,rts} + pin to hold down when using --autoreset (default: DTR) -r RESETCMD, --resetcmd RESETCMD shell command for board power-cycling (instead of DTR //用于板上电重启的shell命令(而不是DTR断言) assertion) - -P {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,usb15,auto}, --protocol {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,usb15,auto} + -P {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,stc8d,stc8g,usb15,auto}, --protocol {stc89,stc12a,stc12b,stc12,stc15a,stc15,stc8,stc8d,stc8g,usb15,auto} protocol version (default: auto) //协议版本(芯片系列)(在默认状态为auto) -p PORT, --port PORT serial port device //串口设备 - -b BAUD, --baud BAUD transfer baud rate (default: 19200) //传输波特率(默认值:19200) + -b BAUD, --baud BAUD transfer baud rate (default: 115200) //传输波特率(默认值:115200) -l HANDSHAKE, --handshake HANDSHAKE handshake baud rate (default: 2400) //握手波特率(默认值:2400) -o OPTION, --option OPTION @@ -50,6 +52,11 @@ optional arguments: 最重要的是, ```-p``` 设置用于编程的串行端口。 +### 传输波特率 + +所有从 STC15 系列开始的 MCU 都支持默认值 115200 波特,至少是之前的 STC12C5A56S2。 +对于较旧的 MCU,您可能必须使用 ```-b 19200``` 才能正确操作。 + ### 通讯协议与规定 STC MCU对BSL使用各种相关但不兼容的协议。协议可以用```-P``` 标志来指定。 @@ -57,12 +64,15 @@ STC MCU对BSL使用各种相关但不兼容的协议。协议可以用```-P``` * ```auto``` 自动检测基于UART的协议(默认) * ```stc89``` STC89/90 系列 +* ```stc89a``` STC89/90 系列(BSL 7.2.5C) * ```stc12a``` STC12x052 系列和其他类似系列 * ```stc12b``` STC12x52 系列, STC12x56 系列和其他类似系列 * ```stc12``` 多数 STC10/11/12 系列 * ```stc15a``` STC15x104E 和 STC15x204E(A) 系列 * ```stc15``` 多数 STC15 系列 -* ```stc8``` STC8 系列 +* ```stc8``` STC8A8K64S4A12 和 STC8F 系列 +* ```stc8d``` 所有 STC8 和 STC32 系列 +* ```stc8g``` STC8G1 和 STC8H1 系列 * ```usb15``` 支持USB的STC15W4系列 doc / reverse-engineering子目录中的文本文件提供了BSL使用的反向工程协议的概述。 diff --git a/stcgal/frontend.py b/stcgal/frontend.py index f33f895..06c1577 100644 --- a/stcgal/frontend.py +++ b/stcgal/frontend.py @@ -266,9 +266,9 @@ def cli(): choices=["dtr", "rts"], default="dtr") parser.add_argument("-r", "--resetcmd", help="shell command for board power-cycling (instead of DTR assertion)", action="store") parser.add_argument("-P", "--protocol", help="protocol version (default: auto)", - choices=["stc89", "stc12a", "stc12b", "stc12", "stc15a", "stc15", "stc8", "stc8d", "stc8g", "usb15", "auto"], default="auto") + choices=["stc89", "stc89a", "stc12a", "stc12b", "stc12", "stc15a", "stc15", "stc8", "stc8d", "stc8g", "usb15", "auto"], default="auto") parser.add_argument("-p", "--port", help="serial port device", default="/dev/ttyUSB0") - parser.add_argument("-b", "--baud", help="transfer baud rate (default: 19200)", type=BaudType(), default=115200) + parser.add_argument("-b", "--baud", help="transfer baud rate (default: 115200)", type=BaudType(), default=115200) parser.add_argument("-l", "--handshake", help="handshake baud rate (default: 2400)", type=BaudType(), default=2400) parser.add_argument("-o", "--option", help="set option (can be used multiple times, see documentation)", action="append") parser.add_argument("-t", "--trim", help="RC oscillator frequency in kHz (STC15+ series only)", type=float, default=0.0) diff --git a/stcgal/protocols.py b/stcgal/protocols.py index ba385bb..716855b 100644 --- a/stcgal/protocols.py +++ b/stcgal/protocols.py @@ -391,7 +391,7 @@ class StcAutoProtocol(StcBaseProtocol): ("stc15a", r"(STC|IAP)15[FL][012]0\d(E|EA|)$"), ("stc15", r"(STC|IAP|IRC)15\D"), ("stc8d", r"STC8H(3|4|8)K"), - ("stc8d", r"STC32G"), + ("stc8d", r"STC32"), ("stc8d", r"STC8A8K\d\dD4"), ("stc8g", r"STC8H"), ("stc8g", r"STC8G"),