rtconfig.py 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. import os
  2. ARCH = 'risc-v'
  3. CPU = 'c908v'
  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_xiaohui.ld'
  22. if os.path.exists('./libraries'):
  23. LINK_FILE = './libraries/xuantie_libraries/chip_riscv_dummy/gcc_flash_xiaohui.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=c908v ' # Modify here based on CPU architecture.
  39. MCPU_DEFINE = ' -DCONFIG_CPU_XUANTIE_C908V=1 ' # Modify here based on CPU architecture.
  40. DEVICE = MCPU + MCPU_DEFINE + ' -Wno-main -mcmodel=medany -MP -MMD '
  41. # 提取全局宏定义
  42. GLOBAL_DEFINES = (
  43. ' -DCONFIG_KERNEL_RTTHREAD=1 '
  44. ' -D__RT_KERNEL_SOURCE__=1 '
  45. ' -DCONFIG_CSI_V2=1 '
  46. ' -DCONFIG_CSI="csi2" '
  47. ' -DCONFIG_SUPPORT_TSPEND=0 '
  48. ' -DCONFIG_SUPPORT_IRQ_NESTED=0 '
  49. ' -DCONFIG_XIP=1 '
  50. ' -DCONFIG_ARCH_MAINSTACK=8192 '
  51. ' -DCONFIG_ARCH_INTERRUPTSTACK=8192 '
  52. ' -DCONFIG_BOARD_XIAOHUI_EVB=1 '
  53. ' -DCLI_CONFIG_STACK_SIZE=8192 '
  54. ' -DCONFIG_PLIC_BASE=134217728 '
  55. ' -DCONFIG_VIC_TSPDR=201326592 '
  56. ' -DCONFIG_CLIC_BASE=201392128 '
  57. ' -DCONFIG_FPP_ENABLE=0 '
  58. ' -DCONFIG_INTC_CLIC_PLIC=1 '
  59. ' -DCONFIG_INIT_TASK_STACK_SIZE=8192 '
  60. ' -DCONFIG_APP_TASK_STACK_SIZE=8192 '
  61. ' -DCONFIG_SYSTICK_HZ=100 '
  62. ' -DCONFIG_DEBUG=1 '
  63. )
  64. CFLAGS = DEVICE + ' -c -Wno-unused-function -g -Wpointer-arith -Wno-undef -Wall -ffunction-sections -fdata-sections -fno-inline-functions \
  65. -fno-builtin -fno-strict-aliasing -Wno-int-to-pointer-cast -Wno-pointer-to-int-cast' + GLOBAL_DEFINES
  66. AFLAGS = DEVICE + ' -D"Default_IRQHandler=SW_handler" ' + GLOBAL_DEFINES
  67. LFLAGS = DEVICE + ' -Wl,-zmax-page-size=1024 -Wl,-Map=yoc.map -nostartfiles -Wl,--gc-sections '
  68. LFLAGS += ' -T ' + LINK_FILE
  69. CPATH = ''
  70. LPATH = ''
  71. if BUILD == 'debug':
  72. CFLAGS += ' -O0 -g3'
  73. AFLAGS += ' -g3'
  74. else:
  75. CFLAGS += ' -O2 -g2'
  76. CXXFLAGS = CFLAGS
  77. POST_ACTION = OBJCPY + ' -O binary $TARGET ' + TARGET_NAME + '\n'
  78. POST_ACTION += SIZE + ' $TARGET\n'
  79. def dist_handle(BSP_ROOT, dist_dir):
  80. import sys
  81. cwd_path = os.getcwd()
  82. sys.path.append(os.path.join(os.path.dirname(BSP_ROOT), '../tools'))
  83. from sdk_dist import dist_do_building
  84. dist_do_building(BSP_ROOT, dist_dir)