[编译] 8、在Linux下搭建 stm8 单片机的开发烧写环境(makefile版)



一、SDCC(Small Device C Compiler)编译环境搭建

SDCC是一个小型设备的C语言编译器,该编译器是标准C语言,可以编译Intel MCS51架构的微处理器,也可以编译STM8等常见MCU。我们要在linux上搭建STM8开发环境,首先要搭建SDCC编译环境。

其主页是:http://sdcc.sourceforge.net/ ,下面是SDCC的首页简介:

SDCC is a retargettable, optimizing Standard C (ANSI C89, ISO C99, ISO C11) compiler suite that targets the Intel MCS51 based microprocessors (8031, 8032, 8051, 8052, etc.), Maxim (formerly Dallas) DS80C390 variants, Freescale (formerly Motorola) HC08 based (hc08, s08), Zilog Z80 based MCUs (z80, z180, gbz80, Rabbit 2000/3000, Rabbit 3000A, TLCS-90) and STMicroelectronics STM8. Work is in progress on supporting the Microchip PIC16 and PIC18 targets. It can be retargeted for other microprocessors.


1.1、下载

有两个可供下载的:

注: 对于选择拿来即用的兄弟,可以直接跳过1.2节


1.2、编译

如何编译:

./config

可能会出现下面几种错误(我也给出了解决办法):

  • 错误 1 、缺少bison :

      configure: error: Cannot find required program bison.
    

    解决方法:

      sudo apt-get install flex bison
    
  • 错误 2 、找不到adjacency_list.hpp

      configure: error: boost library not found (boost/graph/adjacency_list.hpp).
    

    解决方法:

      sudo apt-get install libboost-date-time-dev libboost-program-options-dev libboost-system-dev libboost-filesystem-dev libboost-iostreams-dev
    
  • 错误 3 、 没有PIC14、PIC16设备

      failed for device/lib/pic14
    

    解决方法:

      ./configure --disable-pic14-port --disable-pic16-port
    

1.3、测试

直接下载编译好的需要将其按照说明放入系统bin等文件中,采用编译的会自动将其放入系统bin中。而我比较喜欢不让其和系统的各种东西纠缠在一起,单独放在工程下的一个叫tool的文件里,大不了用的时候输全路径!

如下,我在example目录下建一个makefile和a.c文件,将直接编译好的sdcc文件放在tool下面:

➜  SDCC_WS  tree -L 2
.
├── example
│   ├── a.c
│   └── makefile
├── readme.md
└── tool
    └── sdcc

其中a.c为 stm8 闪灯程序:

#include "stm8l.h"

int main() {
    int d;
    // Configure pins
    PB_DDR = 0x20;
    PB_CR1 = 0x20;
    // Loop
    do {
        PB_ODR ^= 0x20;
        for(d = 0; d < 29000; d++) { }
    } while(1);
}

makefile为:

SDCC_PATH=../tool/sdcc

z_sdcc=${SDCC_PATH}/bin/sdcc
z_packihx=${SDCC_PATH}/bin/packihx


a.hex:a.c
	${z_sdcc} -lstm8 -mstm8 --out-fmt-ihx a.c
	${z_packihx} a.ihx > a.hex

clean:
	rm -rf *.asm *.lst *.mem *.rst *.lnk *.rel *.sym *.ihx *.hex *.map *.lk *.bin

二、Hex2Bin+命令行烧写工具配置使用

2.1、下载工具安装配置

理论上hex也能烧写,但是hex比bin要大一些,所以我们用这里用bin烧写。hex转bin要用到一个Hex2Bin工具,将其下载下来解压到tool目录下;stm8单片机烧写工具需要用一个github开源软件stm8flash,也将其下载到tool目录下:

➜  stm8_linux_tool git:(master) tree -L 2
.
├── app
│   ├── app_stm8_peri_blinky
│   └── app_stm8_peri_uart
├── bin
├── build
│   ├── makefile
│   └── tools.mk
├── readme.md
└── tool
    ├── Hex2bin-2.5
    ├── Hex2bin-2.5.zip
    ├── sdcc
    ├── sdcc.zip
    └── stm8flash

9 directories, 5 files

将makefile改为:

-include tools.mk

z_sdcc=${SDCC_PATH}/bin/sdcc
z_sdld=${SDCC_PATH}/bin/sdld
z_packihx=${SDCC_PATH}/bin/packihx
z_hex2bin=${HEX2BIN_PATH}/hex2bin
z_stm8flash=${STM8FLASH_PATH}/stm8flash

files_temp=*.asm *.lst *.rst *.rel *.sym *.ihx *.hex *.map *.lk *.bin *.cdb


build:
	$(z_sdcc) -lstm8 -mstm8 --out-fmt-ihx $(CFLAGS) $(LDFLAGS) $(APP_PATH)/$(PROJECT)/*.c
	${z_packihx} *.ihx > $(PROJECT).hex
	${z_hex2bin} $(PROJECT).hex

	mv -f $(files_temp) $(BIN_PATH)


clean:
	rm -f $(BIN_PATH)/*

flash:
	echo "00 00 ff 00 ff 00 ff 00 ff 00 ff" | xxd -r -p > factory_defaults.bin
	$(z_stm8flash) -c stlinkv2 -p stm8s103?3 -s opt -w factory_defaults.bin
	$(z_stm8flash) -c stlinkv2 -p stm8s103?3 -w $(BIN_PATH)/*.ihx
	rm factory_defaults.bin

2.2、编译+烧写

进入 build 目录运行 make build PROJECT=app_stm8_peri_blinky,自动编译:


输入make flash 进行烧写:

注:有些芯片被锁起来了,因此要在 flash 前多加一个解锁的指令:

echo "00 00 ff 00 ff 00 ff 00 ff 00 ff" | xxd -r -p > factory_defaults.bin
$(z_stm8flash) -c stlinkv2 -p stm8s103?3 -s opt -w factory_defaults.bin

最终效果是下面一个 stm8 最小开发板上的红色灯珠快速闪烁:


链接



: ** 我做了一系列全自动构建编译环境的工程,目前可以覆盖:51单片机、stm8、esp8266、esp32、nrf51822、nrf52832、android,欢迎到我的 nbtool github 下交流:https://github.com/nbtool **

posted @ 2021-07-31 15:43  beautifulzzzz  阅读(884)  评论(0编辑  收藏  举报