Skip to content

Commit

Permalink
builder: optimize support for nuclei sdk
Browse files Browse the repository at this point in the history
Signed-off-by: Huaqi Fang <578567190@qq.com>
  • Loading branch information
fanghuaqi committed Jan 2, 2024
1 parent e84cc57 commit 108fdda
Showing 1 changed file with 42 additions and 42 deletions.
84 changes: 42 additions & 42 deletions builder/frameworks/nuclei-sdk.py
Original file line number Diff line number Diff line change
Expand Up @@ -40,21 +40,6 @@
def is_valid_soc(soc):
return isdir(join(FRAMEWORK_DIR, "SoC", soc))

def get_inc_dirs(path):
incdirs = []
if isdir(path):
for dir in listdir(path):
dir_path = join(path, dir)
if isdir(dir_path):
incdirs.append(dir_path)
return incdirs

def get_soc_board_incdirs(soc, board):
soc_inc_dir_root = join(FRAMEWORK_DIR, "SoC", soc, "Common", "Include")
board_inc_dir_root = join(FRAMEWORK_DIR, "SoC", soc, "Board", board, "Include")

return [soc_inc_dir_root, board_inc_dir_root]

def select_rtos_package(build_rtos):
SUPPORTED_RTOSES = ("FreeRTOS", "UCOSII", "RTThread")
selected_rtos = None
Expand Down Expand Up @@ -86,7 +71,7 @@ def find_suitable_download(download, download_modes):
print("Change to use DOWNLOAD MODE %s now!!!!!" % (download))
return download

def find_suitable_ldscript(soc, board, download, variant=""):
def find_suitable_ldscript(socdir, soc, board, download, variant=""):
soc_variant = soc
if board == "gd32vf103c_longan_nano":
soc_variant = "gd32vf103x8" if variant == "lite" else "gd32vf103xb"
Expand All @@ -96,7 +81,7 @@ def find_suitable_ldscript(soc, board, download, variant=""):
else:
ld_script = "gcc_%s.ld" % build_soc

build_ldscript = join(FRAMEWORK_DIR, "SoC", build_soc, "Board", build_board, "Source", "GCC", ld_script)
build_ldscript = join(socdir, "Board", build_board, "Source", "GCC", ld_script)
return build_ldscript

def find_arch_abi_tune_cmodel(core, arch, abi, tune, cmodel, splist):
Expand Down Expand Up @@ -135,9 +120,24 @@ def get_arch_flags(arch, abi, tune, cmodel, archext, toolchain):
print("Warning! %s SoC is deprecated, please use evalsoc instead!" %(build_soc))
build_soc = "evalsoc"

FRAMEWORK_SOC_DIR = ""
if not is_valid_soc(build_soc):
print("Error! Could not find SoC software package for SoC %s" % build_soc)
env.Exit(1)
print("Warning! Could not find %s SoC support package in framework-nuclei-sdk" % build_soc)
soc_framework_pkg = "framework-nuclei-sdk-%s" % build_soc
try:
# you can add an extra platform_packages see https://docs.platformio.org/en/latest/projectconf/sections/env/options/platform/platform_packages.html
print("Try to find SoC support package from pio package %s, assume it is provided!" % (soc_framework_pkg))
FRAMEWORK_SOC_DIR = env.PioPlatform().get_package_dir(soc_framework_pkg)
print("Using SoC support package source code from %s" % (soc_framework_pkg))
except KeyError:
print("Error! If you confirm this pio package %s existed, please install it!" % (soc_framework_pkg))
env.Exit(1)

# Set Nuclei SDK Root directory
build_nsdk_dir = FRAMEWORK_DIR
build_nsdk_socdir = os.path.join(FRAMEWORK_DIR, "SoC", build_soc)
if FRAMEWORK_SOC_DIR != "":
build_nsdk_socdir = FRAMEWORK_SOC_DIR

build_core = board.get("build.core", "").lower().strip()
build_arch_ext = board.get("build.arch_ext", "").lower().strip()
Expand Down Expand Up @@ -174,7 +174,7 @@ def get_arch_flags(arch, abi, tune, cmodel, archext, toolchain):
build_download = find_suitable_download(build_download, build_download_modes)

if not build_ldscript:
build_ldscript = find_suitable_ldscript(build_soc, build_board, build_download, build_variant)
build_ldscript = find_suitable_ldscript(build_nsdk_socdir, build_soc, build_board, build_download, build_variant)

build_march, build_mabi, build_mtune, build_mcmodel = find_arch_abi_tune_cmodel(build_core, build_march, build_mabi, build_mtune, build_mcmodel, core_arch_abis)

Expand Down Expand Up @@ -208,9 +208,9 @@ def get_arch_flags(arch, abi, tune, cmodel, archext, toolchain):

build_cppdefines = []
build_cpppaths = [
"$PROJECT_SRC_DIR", "$PROJECT_INCLUDE_DIR", join(FRAMEWORK_DIR, "NMSIS", "Core", "Include"),
join(FRAMEWORK_DIR, "SoC", build_soc, "Common", "Include"),
join(FRAMEWORK_DIR, "SoC", build_soc, "Board", build_board, "Include")]
"$PROJECT_SRC_DIR", "$PROJECT_INCLUDE_DIR", join(build_nsdk_dir, "NMSIS", "Core", "Include"),
join(build_nsdk_socdir, "Common", "Include"),
join(build_nsdk_socdir, "Board", build_board, "Include")]
build_libpaths = []
build_libs = []

