rtconfig.py 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. import os
  2. ARCH = 'risc-v'
  3. CPU = 'e310'
  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 = '/home/zj/risc-v/riscv64-unknown-elf-gcc-20170612-x86_64-linux-centos6/bin'
  12. if os.getenv('RTT_EXEC_PATH'):
  13. EXEC_PATH = os.getenv('RTT_EXEC_PATH')
  14. BUILD = 'debug'
  15. #BUILD = 'release'
  16. CORE = 'risc-v'
  17. MAP_FILE = 'rtthread.map'
  18. LINK_FILE = 'sdram'
  19. TARGET_NAME = 'rtthread.bin'
  20. #------- GCC settings ----------------------------------------------------------
  21. if PLATFORM == 'gcc':
  22. # toolchains
  23. PREFIX = 'riscv64-unknown-elf-'
  24. CC = PREFIX + 'gcc'
  25. AS = PREFIX + 'gcc'
  26. AR = PREFIX + 'ar'
  27. LINK = PREFIX + 'gcc'
  28. TARGET_EXT = 'elf'
  29. SIZE = PREFIX + 'size'
  30. OBJDUMP = PREFIX + 'objdump'
  31. OBJCPY = PREFIX + 'objcopy'
  32. DEVICE = ' -march=rv32imac -mabi=ilp32 -DUSE_PLIC -DUSE_M_TIME -mcmodel=medany -msmall-data-limit=8 -g -L. -nostartfiles -lc '
  33. CFLAGS = DEVICE
  34. CFLAGS += ''
  35. AFLAGS = '-c'+ DEVICE + ' -x assembler-with-cpp'
  36. AFLAGS += ' -Iplatform'
  37. LFLAGS = DEVICE
  38. LFLAGS += ' -Wl,--gc-sections,-cref,-Map=' + MAP_FILE
  39. LFLAGS += ' -T ' + LINK_FILE + '.ld'
  40. CPATH = ''
  41. LPATH = ''
  42. if BUILD == 'debug':
  43. CFLAGS += ' -O0 -gdwarf-2'
  44. AFLAGS += ' -gdwarf-2'
  45. else:
  46. CFLAGS += ' -O2'
  47. POST_ACTION = OBJCPY + ' -O binary $TARGET ' + TARGET_NAME + '\n'
  48. POST_ACTION += SIZE + ' $TARGET\n'