rtconfig.py 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. import os
  2. ARCH = 'risc-v'
  3. CPU = 'c906'
  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=c906fd ' # Modify here based on CPU architecture.
  39. MCPU_DEFINE = ' -DCONFIG_CPU_XUANTIE_C906FD=1 ' # Modify here based on CPU architecture.
  40. DEVICE = MCPU + MCPU_DEFINE + ' -Wno-main -mcmodel=medany -MP -MMD '
  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_XIP=1 '
  47. ' -DCONFIG_ARCH_MAINSTACK=8192 '
  48. ' -DCONFIG_ARCH_INTERRUPTSTACK=8192 '
  49. ' -DCONFIG_BOARD_XIAOHUI_EVB=1 '
  50. ' -DCLI_CONFIG_STACK_SIZE=8192 '
  51. ' -DCONFIG_PLIC_BASE=134217728 '
  52. ' -DCONFIG_VIC_TSPDR=201326592 '
  53. ' -DCONFIG_CLINT_BASE=201326592 '
  54. ' -DCONFIG_INTC_PLIC=1 '
  55. ' -DCONFIG_INIT_TASK_STACK_SIZE=8192 '
  56. ' -DCONFIG_APP_TASK_STACK_SIZE=8192 '
  57. ' -DCONFIG_DEBUG=1 '
  58. )
  59. GLOBAL_DEFINES += ' -DCONFIG_SYSTICK_HZ=RT_TICK_PER_SECOND '
  60. CFLAGS = DEVICE + ' -c -Wno-unused-function -g -Wpointer-arith -Wno-undef -Wall -ffunction-sections -fdata-sections -fno-inline-functions \
  61. -fno-builtin -fno-strict-aliasing -Wno-int-to-pointer-cast -Wno-pointer-to-int-cast' + GLOBAL_DEFINES
  62. AFLAGS = DEVICE + GLOBAL_DEFINES
  63. LFLAGS = DEVICE + ' -Wl,-zmax-page-size=1024 -Wl,-Map=yoc.map -nostartfiles -Wl,--gc-sections '
  64. LFLAGS += ' -T ' + LINK_FILE
  65. CPATH = ''
  66. LPATH = ''
  67. if BUILD == 'debug':
  68. CFLAGS += ' -O0 -g3'
  69. AFLAGS += ' -g3'
  70. else:
  71. CFLAGS += ' -O2 -g2'
  72. CXXFLAGS = CFLAGS
  73. POST_ACTION = OBJCPY + ' -O binary $TARGET ' + TARGET_NAME + '\n'
  74. POST_ACTION += SIZE + ' $TARGET\n'
  75. def dist_handle(BSP_ROOT, dist_dir):
  76. import sys
  77. cwd_path = os.getcwd()
  78. sys.path.append(os.path.join(os.path.dirname(BSP_ROOT), '../tools'))
  79. from sdk_dist import dist_do_building
  80. dist_do_building(BSP_ROOT, dist_dir)