Add support for GD32VF103 flash (#518)

* Backport of GD32VF103 flash driver from https://github.com/riscv-mcu/riscv-openocd (GPL2 licensed)
Tested with a "Longan Nano" GD32VF103 dev board and seems to be working (flash can be read, erased and written).

* Modify src/flash/nor/gd32vf103.c to comply with Travis CI code style requirements.

* Modified README to include GD32VF103 in list of supported flash devices.
This commit is contained in:
ZL2WRW 2020-09-08 07:27:08 +12:00 committed by GitHub
parent 5e84c5dd8a
commit 48e40f3513
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 1362 additions and 4 deletions

8
README
View File

@ -124,10 +124,10 @@ Flash drivers
------------- -------------
ADUC702x, AT91SAM, ATH79, AVR, CFI, DSP5680xx, EFM32, EM357, eSi-TSMC, FM3, ADUC702x, AT91SAM, ATH79, AVR, CFI, DSP5680xx, EFM32, EM357, eSi-TSMC, FM3,
FM4, Freedom E SPI, Kinetis, LPC8xx/LPC1xxx/LPC2xxx/LPC541xx, LPC2900, FM4, Freedom E SPI, GD32VF103, Kinetis, LPC8xx/LPC1xxx/LPC2xxx/LPC541xx,
LPCSPIFI, Marvell QSPI, Milandr, NIIET, NuMicro, PIC32mx, PSoC4, PSoC5LP, LPC2900, LPCSPIFI, Marvell QSPI, Milandr, NIIET, NuMicro, PIC32mx, PSoC4,
SiM3x, Stellaris, STM32, STMSMI, STR7x, STR9x, nRF51; NAND controllers of PSoC5LP, SiM3x, Stellaris, STM32, STMSMI, STR7x, STR9x, nRF51; NAND controllers
AT91SAM9, LPC3180, LPC32xx, i.MX31, MXC, NUC910, Orion/Kirkwood, S3C24xx, of AT91SAM9, LPC3180, LPC32xx, i.MX31, MXC, NUC910, Orion/Kirkwood, S3C24xx,
S3C6400, XMC1xxx, XMC4xxx. S3C6400, XMC1xxx, XMC4xxx.

View File

@ -0,0 +1,8 @@
/* Autogenerated with ../../../../src/helper/bin2char.sh */
0x6f,0x00,0x80,0x00,0x73,0x00,0x10,0x00,0x03,0x2b,0x06,0x00,0x63,0x0c,0x0b,0x04,
0x83,0x2a,0x46,0x00,0xb3,0x87,0x6a,0x41,0xe3,0x88,0x07,0xfe,0x03,0xdb,0x0a,0x00,
0x23,0x10,0x67,0x01,0x93,0x8a,0x2a,0x00,0x13,0x07,0x27,0x00,0x83,0x2b,0xc5,0x00,
0x93,0xf7,0x1b,0x00,0xe3,0x9c,0x07,0xfe,0x93,0xf7,0x4b,0x01,0x63,0x90,0x07,0x02,
0x63,0xe6,0xda,0x00,0x93,0x0a,0x06,0x00,0x93,0x8a,0x8a,0x00,0x23,0x22,0x56,0x01,
0x93,0x85,0xf5,0xff,0x63,0x88,0x05,0x00,0x6f,0xf0,0x1f,0xfb,0x13,0x05,0x00,0x00,
0x23,0x22,0xa6,0x00,0x13,0x85,0x0b,0x00,0x6f,0xf0,0xdf,0xf9,

View File

@ -62,6 +62,7 @@ NOR_DRIVERS = \
%D%/stm32lx.c \ %D%/stm32lx.c \
%D%/stm32l4x.c \ %D%/stm32l4x.c \
%D%/stm32h7x.c \ %D%/stm32h7x.c \
%D%/gd32vf103.c \
%D%/str7x.c \ %D%/str7x.c \
%D%/str9x.c \ %D%/str9x.c \
%D%/str9xpec.c \ %D%/str9xpec.c \

View File

@ -75,6 +75,7 @@ extern const struct flash_driver stm32f2x_flash;
extern const struct flash_driver stm32lx_flash; extern const struct flash_driver stm32lx_flash;
extern const struct flash_driver stm32l4x_flash; extern const struct flash_driver stm32l4x_flash;
extern const struct flash_driver stm32h7x_flash; extern const struct flash_driver stm32h7x_flash;
extern const struct flash_driver gd32vf103_flash;
extern const struct flash_driver stmsmi_flash; extern const struct flash_driver stmsmi_flash;
extern const struct flash_driver str7x_flash; extern const struct flash_driver str7x_flash;
extern const struct flash_driver str9x_flash; extern const struct flash_driver str9x_flash;
@ -147,6 +148,7 @@ static const struct flash_driver * const flash_drivers[] = {
&stm32lx_flash, &stm32lx_flash,
&stm32l4x_flash, &stm32l4x_flash,
&stm32h7x_flash, &stm32h7x_flash,
&gd32vf103_flash,
&stmsmi_flash, &stmsmi_flash,
&str7x_flash, &str7x_flash,
&str9x_flash, &str9x_flash,

1347
src/flash/nor/gd32vf103.c Normal file

File diff suppressed because it is too large Load Diff