Add support for Arduino framework for BluePill F103C8 board // Resolve #5

This commit is contained in:
Ivan Kravets 2016-09-13 19:55:31 +03:00
parent e1f93dc5b9
commit 1abbab0122
3 changed files with 38 additions and 38 deletions

View File

@ -8,7 +8,8 @@
"variant": "stm32f1" "variant": "stm32f1"
}, },
"frameworks": [ "frameworks": [
"mbed" "mbed",
"arduino"
], ],
"name": "BluePill F103C8", "name": "BluePill F103C8",
"upload": { "upload": {

View File

@ -28,8 +28,14 @@ from SCons.Script import DefaultEnvironment
env = DefaultEnvironment() env = DefaultEnvironment()
platform = env.PioPlatform() platform = env.PioPlatform()
board = env.BoardConfig()
if "stm32f103" in env.BoardConfig().get("build.mcu", ""): if board.id == "bluepill_f103c8":
board = env.BoardConfig("genericSTM32F103C8")
env['LDSCRIPT_PATH'] = board.get("build.ldscript")
env.ProcessFlags(board.get("build.extra_flags"))
if "stm32f103" in board.get("build.mcu", ""):
FRAMEWORK_DIR = join(platform.get_package_dir( FRAMEWORK_DIR = join(platform.get_package_dir(
"framework-arduinoststm32"), "STM32F1") "framework-arduinoststm32"), "STM32F1")
env.Append( env.Append(
@ -39,18 +45,18 @@ if "stm32f103" in env.BoardConfig().get("build.mcu", ""):
"ARDUINO_ARCH_STM32F1" "ARDUINO_ARCH_STM32F1"
] ]
) )
if "stm32f103r8" or "stm32f103rb" in env.BoardConfig().get( if "stm32f103r8" or "stm32f103rb" in board.get(
"build.mcu", ""): "build.mcu", ""):
env.Append(CPPDEFINES=[ env.Append(CPPDEFINES=[
"BOARD_generic_stm32f103r8", "ARDUINO_GENERIC_STM32F103R"]) "BOARD_generic_stm32f103r8", "ARDUINO_GENERIC_STM32F103R"])
elif "stm32f103rc" or "stm32f103re" in env.BoardConfig().get( elif "stm32f103rc" or "stm32f103re" in board.get(
"build.mcu", ""): "build.mcu", ""):
env.Append(CPPDEFINES=[ env.Append(CPPDEFINES=[
"BOARD_generic_stm32f103r", "ARDUINO_GENERIC_STM32F103R"]) "BOARD_generic_stm32f103r", "ARDUINO_GENERIC_STM32F103R"])
elif "stm32f103c" in env.BoardConfig().get("build.mcu", ""): elif "stm32f103c" in board.get("build.mcu", ""):
env.Append(CPPDEFINES=[ env.Append(CPPDEFINES=[
"BOARD_generic_stm32f103c", "ARDUINO_GENERIC_STM32F103C"]) "BOARD_generic_stm32f103c", "ARDUINO_GENERIC_STM32F103C"])
elif "stm32f103rb_maple" in env.BoardConfig().get("build.mcu", ""): elif "stm32f103rb_maple" in board.get("build.mcu", ""):
env.Append(CPPDEFINES=["BOARD_maple", "ARDUINO_MAPLE_REV3"]) env.Append(CPPDEFINES=["BOARD_maple", "ARDUINO_MAPLE_REV3"])
FRAMEWORK_VERSION = platform.get_package_version("framework-arduinoststm32") FRAMEWORK_VERSION = platform.get_package_version("framework-arduinoststm32")
@ -64,7 +70,7 @@ env.Append(
], ],
CPPPATH=[ CPPPATH=[
join(FRAMEWORK_DIR, "cores", env.BoardConfig().get("build.core")), join(FRAMEWORK_DIR, "cores", board.get("build.core")),
join(FRAMEWORK_DIR, "system", "libmaple"), join(FRAMEWORK_DIR, "system", "libmaple"),
join(FRAMEWORK_DIR, "system", "libmaple", "include"), join(FRAMEWORK_DIR, "system", "libmaple", "include"),
join(FRAMEWORK_DIR, "system", "libmaple", "usb", "stm32f1"), join(FRAMEWORK_DIR, "system", "libmaple", "usb", "stm32f1"),
@ -73,7 +79,7 @@ env.Append(
LIBPATH=[ LIBPATH=[
join(FRAMEWORK_DIR, "variants", join(FRAMEWORK_DIR, "variants",
env.BoardConfig().get("build.variant"), "ld") board.get("build.variant"), "ld")
] ]
) )
@ -81,14 +87,14 @@ for item in ("-nostartfiles", "-nostdlib"):
if item in env['LINKFLAGS']: if item in env['LINKFLAGS']:
env['LINKFLAGS'].remove(item) env['LINKFLAGS'].remove(item)
ld = env.BoardConfig().get("build.ldscript") ld = board.get("build.ldscript")
if env.subst("$UPLOAD_PROTOCOL") == "dfu": if env.subst("$UPLOAD_PROTOCOL") == "dfu":
if "stm32f103c" in env.BoardConfig().get("build.mcu", ""): if "stm32f103c" in board.get("build.mcu", ""):
ld = "bootloader_20.ld" ld = "bootloader_20.ld"
elif "stm32f103r" in env.BoardConfig().get("build.mcu", ""): elif "stm32f103r" in board.get("build.mcu", ""):
ld = "bootloader.ld" ld = "bootloader.ld"
if "stm32f103rb_maple" in env.BoardConfig().get("build.mcu", ""): if "stm32f103rb_maple" in board.get("build.mcu", ""):
env.Append(CPPDEFINES=["VECT_TAB_ADDR=0x8005000", "SERIAL_USB"]) env.Append(CPPDEFINES=["VECT_TAB_ADDR=0x8005000", "SERIAL_USB"])
else: else:
env.Append(CPPDEFINES=[ env.Append(CPPDEFINES=[
@ -96,11 +102,12 @@ if env.subst("$UPLOAD_PROTOCOL") == "dfu":
env.Replace(LDSCRIPT_PATH=ld) env.Replace(LDSCRIPT_PATH=ld)
else: else:
env.Append(CPPDEFINES=["VECT_TAB_ADDR=0x8000000"]) env.Append(CPPDEFINES=["VECT_TAB_ADDR=0x8000000"])
# #
# Lookup for specific core's libraries # Lookup for specific core's libraries
# #
BOARD_CORELIBDIRNAME = env.BoardConfig().get("build.core", "") BOARD_CORELIBDIRNAME = board.get("build.core", "")
env.Append( env.Append(
LIBSOURCE_DIRS=[ LIBSOURCE_DIRS=[
join(FRAMEWORK_DIR, "libraries", "__cores__", BOARD_CORELIBDIRNAME), join(FRAMEWORK_DIR, "libraries", "__cores__", BOARD_CORELIBDIRNAME),
@ -114,29 +121,21 @@ env.Append(
libs = [] libs = []
if "build.variant" in env.BoardConfig(): if "build.variant" in board:
env.Append( env.Append(
CPPPATH=[ CPPPATH=[
join(FRAMEWORK_DIR, "variants", join(FRAMEWORK_DIR, "variants",
env.BoardConfig().get("build.variant")) board.get("build.variant"))
] ]
) )
libs.append(env.BuildLibrary( libs.append(env.BuildLibrary(
join("$BUILD_DIR", "FrameworkArduinoVariant"), join("$BUILD_DIR", "FrameworkArduinoVariant"),
join(FRAMEWORK_DIR, "variants", env.BoardConfig().get("build.variant")) join(FRAMEWORK_DIR, "variants", board.get("build.variant"))
)) ))
envsafe = env.Clone() libs.append(env.BuildLibrary(
libs.append(envsafe.BuildLibrary(
join("$BUILD_DIR", "FrameworkArduino"), join("$BUILD_DIR", "FrameworkArduino"),
join(FRAMEWORK_DIR, "cores", env.BoardConfig().get("build.core")) join(FRAMEWORK_DIR, "cores", board.get("build.core"))
)) ))
env.Append(
LIBPATH=[
join(FRAMEWORK_DIR, "variants", env.BoardConfig().get("build.variant"))
]
)
env.Prepend(LIBS=libs) env.Prepend(LIBS=libs)

View File

@ -13,7 +13,7 @@
"type": "git", "type": "git",
"url": "https://github.com/platformio/platform-ststm32.git" "url": "https://github.com/platformio/platform-ststm32.git"
}, },
"version": "1.0.1", "version": "1.1.0-alpha1",
"packageRepositories": [ "packageRepositories": [
"https://dl.bintray.com/platformio/dl-packages/manifest.json", "https://dl.bintray.com/platformio/dl-packages/manifest.json",
"https://sourceforge.net/projects/platformio-storage/files/packages/manifest.json/download", "https://sourceforge.net/projects/platformio-storage/files/packages/manifest.json/download",