rtconfig.py 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. import os
  2. ARCH = 'risc-v'
  3. CPU = 'e906'
  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:\RT-ThreadStudio\repo\Extract\ToolChain_Support_Packages\RISC-V\XTGccElfNewlib\V3.0.1\R\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 = '../../libraries/xuantie_libraries/chip_riscv_dummy/gcc_flash_smartl.ld'
  22. if os.path.exists('./libraries'):
  23. LINK_FILE = './libraries/xuantie_libraries/chip_riscv_dummy/gcc_flash_smartl.ld'
  24. TARGET_NAME = 'rtthread.bin'
  25. #------- GCC settings ----------------------------------------------------------
  26. if PLATFORM == 'gcc':
  27. # toolchains
  28. PREFIX = 'riscv64-unknown-elf-'
  29. CC = PREFIX + 'gcc'
  30. CXX= PREFIX + 'g++'
  31. AS = PREFIX + 'gcc'
  32. AR = PREFIX + 'ar'
  33. LINK = PREFIX + 'gcc'
  34. TARGET_EXT = 'elf'
  35. SIZE = PREFIX + 'size'
  36. OBJDUMP = PREFIX + 'objdump'
  37. OBJCPY = PREFIX + 'objcopy'
  38. MCPU = ' -mcpu=e906fd ' # Modify here based on CPU architecture.
  39. MCPU_DEFINE = ' -DCONFIG_CPU_XUANTIE_E906FD=1 ' # Modify here based on CPU architecture.
  40. DEVICE = MCPU + MCPU_DEFINE + ' -Wno-main -mcmodel=medlow'
  41. GLOBAL_DEFINES = (
  42. '-DCONFIG_KERNEL_RTTHREAD=1 '
  43. '-D__RT_KERNEL_SOURCE__=1 '
  44. '-DCONFIG_CSI_V2=1 '
  45. '-DCONFIG_CSI="csi2" '
  46. '-DCONFIG_SUPPORT_TSPEND=0 '
  47. '-DCONFIG_SUPPORT_IRQ_NESTED=0 '
  48. '-DCONFIG_XIP=1 '
  49. '-DCONFIG_ARCH_MAINSTACK=4096 '
  50. '-DCONFIG_ARCH_INTERRUPTSTACK=4096 '
  51. '-DCONFIG_BOARD_SMARTL_EVB=1 '
  52. '-DCLI_CONFIG_STACK_SIZE=4096 '
  53. )
  54. CFLAGS = DEVICE + ' -c -MP -MMD -Wno-unused-function -g -nostdlib -Wpointer-arith -Wno-undef -Wall -Wl,-EL \
  55. -ffunction-sections -fdata-sections -fno-inline-functions -fno-builtin -fno-strict-aliasing \
  56. -fno-strength-reduce -Os -g -Wall -Wunused -Wformat -Wformat-security -Warray-bounds -Wuninitialized \
  57. -Wreturn-type -Wcomment -Wswitch -Wparentheses -Wlogical-op ' + GLOBAL_DEFINES
  58. AFLAGS = DEVICE + ' -MP -MMD -D"Default_IRQHandler=SW_handler" ' + GLOBAL_DEFINES
  59. LFLAGS = DEVICE + ' -MP -MMD -Wl,-zmax-page-size=1024 -Wl,-Map=yoc.map -Wl,-zmax-page-size=1024 -Wl,-Map=yoc.map -Wl,--whole-archive -Wl,--no-whole-archive -nostartfiles -Wl,--gc-sections '
  60. LFLAGS += ' -T ' + LINK_FILE
  61. CPATH = ''
  62. LPATH = ''
  63. if BUILD == 'debug':
  64. CFLAGS += ' -Os -g3'
  65. AFLAGS += ' -g3'
  66. else:
  67. CFLAGS += ' -O2 -g2'
  68. CXXFLAGS = CFLAGS
  69. POST_ACTION = OBJCPY + ' -O binary $TARGET ' + TARGET_NAME + '\n'
  70. POST_ACTION += SIZE + ' $TARGET\n'
  71. def dist_handle(BSP_ROOT, dist_dir):
  72. import sys
  73. cwd_path = os.getcwd()
  74. sys.path.append(os.path.join(os.path.dirname(BSP_ROOT), '../tools'))
  75. from sdk_dist import dist_do_building
  76. dist_do_building(BSP_ROOT, dist_dir)