Expand Down Expand Up @@ -254,13 +254,13 @@ def get_arch_flags(arch, abi, tune, cmodel, archext, toolchain):
libname = "nmsis_%s" % (lib)
if libname in sel_nmsis_libs:
build_libs.extend(["%s_%s" % (libname, build_nmsis_lib_arch)])
build_libpaths.extend([join(FRAMEWORK_DIR, "NMSIS", "Library", lib.upper(), "GCC")])
build_cpppaths.extend([join(FRAMEWORK_DIR, "NMSIS", lib.upper(), "Include")])
build_libpaths.extend([join(build_nsdk_dir, "NMSIS", "Library", lib.upper(), "GCC")])
build_cpppaths.extend([join(build_nsdk_dir, "NMSIS", lib.upper(), "Include")])
if lib == "dsp":
build_cpppaths.extend([join(FRAMEWORK_DIR, "NMSIS", lib.upper(), "PrivateInclude")])
build_cpppaths.extend([join(build_nsdk_dir, "NMSIS", lib.upper(), "PrivateInclude")])

if build_soc == "gd32vf103" and build_usb_driver != "":
build_cpppaths.extend([join(FRAMEWORK_DIR, "SoC", build_soc, "Common", "Include", "Usb")])
build_cpppaths.extend([join(build_nsdk_socdir, "Common", "Include", "Usb")])

if build_simu:
build_cppdefines.extend([("SIMULATION_MODE", "SIMULATION_MODE_%s" % (build_simu.upper()))])
Expand Down Expand Up @@ -329,58 +329,58 @@ def get_arch_flags(arch, abi, tune, cmodel, archext, toolchain):
libs = [
env.BuildLibrary(
join("$BUILD_DIR", "SoC", build_soc, soclibname),
join(FRAMEWORK_DIR, "SoC", build_soc, "Common"),
join(build_nsdk_socdir, "Common"),
src_filter="+<*> -<**/IAR/> -<**/Stubs/> -<**/Usb/> +<**/%s/>" % (stubname)
),
env.BuildLibrary(
join("$BUILD_DIR", "SoC", build_soc, "Board", boardlibname),
join(FRAMEWORK_DIR, "SoC", build_soc, "Board", build_board),
join(build_nsdk_socdir, "Board", build_board),
src_filter="+<*> -<**/IAR/>"
)
]

if selected_rtos == "FreeRTOS":
libs.append(env.BuildLibrary(
join("$BUILD_DIR", "RTOS", "FreeRTOS"),
join(FRAMEWORK_DIR, "OS", "FreeRTOS", "Source"),
join(build_nsdk_dir, "OS", "FreeRTOS", "Source"),
src_filter="+<*> -<portable/MemMang/> -<portable/IAR/> +<portable/MemMang/heap_4.c>"
))
env.Append(
CPPPATH = [
join(FRAMEWORK_DIR, "OS", "FreeRTOS", "Source", "include"),
join(FRAMEWORK_DIR, "OS", "FreeRTOS", "Source", "portable")
join(build_nsdk_dir, "OS", "FreeRTOS", "Source", "include"),
join(build_nsdk_dir, "OS", "FreeRTOS", "Source", "portable")
]
)
elif selected_rtos == "UCOSII":
libs.append(env.BuildLibrary(
join("$BUILD_DIR", "RTOS", "UCOSII"),
join(FRAMEWORK_DIR, "OS", "UCOSII"),
join(build_nsdk_dir, "OS", "UCOSII"),
src_filter="+<*> -<arch/iar/>"
))
env.Append(
CPPPATH = [
join(FRAMEWORK_DIR, "OS", "UCOSII", "arch"),
join(FRAMEWORK_DIR, "OS", "UCOSII", "cfg"),
join(FRAMEWORK_DIR, "OS", "UCOSII", "source")
join(build_nsdk_dir, "OS", "UCOSII", "arch"),
join(build_nsdk_dir, "OS", "UCOSII", "cfg"),
join(build_nsdk_dir, "OS", "UCOSII", "source")
]
)
elif selected_rtos == "RTThread":
libs.append(env.BuildLibrary(
join("$BUILD_DIR", "RTOS", "RTThread"),
join(FRAMEWORK_DIR, "OS", "RTThread"),
join(build_nsdk_dir, "OS", "RTThread"),
src_filter=rtt_srcfilter
))
env.Append(
CPPPATH = [
join(FRAMEWORK_DIR, "OS", "RTThread", "libcpu", "risc-v", "nuclei"),
join(FRAMEWORK_DIR, "OS", "RTThread", "include"),
join(FRAMEWORK_DIR, "OS", "RTThread", "include", "libc")
join(build_nsdk_dir, "OS", "RTThread", "libcpu", "risc-v", "nuclei"),
join(build_nsdk_dir, "OS", "RTThread", "include"),
join(build_nsdk_dir, "OS", "RTThread", "include", "libc")
]
)
if build_rtthread_msh == "1":
env.Append(
CPPPATH = [
join(FRAMEWORK_DIR, "OS", "RTThread", "components", "finsh")
join(build_nsdk_dir, "OS", "RTThread", "components", "finsh")
]
)

Expand All @@ -396,7 +396,7 @@ def get_arch_flags(arch, abi, tune, cmodel, archext, toolchain):

libs.append(env.BuildLibrary(
join("$BUILD_DIR", "SoC", build_soc, "%s_usb" %(soclibname)),
join(FRAMEWORK_DIR, "SoC", build_soc, "Common", "Source", "Drivers", "Usb"),
join(build_nsdk_socdir, "Common", "Source", "Drivers", "Usb"),
src_filter=usb_srcfilter
))

Expand Down

0 comments on commit 108fdda

Please # to comment.