Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Blinkinlabs/ch554_sdcc
CH554 software development kit for SDCC
https://github.com/Blinkinlabs/ch554_sdcc
Last synced: 3 months ago
JSON representation
CH554 software development kit for SDCC
- Host: GitHub
- URL: https://github.com/Blinkinlabs/ch554_sdcc
- Owner: Blinkinlabs
- Created: 2017-12-01T18:20:49.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2023-11-17T13:35:54.000Z (about 1 year ago)
- Last Synced: 2024-08-02T15:20:45.564Z (6 months ago)
- Language: C
- Homepage:
- Size: 5.19 MB
- Stars: 295
- Watchers: 28
- Forks: 70
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
Awesome Lists containing this project
README
# CH554 software development kit for SDCC ![Linux build](https://github.com/Blinkinlabs/ch554_sdcc/workflows/Linux%20build/badge.svg)
![image](https://raw.githubusercontent.com/Blinkinlabs/ch554_sdcc/master/documentation/devboard.png)
This is a port of the CH554 SDK, from Keil C51 to SDCC.
The CH55x family of microcontrollers is notable because it has both an extremely low cost, USB device and host peripherals, and a preloaded USB bootloader.
# Other Info
Contains tranlated comments for esier understanding how the ch55x range operate and extra examples included.
If you want a gentler introduction to CH55x programming, this Arduino port might be worth a look:
https://github.com/DeqingSun/ch55xduinoWCH has released official english translations of their datasheets for the parts:
* [CH551/CH5522](http://www.wch-ic.com/downloads/file/309.html)
* [CH554](http://www.wch-ic.com/downloads/file/229.html)# Getting Started
## Get the toolchain: Windows
You'll need a recent version of SDCC, as well as mingw for make, and likely also git-bash for the bash shell. Additionally, you'll need WCHISPTOOL to upload code to the chips.
* [git for windows](https://github.com/git-for-windows/git/releases/download/v2.15.1.windows.2/Git-2.15.1.2-64-bit.exe)
* [SDCC 3.6.0](https://sourceforge.net/projects/sdcc/files/latest/download?source=files)
* [mingw installer](https://downloads.sourceforge.net/project/mingw/Installer/mingw-get-setup.exe)
* [WCHISPTOOL](http://wch.cn/download/WCHISPTool_Setup_exe.html) (see note below)TODO: How to set up the enviroment to find these bits automatically
Once the tools are installed, add the following lines to the end of your .bashrc file:
# SDCC compiler tools
export PATH=$PATH:/c/Program\ Files/SDCC/bin# Mingw tools (for Make)
export PATH=$PATH:/c/Qt/Qt5.10.0/Tools/mingw530_32/binalias make=mingw32-make.exe
TODO: Use standalone mingw tools instead of the ones from Qt
Note: [LibreCH551](https://github.com/rgwan/librech551) works with the CH554, and can be used in place of the vendor-provided WCHISPTOOL on Windows. A big advantage of the open tools is that they can be automated, rather than manually clicking on things in the vendor tool. Please see the respective project pages for up-to-date installation instructions, as you'll likely need to bind the VID/PID pair for your specific WCH chip to the LibUSB using Zadig. Another tool is [ch552tool](https://github.com/MarsTechHAN/ch552tool).
## Get the toolchain: Linux
For Debian-based systems, this should work:
sudo apt-install build-essential sdcc
There are multiple open source tools for loading firmware onto the CH55x chip:
* [LibreCH551](https://github.com/rgwan/librech551)
* [ch552tool](https://github.com/MarsTechHAN/ch552tool)These tools are reported to work with CH554 as well as CH552/CH551.
## Get the toolchain: macOs
You'll need xcode (for make), as well as SDCC. ISP Tool will be same as Linux's.
## Build the examples
Then clone this repository, and build the examples:
git clone https://github.com/Blinkinlabs/ch554_sdcc.git
cd ch554_sdcc/examples
makeIf everything is set up correctly, all of the examples should now be built.
On Windows: Use the 'WCHISPTool' to flash an image onto the target device.
On Linux/Mac (or Windows after you have installed and configured LibreCH551), you can run 'make flash' to load the example onto your board.## Port a file from Keil C51 syntax to SDCC
The syntax for the two compilers are slightly incompatible. Notable issues from the SDK are:
* SFR and SBIT defines are different
* Absolute addressing format is different
* SDCC doesn't automatically track absolute-addressed variables
* SDCC can use standard types like 'uint8_t', the C51 examples used non-standard defines like 'UINT8'
* SDCC is little endian, while C51 appears to be big endianThis project includes a simplistic python script that can automatically translate some simple grammer changes. It can be used like this:
python tools/c51_to_sdcc.py [source] [destination]
With any luck it should do 90% of the translation work for you.
## Create a new example
Create a new directory in the examples folder, with the name of the new example:
cd examples/
mkdir fastblink
cd fastblinkAdd a Makefile that referes to the master template makefile:
vi Makefile
With these contents:
TARGET = fastblink
C_FILES = \
main.c
include ../Makefile.includeChange the definition of target to match the new example name.
Next, add a barebones main file:
vi main.c
With these contents:
// Blink an LED connected to pin 1.7
#include
#include#define LED_PIN 7
SBIT(LED, 0x90, LED_PIN);void main() {
// Configure pin 1.6 as GPIO output
P1_DIR_PU &= 0x0C;
P1_MOD_OC = P1_MOD_OC & ~(1< fastblink.hex
packihx: read 31 lines, wrote 48: OK.The .hex file can now be loaded onto the target using WCHISPTOOL.
## Build configuration variables
The build configuration is specified in the master Makefile.include file, however some variables can be overridden by the local Makefile:
| Makefile variable | Description |
| --- | --- |
| TARGET | Example name, used to name the .hex file |
| C_FILES | List of c files to include in the example build |
| FREQ_SYS | System clock frequency. Default is 12000000 (12MHz). See 'include/debug.c' for a list of accepted values |
| XRAM_SIZE | Size of the non-reserved XRAM. Update to reserve a portion of the XRAM for absolute variables, such as for the USB DMA pointer |
| XRAM_LOC | Starting position of the non-reserved XRAM. Update to reserve a portion of the XRAM for absolute variables, such as for the USB DMA pointer |
| STDIO_UART | Set to '0' to use UART0 for STDIO, or '1' to use UART1 for STDIO (not finished) |# Status
Here is a list of the different peripheral drivers and examples that need to be ported
| Peripheral | Description | Status |
| --- | --- | --- |
| ADC | Analog-to-digital converter | in progress |
| DataFlash | DataFlash (EEPROM) peripheral | not started |
| GPIO | I/O peripheral example | not started |
| UART0/stdlib | stdio example using UART0 | in progress |
| UART1/stdlib | stdio example using UART1 | in progress |
| Watchdog | Watchdog timer configuration | not started |
| IAP | Jump from user program to the bootloader | complete |
| PWM | Pulse Width modulation peripheral | complete |
| SPI | Serial Peripheral Interface | not started |
| Timer | 8051-style Timers 0 and 1 | not started |
| Timer2 | Extended Timer 2 | not started |
| TouchKey | Capacitive touch peripheral | in progress |
| Chip ID | Read the built-in chip ID | not started |
| Type-C | USB C power negotiation peripheral | not started |
| USB\Device | USB device peripheral: HID (?) profile | not started |
| S_CDC | USB device peripheral: CDC profile | complete |
| U_DISK | USB device peripheral: USB mass storage device profile | not started |
| Compound_Dev | USB device peripheral: compound device example (?) | not started |
| USB\Host | USB host peripheral: hub (?) example | not started |
| USB\U_DISK | USB host peripheral: read/write USB mass storage device | not started |# Contributing
Contributions are welcome! Please see CONTRIBUTING.md
# References
* [Official CH554 SDK (snapshot)](https://github.com/HonghongLu/CH554)
* [SDCC Compiler Users Guide](http://sdcc.sourceforge.net/doc/sdccman.pdf)
* [CH554 manual (Chinese)](https://github.com/HonghongLu/CH554/blob/master/CH554DS1.PDF)
* [CH554 manual (English-ish translation)](https://github.com/Blinkinlabs/ch554_sdcc/blob/master/documentation/CH554%20manual%20english.pdf)
* [CH554 instruction set timings](https://github.com/HonghongLu/CH554/blob/master/official%20ch554%20evt%20pcb/PUB/CH55X%C2%AA%E2%80%9E%C2%B1%E2%80%A1%C3%B7%E2%88%8F%C2%A1%C3%93.PDF)