rtconfig.py 2.0 KB
Newer Older
1 2 3 4
import os

# toolchains options
ARCH        ='mips'
还_没_想_好's avatar
还_没_想_好 已提交
5
CPU         ='x1000'
6 7 8 9 10 11 12
CROSS_TOOL  ='gcc'

if os.getenv('RTT_CC'):
    CROSS_TOOL = os.getenv('RTT_CC')

if  CROSS_TOOL == 'gcc':
    PLATFORM    = 'gcc'
还_没_想_好's avatar
还_没_想_好 已提交
13
    EXEC_PATH   = r'E:\work\env\tools\gnu_gcc\mips_gcc\mips-2016.05\bin'
14 15 16 17 18 19 20
else:
    print 'Please make sure your toolchains is GNU GCC!'
    exit(0)

if os.getenv('RTT_EXEC_PATH'):
    EXEC_PATH = os.getenv('RTT_EXEC_PATH')

还_没_想_好's avatar
还_没_想_好 已提交
21 22 23 24 25 26 27

# BUILD = 'debug'
# BUILD = 'release'
BUILD = 'release_O3'

# FLOAT       = 'soft'
FLOAT       = 'hard'
28 29 30 31 32 33 34 35

if PLATFORM == 'gcc':
    # toolchains
    PREFIX  = 'mips-sde-elf-'
    CC      = PREFIX + 'gcc'
    CXX     = PREFIX + 'g++'
    AS      = PREFIX + 'gcc'
    AR      = PREFIX + 'ar'
还_没_想_好's avatar
还_没_想_好 已提交
36
    LINK    = PREFIX + 'g++'
37 38 39 40
    TARGET_EXT = 'elf'
    SIZE    = PREFIX + 'size'
    OBJDUMP = PREFIX + 'objdump'
    OBJCPY  = PREFIX + 'objcopy'
还_没_想_好's avatar
还_没_想_好 已提交
41
    STRIP   = PREFIX + 'strip'
42

还_没_想_好's avatar
还_没_想_好 已提交
43 44 45 46 47 48
    if FLOAT == 'soft':
        DEVICE = ' -mips32r2 -msoft-float -mfp32'
    else:
        DEVICE = ' -mips32r2 -mhard-float -mfp32'

    CFLAGS  = DEVICE + ' -EL -G0 -mno-abicalls -fno-pic -fno-builtin -fno-exceptions -ffunction-sections -fno-omit-frame-pointer'
49 50 51 52 53 54 55 56
    AFLAGS  = ' -c' + DEVICE + ' -EL -x assembler-with-cpp'
    LFLAGS  = DEVICE + ' -EL -Wl,--gc-sections,-Map=rtthread_x1000.map,-cref,-u,Reset_Handler -T x1000_ram.lds'
    CPATH   = ''
    LPATH   = ''

    if BUILD == 'debug':
        CFLAGS += ' -O0 -gdwarf-2'
        AFLAGS += ' -gdwarf-2'
还_没_想_好's avatar
还_没_想_好 已提交
57 58
    elif BUILD == 'release_O3':
        CFLAGS += ' -O3'
59 60 61 62 63
    else:
        CFLAGS += ' -O2'

    CXXFLAGS = CFLAGS

还_没_想_好's avatar
还_没_想_好 已提交
64 65 66 67 68 69
    M_CFLAGS = DEVICE + ' -EL -G0 -O2 -mno-abicalls -fno-common -fno-exceptions -fno-omit-frame-pointer -mlong-calls -fno-pic '
    M_CXXFLAGS = M_CFLAGS
    M_LFLAGS = DEVICE + ' -EL -r -Wl,--gc-sections,-z,max-page-size=0x4' +\
                                    ' -nostartfiles -static-libgcc'
    M_POST_ACTION = STRIP + ' -R .hash $TARGET\n' + SIZE + ' $TARGET \n'

70 71
DUMP_ACTION = OBJDUMP + ' -D -S $TARGET > rtt.asm\n'
POST_ACTION = OBJCPY + ' -O binary $TARGET rtthread.bin\n' + SIZE + ' $TARGET \n'