rtconfig.py 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  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 = "gd32vf103"
  18. NUCLEI_SDK_BOARD = "gd32vf103v_rvstar"
  19. NUCLEI_SDK_DOWNLOAD = "flashxip"
  20. NUCLEI_SDK_CORE = "n205"
  21. if PLATFORM == 'gcc':
  22. # toolchains
  23. PREFIX = 'riscv-nuclei-elf-'
  24. CC = PREFIX + 'gcc'
  25. CXX = PREFIX + 'g++'
  26. AS = PREFIX + 'gcc'
  27. AR = PREFIX + 'ar'
  28. LINK = PREFIX + 'gcc'
  29. GDB = PREFIX + 'gdb'
  30. TARGET_EXT = 'elf'
  31. SIZE = PREFIX + 'size'
  32. OBJDUMP = PREFIX + 'objdump'
  33. OBJCPY = PREFIX + 'objcopy'
  34. CFLAGS = ' -ffunction-sections -fdata-sections -fno-common '
  35. AFLAGS = CFLAGS
  36. LFLAGS = ' --specs=nano.specs --specs=nosys.specs -nostartfiles -Wl,--gc-sections '
  37. LFLAGS += ' -Wl,-cref,-Map=rtthread.map'
  38. LFLAGS += ' -u _isatty -u _write -u _sbrk -u _read -u _close -u _fstat -u _lseek '
  39. CPATH = ''
  40. LPATH = ''
  41. if BUILD == 'debug':
  42. CFLAGS += ' -O0 -ggdb'
  43. AFLAGS += ' -ggdb'
  44. else:
  45. CFLAGS += ' -O2 -Os'
  46. CXXFLAGS = CFLAGS
  47. DUMP_ACTION = OBJDUMP + ' -D -S $TARGET > rtt.asm\n'
  48. POST_ACTION = OBJCPY + ' -O binary $TARGET rtthread.bin\n' + SIZE + ' $TARGET \n'