rtconfig.py 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. import os
  2. # toolchains options
  3. ARCH='risc-v'
  4. CPU='nuclei'
  5. CROSS_TOOL='gcc'
  6. if os.getenv('RTT_CC'):
  7. CROSS_TOOL = os.getenv('RTT_CC')
  8. if CROSS_TOOL == 'gcc':
  9. PLATFORM = 'gcc'
  10. EXEC_PATH = 'D:/Software/Nuclei/gcc/bin'
  11. else:
  12. print("CROSS_TOOL = {} not yet supported" % CROSS_TOOL)
  13. # if os.getenv('RTT_EXEC_PATH'):
  14. # EXEC_PATH = os.getenv('RTT_EXEC_PATH')
  15. BUILD = 'debug'
  16. # Fixed configurations below
  17. NUCLEI_SDK_SOC = "hbird"
  18. NUCLEI_SDK_BOARD = "hbird_eval"
  19. # Configurable options below
  20. # DOWNLOAD: https://doc.nucleisys.com/nuclei_sdk/develop/buildsystem.html#download
  21. NUCLEI_SDK_DOWNLOAD = "ilm"
  22. # CORE: See https://doc.nucleisys.com/nuclei_sdk/develop/buildsystem.html#core
  23. NUCLEI_SDK_CORE = "nx600"
  24. if PLATFORM == 'gcc':
  25. # toolchains
  26. PREFIX = 'riscv-nuclei-elf-'
  27. CC = PREFIX + 'gcc'
  28. CXX = PREFIX + 'g++'
  29. AS = PREFIX + 'gcc'
  30. AR = PREFIX + 'ar'
  31. LINK = PREFIX + 'gcc'
  32. GDB = PREFIX + 'gdb'
  33. TARGET_EXT = 'elf'
  34. SIZE = PREFIX + 'size'
  35. OBJDUMP = PREFIX + 'objdump'
  36. OBJCPY = PREFIX + 'objcopy'
  37. CFLAGS = ' -ffunction-sections -fdata-sections -fno-common '
  38. AFLAGS = CFLAGS
  39. LFLAGS = ' --specs=nano.specs --specs=nosys.specs -nostartfiles -Wl,--gc-sections '
  40. LFLAGS += ' -Wl,-cref,-Map=rtthread.map'
  41. LFLAGS += ' -u _isatty -u _write -u _sbrk -u _read -u _close -u _fstat -u _lseek '
  42. CPATH = ''
  43. LPATH = ''
  44. LIBS = ['stdc++']
  45. if BUILD == 'debug':
  46. CFLAGS += ' -O2 -ggdb'
  47. AFLAGS += ' -ggdb'
  48. else:
  49. CFLAGS += ' -O2 -Os'
  50. CXXFLAGS = CFLAGS
  51. DUMP_ACTION = OBJDUMP + ' -D -S $TARGET > rtt.asm\n'
  52. POST_ACTION = OBJCPY + ' -O binary $TARGET rtthread.bin\n' + SIZE + ' $TARGET \n'
  53. def dist_handle(BSP_ROOT, dist_dir):
  54. import sys
  55. cwd_path = os.getcwd()
  56. sys.path.append(os.path.join(os.path.dirname(BSP_ROOT), 'tools'))
  57. from sdk_dist import dist_do_building
  58. dist_do_building(BSP_ROOT, dist_dir)