Add support for Arduino framework for BluePill F103C8 board // Resolve #5
This commit is contained in:
parent
e1f93dc5b9
commit
1abbab0122
|
@ -1,21 +1,22 @@
|
||||||
{
|
{
|
||||||
"build": {
|
"build": {
|
||||||
"core": "stm32",
|
"core": "stm32",
|
||||||
"cpu": "cortex-m3",
|
"cpu": "cortex-m3",
|
||||||
"f_cpu": "72000000L",
|
"f_cpu": "72000000L",
|
||||||
"ldscript": "stm32f103xb.ld",
|
"ldscript": "stm32f103xb.ld",
|
||||||
"mcu": "stm32f103c8t6",
|
"mcu": "stm32f103c8t6",
|
||||||
"variant": "stm32f1"
|
"variant": "stm32f1"
|
||||||
},
|
},
|
||||||
"frameworks": [
|
"frameworks": [
|
||||||
"mbed"
|
"mbed",
|
||||||
],
|
"arduino"
|
||||||
"name": "BluePill F103C8",
|
],
|
||||||
|
"name": "BluePill F103C8",
|
||||||
"upload": {
|
"upload": {
|
||||||
"maximum_ram_size": 20480,
|
"maximum_ram_size": 20480,
|
||||||
"maximum_size": 65536,
|
"maximum_size": 65536,
|
||||||
"protocol": "stlink"
|
"protocol": "stlink"
|
||||||
},
|
},
|
||||||
"url": "http://www.st.com/content/st_com/en/products/microcontrollers/stm32-32-bit-arm-cortex-mcus/stm32f1-series/stm32f103/stm32f103c8.html",
|
"url": "http://www.st.com/content/st_com/en/products/microcontrollers/stm32-32-bit-arm-cortex-mcus/stm32f1-series/stm32f103/stm32f103c8.html",
|
||||||
"vendor": "Generic"
|
"vendor": "Generic"
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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",
|
||||||
|
|
Loading…
Reference in New Issue