mirror of
https://github.com/platformio/platformio-core.git
synced 2025-07-30 10:07:14 +02:00
Initial commit with supported platforms: Atmel AVR, TI MSP430 and TI C Series MCU
This commit is contained in:
5
.gitignore
vendored
Normal file
5
.gitignore
vendored
Normal file
@ -0,0 +1,5 @@
|
||||
*.egg-info
|
||||
*.pyc
|
||||
.pioenvs
|
||||
.tox
|
||||
.sconsign.dblite
|
3
.isort.cfg
Normal file
3
.isort.cfg
Normal file
@ -0,0 +1,3 @@
|
||||
[settings]
|
||||
line_length=79
|
||||
known_third_party=click,clint,serial,SCons
|
@ -1,4 +1,4 @@
|
||||
platformio
|
||||
PlatformIO
|
||||
==========
|
||||
|
||||
An easy way to build code with different development platforms
|
16
platformio/__init__.py
Normal file
16
platformio/__init__.py
Normal file
@ -0,0 +1,16 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
||||
|
||||
VERSION = (0, 0, 0)
|
||||
__version__ = ".".join([str(s) for s in VERSION])
|
||||
|
||||
__title__ = "platformio"
|
||||
__description__ = ("An easy way to build code with different development"
|
||||
"platforms")
|
||||
__url__ = "https://github.com/ivankravets/platformio"
|
||||
|
||||
__author__ = "Ivan Kravets"
|
||||
__email__ = "me@ikravets.com"
|
||||
|
||||
__license__ = "MIT Licence"
|
||||
__copyright__ = "Copyright (C) 2014 Ivan Kravets"
|
84
platformio/__main__.py
Normal file
84
platformio/__main__.py
Normal file
@ -0,0 +1,84 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
||||
|
||||
import click
|
||||
from sys import exit
|
||||
|
||||
from clint.textui import colored, indent, puts
|
||||
|
||||
|
||||
from platformio.util import get_project_config, run_builder
|
||||
|
||||
|
||||
@click.group()
|
||||
def main():
|
||||
pass
|
||||
|
||||
|
||||
@main.group()
|
||||
def init():
|
||||
""" Initialize new platformio based project """
|
||||
pass
|
||||
|
||||
|
||||
@main.group()
|
||||
def install():
|
||||
""" Install new platforms """
|
||||
pass
|
||||
|
||||
|
||||
@main.group()
|
||||
def list():
|
||||
""" List installed platforms """
|
||||
pass
|
||||
|
||||
|
||||
@main.command()
|
||||
@click.option("--environment", "-e", multiple=True)
|
||||
@click.option("--target", "-t", multiple=True)
|
||||
def run(environment, target):
|
||||
"""Process project environments """
|
||||
|
||||
config = get_project_config()
|
||||
for section in config.sections():
|
||||
if section[:4] != "env:":
|
||||
continue
|
||||
envname = section[4:]
|
||||
|
||||
if environment and envname not in environment:
|
||||
puts("Skipped %s environment" % colored.yellow(envname))
|
||||
continue
|
||||
|
||||
puts("Processing %s environment:" % colored.cyan(envname))
|
||||
variables = ["%s=%s" % (o.upper(), v) for o, v in config.items(section)
|
||||
if o != "targets"]
|
||||
variables.append("PIOENV=" + envname)
|
||||
|
||||
envtargets = []
|
||||
if target:
|
||||
envtargets = [t for t in target]
|
||||
elif config.has_option(section, "targets"):
|
||||
envtargets = config.get(section, "targets").split()
|
||||
|
||||
result = run_builder(variables, envtargets)
|
||||
|
||||
# print result
|
||||
with indent(4, quote=colored.white(".")):
|
||||
puts(colored.green(result['out']))
|
||||
puts(colored.red(result['err']))
|
||||
|
||||
|
||||
@main.group()
|
||||
def search():
|
||||
""" Search for new platforms """
|
||||
pass
|
||||
|
||||
|
||||
@main.group()
|
||||
def show():
|
||||
""" Show information about installed platforms """
|
||||
pass
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
exit(main())
|
2
platformio/builder/__init__.py
Normal file
2
platformio/builder/__init__.py
Normal file
@ -0,0 +1,2 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
54
platformio/builder/main.py
Normal file
54
platformio/builder/main.py
Normal file
@ -0,0 +1,54 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
||||
|
||||
from os.path import isdir, join
|
||||
|
||||
from SCons.Script import (DefaultEnvironment, Exit, SConscript,
|
||||
SConscriptChdir, Variables)
|
||||
|
||||
from platformio.util import get_home_dir, get_project_dir, get_source_dir
|
||||
|
||||
|
||||
PIOBUILDER_DIR = join(get_source_dir(), "builder")
|
||||
# AllowSubstExceptions()
|
||||
|
||||
# define user's variables
|
||||
clivars = Variables(None)
|
||||
clivars.AddVariables(
|
||||
("PIOENV",),
|
||||
("PLATFORM",),
|
||||
("BOARD",),
|
||||
("UPLOAD_PORT",)
|
||||
)
|
||||
|
||||
# print sdf
|
||||
|
||||
DefaultEnvironment(
|
||||
tools=["default", "platformio"],
|
||||
toolpath=[join(PIOBUILDER_DIR, "tools")],
|
||||
variables=clivars,
|
||||
|
||||
PROJECT_DIR=get_project_dir(),
|
||||
|
||||
PLATFORMIOHOME_DIR=get_home_dir(),
|
||||
PLATFORM_DIR=join("$PLATFORMIOHOME_DIR", "${PLATFORM}"),
|
||||
PLATFORMCORE_DIR=join("$PLATFORM_DIR", "core"),
|
||||
PLATFORMTOOLS_DIR=join("$PLATFORM_DIR", "tools"),
|
||||
|
||||
BUILD_DIR=join("$PROJECT_DIR", ".pioenvs", "${PIOENV}"),
|
||||
BUILDCORE_DIR=join("$BUILD_DIR", "core"),
|
||||
BUILDSRC_DIR=join("$BUILD_DIR", "src")
|
||||
)
|
||||
|
||||
PLATFORM = DefaultEnvironment().subst("${PLATFORM}")
|
||||
|
||||
if not isdir(DefaultEnvironment().subst("$PLATFORMIOHOME_DIR")):
|
||||
Exit("You haven't installed any platforms yet. Please use"
|
||||
"`platformio install` command")
|
||||
elif not isdir(DefaultEnvironment().subst("$PLATFORM_DIR")):
|
||||
Exit("An '%s' platform hasn't been installed yet. Please use "
|
||||
"`platformio install %s` command" % (PLATFORM.upper(),
|
||||
PLATFORM))
|
||||
|
||||
SConscriptChdir(0)
|
||||
SConscript(join(PIOBUILDER_DIR, "scripts", PLATFORM + ".py"))
|
2
platformio/builder/scripts/__init__.py
Normal file
2
platformio/builder/scripts/__init__.py
Normal file
@ -0,0 +1,2 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
190
platformio/builder/scripts/atmelavr.py
Normal file
190
platformio/builder/scripts/atmelavr.py
Normal file
@ -0,0 +1,190 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
||||
|
||||
"""
|
||||
Builder for Atmel AVR series of microcontrollers
|
||||
|
||||
Fully compatible with Arduino programming language (based on Wiring)
|
||||
"""
|
||||
|
||||
from os.path import join
|
||||
|
||||
from SCons.Script import (AlwaysBuild, Builder, COMMAND_LINE_TARGETS, Default,
|
||||
DefaultEnvironment, Exit)
|
||||
|
||||
#
|
||||
# SETUP ENVIRONMENT
|
||||
#
|
||||
|
||||
env = DefaultEnvironment()
|
||||
|
||||
BOARD_OPTIONS = env.ParseBoardOptions(join("$PLATFORM_DIR", "boards.txt"),
|
||||
"${BOARD}")
|
||||
env.Replace(
|
||||
ARDUINO_VERSION=open(join(env.subst("$PLATFORM_DIR"),
|
||||
"version.txt")).read().replace(".", "").strip(),
|
||||
|
||||
BOARD_MCU=BOARD_OPTIONS['build.mcu'],
|
||||
BOARD_F_CPU=BOARD_OPTIONS['build.f_cpu'],
|
||||
BOARD_VID=BOARD_OPTIONS.get("build.vid", "0"),
|
||||
BOARD_PID=BOARD_OPTIONS.get("build.pid", "0"),
|
||||
|
||||
AR="avr-ar",
|
||||
AS="avr-as",
|
||||
CC="avr-gcc",
|
||||
CXX="avr-g++",
|
||||
OBJCOPY="avr-objcopy",
|
||||
RANLIB="avr-ranlib",
|
||||
|
||||
ARFLAGS=["rcs"],
|
||||
|
||||
ASFLAGS=[
|
||||
"-g", # include debugging info (so errors include line numbers)
|
||||
"-x", "assembler-with-cpp",
|
||||
"-mmcu=$BOARD_MCU",
|
||||
"-DF_CPU=$BOARD_F_CPU",
|
||||
"-DUSB_VID=$BOARD_VID",
|
||||
"-DUSB_PID=$BOARD_PID",
|
||||
"-DARDUINO=$ARDUINO_VERSION"
|
||||
],
|
||||
CCFLAGS=[
|
||||
"-g", # include debugging info (so errors include line numbers)
|
||||
"-Os", # optimize for size
|
||||
"-Wall", # show warnings
|
||||
"-fno-exceptions",
|
||||
"-ffunction-sections", # place each function in its own section
|
||||
"-fdata-sections",
|
||||
"-mmcu=$BOARD_MCU",
|
||||
"-DF_CPU=$BOARD_F_CPU",
|
||||
"-MMD", # output dependancy info
|
||||
"-DUSB_VID=$BOARD_VID",
|
||||
"-DUSB_PID=$BOARD_PID",
|
||||
"-DARDUINO=$ARDUINO_VERSION"
|
||||
],
|
||||
CFLAGS=["-std=gnu99"],
|
||||
|
||||
LINKFLAGS=[
|
||||
"-Os",
|
||||
"-Wl,--gc-sections" + (",--relax" if BOARD_OPTIONS['build.mcu'] ==
|
||||
"atmega2560" else ""),
|
||||
"-mmcu=$BOARD_MCU",
|
||||
"-lm"
|
||||
],
|
||||
|
||||
CPPPATH=[
|
||||
"$PLATFORMCORE_DIR",
|
||||
join("$PLATFORM_DIR", "variants", BOARD_OPTIONS['build.variant'])
|
||||
],
|
||||
|
||||
UPLOADER="avrdude",
|
||||
UPLOADERFLAGS=[
|
||||
"-V", # do not verify
|
||||
"-q", # suppress progress output
|
||||
"-D", # disable auto erase for flash memory
|
||||
"-p", "$BOARD_MCU",
|
||||
"-C", join("$PLATFORMTOOLS_DIR", "avr", "etc", "avrdude.conf"),
|
||||
"-c", ("stk500v1" if BOARD_OPTIONS['upload.protocol'] == "stk500" else
|
||||
BOARD_OPTIONS['upload.protocol']),
|
||||
"-b", BOARD_OPTIONS['upload.speed'],
|
||||
"-P", "${UPLOAD_PORT}"
|
||||
],
|
||||
UPLOADHEXCMD="$UPLOADER $UPLOADERFLAGS -U flash:w:$SOURCES:i",
|
||||
UPLOADEEPCMD="$UPLOADER $UPLOADERFLAGS -U eeprom:w:$SOURCES:i"
|
||||
)
|
||||
|
||||
env.Append(
|
||||
BUILDERS=dict(
|
||||
ElfToEep=Builder(
|
||||
action=" ".join([
|
||||
"$OBJCOPY",
|
||||
"-O",
|
||||
"ihex",
|
||||
"-j",
|
||||
".eeprom",
|
||||
'--set-section-flags=.eeprom="alloc,load"',
|
||||
"--no-change-warnings",
|
||||
"--change-section-lma",
|
||||
".eeprom=0",
|
||||
"$SOURCES",
|
||||
"$TARGET"]),
|
||||
suffix=".eep"
|
||||
),
|
||||
|
||||
ElfToHex=Builder(
|
||||
action=" ".join([
|
||||
"$OBJCOPY",
|
||||
"-O",
|
||||
"ihex",
|
||||
"-R",
|
||||
".eeprom",
|
||||
"$SOURCES",
|
||||
"$TARGET"]),
|
||||
suffix=".hex"
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
env.PrependENVPath(
|
||||
"PATH",
|
||||
join(env.subst("$PLATFORMTOOLS_DIR"), "avr", "bin")
|
||||
)
|
||||
|
||||
|
||||
#
|
||||
# Target: Build Core Library
|
||||
#
|
||||
|
||||
target_corelib = env.BuildCoreLibrary()
|
||||
|
||||
|
||||
#
|
||||
# Target: Build executable and linkable firmware
|
||||
#
|
||||
|
||||
target_elf = env.BuildFirmware([target_corelib])
|
||||
|
||||
|
||||
#
|
||||
# Target: Extract EEPROM data (from EEMEM directive) to .eep file
|
||||
#
|
||||
|
||||
target_eep = env.ElfToEep(join("$BUILD_DIR", "firmware"), target_elf)
|
||||
|
||||
|
||||
#
|
||||
# Target: Build the .hex file
|
||||
#
|
||||
|
||||
target_hex = env.ElfToHex(join("$BUILD_DIR", "firmware"), target_elf)
|
||||
|
||||
|
||||
#
|
||||
# Target: Upload .eep file
|
||||
#
|
||||
|
||||
eep = env.Alias("eep", target_eep, [
|
||||
lambda target, source, env: env.ResetDevice(), "$UPLOADEEPCMD"])
|
||||
AlwaysBuild(eep)
|
||||
|
||||
|
||||
#
|
||||
# Target: Upload .hex file
|
||||
#
|
||||
|
||||
upload = env.Alias("upload", target_hex, [
|
||||
lambda target, source, env: env.ResetDevice(), "$UPLOADHEXCMD"])
|
||||
AlwaysBuild(upload)
|
||||
|
||||
|
||||
#
|
||||
# Target: Define targets
|
||||
#
|
||||
|
||||
env.Alias("build-eep", [target_eep])
|
||||
Default([target_corelib, target_elf, target_hex])
|
||||
|
||||
# check for $UPLOAD_PORT variable
|
||||
is_uptarget = ("eep" in COMMAND_LINE_TARGETS or "upload" in
|
||||
COMMAND_LINE_TARGETS)
|
||||
if is_uptarget and not env.subst("$UPLOAD_PORT"):
|
||||
Exit("Please specify 'upload_port'")
|
137
platformio/builder/scripts/timsp430.py
Normal file
137
platformio/builder/scripts/timsp430.py
Normal file
@ -0,0 +1,137 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
||||
|
||||
"""
|
||||
Builder for Texas Instruments
|
||||
MSP430 Ultra-Low Power 16-bit microcontrollers
|
||||
|
||||
Fully compatible with Energia programming language (based on Wiring).
|
||||
"""
|
||||
|
||||
from os.path import join
|
||||
|
||||
from SCons.Script import AlwaysBuild, Builder, Default, DefaultEnvironment
|
||||
|
||||
#
|
||||
# SETUP ENVIRONMENT
|
||||
#
|
||||
|
||||
env = DefaultEnvironment()
|
||||
|
||||
BOARD_OPTIONS = env.ParseBoardOptions(join("$PLATFORM_DIR", "boards.txt"),
|
||||
"${BOARD}")
|
||||
env.Replace(
|
||||
# See https://github.com/energia/Energia/blob/master/app/src/
|
||||
# processing/app/Base.java#L45
|
||||
ARDUINO_VERSION="101",
|
||||
ENERGIA_VERSION="12",
|
||||
|
||||
BOARD_MCU=BOARD_OPTIONS['build.mcu'],
|
||||
BOARD_F_CPU=BOARD_OPTIONS['build.f_cpu'],
|
||||
|
||||
AR="msp430-ar",
|
||||
AS="msp430-as",
|
||||
CC="msp430-gcc",
|
||||
CXX="msp430-g++",
|
||||
OBJCOPY="msp430-objcopy",
|
||||
RANLIB="msp430-ranlib",
|
||||
|
||||
ARFLAGS=["rcs"],
|
||||
|
||||
ASFLAGS=[
|
||||
"-g", # include debugging info (so errors include line numbers)
|
||||
"-assembler-with-cpp",
|
||||
"-mmcu=$BOARD_MCU",
|
||||
"-DF_CPU=$BOARD_F_CPU",
|
||||
"-DARDUINO=$ARDUINO_VERSION",
|
||||
"-DENERGIA=$ENERGIA_VERSION"
|
||||
],
|
||||
CCFLAGS=[
|
||||
"-g", # include debugging info (so errors include line numbers)
|
||||
"-Os", # optimize for size
|
||||
"-Wall", # show warnings
|
||||
"-ffunction-sections", # place each function in its own section
|
||||
"-fdata-sections",
|
||||
"-mmcu=$BOARD_MCU",
|
||||
"-DF_CPU=$BOARD_F_CPU",
|
||||
"-MMD", # output dependancy info
|
||||
"-DARDUINO=$ARDUINO_VERSION",
|
||||
"-DENERGIA=$ENERGIA_VERSION"
|
||||
],
|
||||
|
||||
LINK="$CC",
|
||||
LINKFLAGS=[
|
||||
"-Os",
|
||||
"-mmcu=$BOARD_MCU",
|
||||
"-Wl,-gc-sections,-u,main"
|
||||
],
|
||||
|
||||
CPPPATH=[
|
||||
"$PLATFORMCORE_DIR",
|
||||
join("$PLATFORM_DIR", "variants", BOARD_OPTIONS['build.variant'])
|
||||
],
|
||||
|
||||
UPLOADER=(join("$PLATFORMTOOLS_DIR", "msp430", "mspdebug", "mspdebug")),
|
||||
UPLOADERFLAGS=[
|
||||
BOARD_OPTIONS['upload.protocol'],
|
||||
"--force-reset"
|
||||
],
|
||||
UPLOADCMD='$UPLOADER $UPLOADERFLAGS "prog $SOURCES"'
|
||||
)
|
||||
|
||||
env.Append(
|
||||
BUILDERS=dict(
|
||||
ElfToHex=Builder(
|
||||
action=" ".join([
|
||||
"$OBJCOPY",
|
||||
"-O",
|
||||
"ihex",
|
||||
"-R",
|
||||
".eeprom",
|
||||
"$SOURCES",
|
||||
"$TARGET"]),
|
||||
suffix=".hex"
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
env.PrependENVPath(
|
||||
"PATH",
|
||||
join(env.subst("$PLATFORMTOOLS_DIR"), "msp430", "bin")
|
||||
)
|
||||
|
||||
|
||||
#
|
||||
# Target: Build Core Library
|
||||
#
|
||||
|
||||
target_corelib = env.BuildCoreLibrary()
|
||||
|
||||
|
||||
#
|
||||
# Target: Build executable and linkable firmware
|
||||
#
|
||||
|
||||
target_elf = env.BuildFirmware([target_corelib, "m"])
|
||||
|
||||
|
||||
#
|
||||
# Target: Build the .hex
|
||||
#
|
||||
|
||||
target_hex = env.ElfToHex(join("$BUILD_DIR", "firmware"), target_elf)
|
||||
|
||||
|
||||
#
|
||||
# Target: Upload firmware
|
||||
#
|
||||
|
||||
upload = env.Alias("upload", target_hex, ["$UPLOADCMD"])
|
||||
AlwaysBuild(upload)
|
||||
|
||||
|
||||
#
|
||||
# Target: Define targets
|
||||
#
|
||||
|
||||
Default([target_corelib, target_elf, target_hex])
|
152
platformio/builder/scripts/titiva.py
Normal file
152
platformio/builder/scripts/titiva.py
Normal file
@ -0,0 +1,152 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
||||
|
||||
"""
|
||||
Builder for Texas Instruments
|
||||
Tiva C Series ARM Cortex-M4 microcontrollers.
|
||||
|
||||
Fully compatible with Energia programming language (based on Wiring).
|
||||
"""
|
||||
|
||||
from os.path import join
|
||||
|
||||
from SCons.Script import AlwaysBuild, Builder, Default, DefaultEnvironment
|
||||
|
||||
#
|
||||
# SETUP ENVIRONMENT
|
||||
#
|
||||
|
||||
env = DefaultEnvironment()
|
||||
|
||||
BOARD_OPTIONS = env.ParseBoardOptions(join("$PLATFORM_DIR", "boards.txt"),
|
||||
"${BOARD}")
|
||||
env.Replace(
|
||||
ARDUINO_VERSION="101",
|
||||
ENERGIA_VERSION="12",
|
||||
|
||||
BOARD_MCU=BOARD_OPTIONS['build.mcu'],
|
||||
BOARD_F_CPU=BOARD_OPTIONS['build.f_cpu'],
|
||||
|
||||
AR="arm-none-eabi-ar",
|
||||
AS="arm-none-eabi-as",
|
||||
CC="arm-none-eabi-gcc",
|
||||
CXX="arm-none-eabi-g++",
|
||||
OBJCOPY="arm-none-eabi-objcopy",
|
||||
RANLIB="arm-none-eabi-ranlib",
|
||||
|
||||
ARFLAGS=["rcs"],
|
||||
|
||||
ASFLAGS=[
|
||||
"-g", # include debugging info (so errors include line numbers)
|
||||
"-assembler-with-cpp",
|
||||
"-Wall",
|
||||
"-mthumb",
|
||||
"-mcpu=cortex-m4",
|
||||
"-mfloat-abi=hard",
|
||||
"-mfpu=fpv4-sp-d16",
|
||||
"-fsingle-precision-constant",
|
||||
"-DF_CPU=$BOARD_F_CPU",
|
||||
"-DARDUINO=$ARDUINO_VERSION",
|
||||
"-DENERGIA=$ENERGIA_VERSION"
|
||||
],
|
||||
|
||||
CCFLAGS=[
|
||||
"-g", # include debugging info (so errors include line numbers)
|
||||
"-Os", # optimize for size
|
||||
"-Wall", # show warnings
|
||||
"-ffunction-sections", # place each function in its own section
|
||||
"-fdata-sections",
|
||||
"-Wall",
|
||||
"-mthumb",
|
||||
"-mcpu=cortex-m4",
|
||||
"-mfloat-abi=hard",
|
||||
"-mfpu=fpv4-sp-d16",
|
||||
"-fsingle-precision-constant",
|
||||
"-DF_CPU=$BOARD_F_CPU",
|
||||
"-MMD", # output dependancy info
|
||||
"-DARDUINO=$ARDUINO_VERSION",
|
||||
"-DENERGIA=$ENERGIA_VERSION"
|
||||
],
|
||||
|
||||
CXXFLAGS=[
|
||||
"-fno-rtti",
|
||||
"-fno-exceptions"
|
||||
],
|
||||
|
||||
LINKFLAGS=[
|
||||
"-Os",
|
||||
"-nostartfiles",
|
||||
"-nostdlib",
|
||||
"-Wl,--gc-sections",
|
||||
"-T", join("$PLATFORMCORE_DIR", BOARD_OPTIONS['ldscript']),
|
||||
"-Wl,--entry=ResetISR",
|
||||
"-mthumb",
|
||||
"-mcpu=cortex-m4",
|
||||
"-mfloat-abi=hard",
|
||||
"-mfpu=fpv4-sp-d16",
|
||||
"-fsingle-precision-constant"
|
||||
],
|
||||
|
||||
CPPPATH=[
|
||||
"$PLATFORMCORE_DIR",
|
||||
join("$PLATFORM_DIR", "variants", BOARD_OPTIONS['build.variant'])
|
||||
],
|
||||
|
||||
UPLOADER="lm4flash",
|
||||
UPLOADCMD="$UPLOADER $SOURCES"
|
||||
)
|
||||
|
||||
env.Append(
|
||||
BUILDERS=dict(
|
||||
ElfToBin=Builder(
|
||||
action=" ".join([
|
||||
"$OBJCOPY",
|
||||
"-O",
|
||||
"binary",
|
||||
"$SOURCES",
|
||||
"$TARGET"]),
|
||||
suffix=".hex"
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
env.PrependENVPath(
|
||||
"PATH",
|
||||
join(env.subst("$PLATFORMTOOLS_DIR"), "lm4f", "bin")
|
||||
)
|
||||
|
||||
|
||||
#
|
||||
# Target: Build Core Library
|
||||
#
|
||||
|
||||
target_corelib = env.BuildCoreLibrary()
|
||||
|
||||
|
||||
#
|
||||
# Target: Build executable and linkable firmware
|
||||
#
|
||||
|
||||
target_elf = env.BuildFirmware([target_corelib, "c", "gcc", "m"])
|
||||
|
||||
|
||||
#
|
||||
# Target: Build the .bin file
|
||||
#
|
||||
|
||||
target_bin = env.ElfToBin(join("$BUILD_DIR", "firmware"), target_elf)
|
||||
|
||||
|
||||
#
|
||||
# Target: Upload firmware
|
||||
#
|
||||
|
||||
upload = env.Alias("upload", target_bin, ["$UPLOADCMD"])
|
||||
AlwaysBuild(upload)
|
||||
|
||||
|
||||
#
|
||||
# Target: Define targets
|
||||
#
|
||||
|
||||
Default([target_corelib, target_elf, target_bin])
|
2
platformio/builder/tools/__init__.py
Normal file
2
platformio/builder/tools/__init__.py
Normal file
@ -0,0 +1,2 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
98
platformio/builder/tools/platformio.py
Normal file
98
platformio/builder/tools/platformio.py
Normal file
@ -0,0 +1,98 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
||||
|
||||
from os import walk
|
||||
from os.path import isfile, join
|
||||
from time import sleep
|
||||
|
||||
from serial import Serial
|
||||
|
||||
|
||||
def BuildCoreLibrary(env):
|
||||
corelib = env.Clone()
|
||||
vdirs = corelib.VariantDirRecursive("$BUILDCORE_DIR", "$PLATFORMCORE_DIR")
|
||||
return corelib.Library(
|
||||
corelib.subst("$BUILDCORE_DIR"),
|
||||
[corelib.GlobCXXFiles(vdir) for vdir in vdirs]
|
||||
)
|
||||
|
||||
|
||||
def BuildFirmware(env, liblist):
|
||||
src = env.Clone()
|
||||
vdirs = src.VariantDirRecursive("$BUILDSRC_DIR",
|
||||
join("$PROJECT_DIR", "src"))
|
||||
return src.Program(
|
||||
join("$BUILD_DIR", "firmware"),
|
||||
[src.GlobCXXFiles(vdir) for vdir in vdirs],
|
||||
LIBS=liblist,
|
||||
LIBPATH="$BUILD_DIR",
|
||||
PROGSUFFIX=".elf")
|
||||
|
||||
|
||||
def GlobCXXFiles(env, path):
|
||||
files = []
|
||||
for suff in ["*.c", "*.cpp", "*.S"]:
|
||||
_list = env.Glob(join(path, suff))
|
||||
if _list:
|
||||
files += _list
|
||||
return files
|
||||
|
||||
|
||||
def VariantDirRecursive(env, variant_dir, src_dir, duplicate=True):
|
||||
# add root dir by default
|
||||
variants = [variant_dir]
|
||||
env.VariantDir(variant_dir, src_dir, duplicate)
|
||||
for root, dirnames, filenames in walk(env.subst(src_dir)):
|
||||
if not dirnames:
|
||||
continue
|
||||
for dn in dirnames:
|
||||
env.VariantDir(join(variant_dir, dn), join(root, dn), duplicate)
|
||||
variants.append(join(variant_dir, dn))
|
||||
return variants
|
||||
|
||||
|
||||
def ParseBoardOptions(env, path, name):
|
||||
path = env.subst(path)
|
||||
name = env.subst(name)
|
||||
if not isfile(path):
|
||||
env.Exit("Invalid path to boards.txt -> %s" % path)
|
||||
|
||||
data = {}
|
||||
_namelen = len(name) + 1
|
||||
with open(path) as f:
|
||||
for line in f:
|
||||
if line[0:_namelen] != name + ".":
|
||||
continue
|
||||
line = line[_namelen:].strip()
|
||||
opt, value = line.split("=", 1)
|
||||
data[opt] = value
|
||||
if not data:
|
||||
env.Exit("Unknown Board '%s'" % name)
|
||||
else:
|
||||
return data
|
||||
|
||||
|
||||
def ResetDevice(env):
|
||||
""" Pulse the DTR line and flush serial buffer """
|
||||
s = Serial(env.subst("$UPLOAD_PORT"))
|
||||
s.flushInput()
|
||||
s.setDTR(False)
|
||||
s.setRTS(False)
|
||||
sleep(0.1)
|
||||
s.setDTR(True)
|
||||
s.setRTS(True)
|
||||
s.close()
|
||||
|
||||
|
||||
def exists(env):
|
||||
return True
|
||||
|
||||
|
||||
def generate(env):
|
||||
env.AddMethod(BuildCoreLibrary)
|
||||
env.AddMethod(BuildFirmware)
|
||||
env.AddMethod(GlobCXXFiles)
|
||||
env.AddMethod(VariantDirRecursive)
|
||||
env.AddMethod(ParseBoardOptions)
|
||||
env.AddMethod(ResetDevice)
|
||||
return env
|
67
platformio/util.py
Normal file
67
platformio/util.py
Normal file
@ -0,0 +1,67 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
||||
|
||||
from sys import exit
|
||||
from os import getcwd
|
||||
from os.path import dirname, expanduser, join, realpath, isfile
|
||||
from subprocess import Popen, PIPE
|
||||
|
||||
try:
|
||||
from configparser import ConfigParser
|
||||
except ImportError:
|
||||
from ConfigParser import ConfigParser
|
||||
|
||||
|
||||
def get_home_dir():
|
||||
return expanduser("~/.platformio")
|
||||
|
||||
|
||||
def get_source_dir():
|
||||
return dirname(realpath(__file__))
|
||||
|
||||
|
||||
def get_project_dir():
|
||||
return getcwd()
|
||||
|
||||
|
||||
def get_project_config():
|
||||
try:
|
||||
return getattr(get_project_config, "_cache")
|
||||
except AttributeError:
|
||||
pass
|
||||
|
||||
path = join(get_project_dir(), "platformio.ini")
|
||||
if not isfile(path):
|
||||
exit("Not a platformio project. Use `platformio init` command")
|
||||
|
||||
get_project_config._cache = ConfigParser()
|
||||
get_project_config._cache.read(path)
|
||||
return get_project_config._cache
|
||||
|
||||
|
||||
def exec_command(args):
|
||||
p = Popen(args, stdout=PIPE, stderr=PIPE)
|
||||
out, err = p.communicate()
|
||||
result = dict(out=out.strip(), err=err.strip())
|
||||
|
||||
# fix STDERR "flash written"
|
||||
if "flash written" in result['err']:
|
||||
result['out'] += "\n" + result['err']
|
||||
result['err'] = ""
|
||||
|
||||
return result
|
||||
|
||||
|
||||
def run_builder(variables, targets):
|
||||
assert isinstance(variables, list)
|
||||
assert isinstance(targets, list)
|
||||
|
||||
if "clean" in targets:
|
||||
targets.remove("clean")
|
||||
targets.append("-c")
|
||||
|
||||
return exec_command([
|
||||
"scons",
|
||||
"-Q",
|
||||
"-f", join(get_source_dir(), "builder", "main.py")
|
||||
] + variables + targets)
|
42
setup.py
Normal file
42
setup.py
Normal file
@ -0,0 +1,42 @@
|
||||
# Copyright (C) Ivan Kravets <me@ikravets.com>
|
||||
# See LICENSE for details.
|
||||
|
||||
from setuptools import find_packages, setup
|
||||
|
||||
from platformio import (__author__, __description__, __email__, __license__,
|
||||
__title__, __url__, __version__)
|
||||
|
||||
setup(
|
||||
name=__title__,
|
||||
version=__version__,
|
||||
description=__description__,
|
||||
long_description=open("README.rst").read(),
|
||||
author=__author__,
|
||||
author_email=__email__,
|
||||
url=__url__,
|
||||
license=__license__,
|
||||
install_requires=[
|
||||
"click",
|
||||
"clint",
|
||||
"pyserial"
|
||||
"SCons"
|
||||
],
|
||||
packages=find_packages(),
|
||||
entry_points={
|
||||
"console_scripts": [
|
||||
"platformio = platformio.__main__:main"
|
||||
]
|
||||
},
|
||||
classifiers=[
|
||||
"Development Status :: 2 - Pre-Alpha",
|
||||
"Environment :: Console",
|
||||
"Intended Audience :: Developers",
|
||||
"License :: OSI Approved :: MIT License",
|
||||
"Operating System :: OS Independent",
|
||||
"Programming Language :: C",
|
||||
"Programming Language :: Python",
|
||||
"Topic :: Software Development",
|
||||
"Topic :: Software Development :: Build Tools",
|
||||
"Topic :: Software Development :: Compilers"
|
||||
]
|
||||
)
|
22
tox.ini
Normal file
22
tox.ini
Normal file
@ -0,0 +1,22 @@
|
||||
[tox]
|
||||
envlist = develop, lint
|
||||
|
||||
[testenv]
|
||||
envlogdir = /tmp/toxlogdir
|
||||
envtmpdir = /tmp/toxtmpdir
|
||||
commands =
|
||||
{envpython} --version
|
||||
|
||||
[testenv:develop]
|
||||
usedevelop = True
|
||||
deps =
|
||||
isort
|
||||
flake8
|
||||
|
||||
[testenv:lint]
|
||||
deps =
|
||||
flake8
|
||||
pylint
|
||||
commands =
|
||||
flake8 ./platformio
|
||||
pylint --rcfile=./.pylintrc ./platformio
|
Reference in New Issue
Block a user