1
0

rtconfig.py 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. import os
  2. ARCH = 'risc-v'
  3. CPU = 'ch32v1'
  4. # toolchains options
  5. CROSS_TOOL = 'gcc'
  6. #------- toolchains path -------------------------------------------------------
  7. if os.getenv('RTT_CC'):
  8. CROSS_TOOL = os.getenv('RTT_CC')
  9. if CROSS_TOOL == 'gcc':
  10. PLATFORM = 'gcc'
  11. EXEC_PATH = r'D:/Softwares/RT_ThreadStudio/repo/Extract/ToolChain_Support_Packages/WCH/RISC-V-GCC-WCH/8.2.0/bin'
  12. else:
  13. print('Please make sure your toolchains is GNU GCC!')
  14. exit(0)
  15. # if os.getenv('RTT_EXEC_PATH'):
  16. # EXEC_PATH = os.getenv('RTT_EXEC_PATH')
  17. BUILD = 'debug'
  18. #BUILD = 'release'
  19. CORE = 'risc-v'
  20. MAP_FILE = 'rtthread.map'
  21. LINK_FILE = './board/linker_scripts/link.lds'
  22. TARGET_NAME = 'rtthread.bin'
  23. #------- GCC settings ----------------------------------------------------------
  24. if PLATFORM == 'gcc':
  25. # toolchains
  26. PREFIX = 'riscv-none-embed-'
  27. CC = PREFIX + 'gcc'
  28. CXX= PREFIX + 'g++'
  29. AS = PREFIX + 'gcc'
  30. AR = PREFIX + 'ar'
  31. LINK = PREFIX + 'gcc'
  32. TARGET_EXT = 'elf'
  33. SIZE = PREFIX + 'size'
  34. OBJDUMP = PREFIX + 'objdump'
  35. OBJCPY = PREFIX + 'objcopy'
  36. DEVICE = ' -march=rv32imac -mabi=ilp32 -DUSE_PLIC -DUSE_M_TIME -DNO_INIT -mcmodel=medany -msmall-data-limit=8 -L. -nostartfiles -lc '
  37. CFLAGS = DEVICE
  38. CFLAGS += ' -save-temps=obj'
  39. AFLAGS = '-c'+ DEVICE + ' -x assembler-with-cpp'
  40. LFLAGS = DEVICE
  41. LFLAGS += ' -Wl,--gc-sections,-cref,-Map=' + MAP_FILE
  42. LFLAGS += ' -T ' + LINK_FILE
  43. LFLAGS += ' -Wl,-wrap=memset'
  44. CPATH = ''
  45. LPATH = ''
  46. if BUILD == 'debug':
  47. CFLAGS += ' -O0 -g3'
  48. AFLAGS += ' -g3'
  49. else:
  50. CFLAGS += ' -O2'
  51. POST_ACTION = OBJCPY + ' -O binary $TARGET ' + TARGET_NAME + '\n'
  52. POST_ACTION += SIZE + ' $TARGET\n'