我用IAR5.2的环境,想让编译的代码整个放到不是0x00地址处(例如0x2000),设置完相应的.icf文件,可是编译后发现发现,真正的代码段是放到了0x2000处,但是cstartup.s的中断向量表还是从0x00处开始的,请问怎么样才能使cstartup.s的中断向量表从0x2000处开始。 以下为cstartup.s源文件:
;******************************************************************************************************** ; MACROS AND DEFINIITIONS ;********************************************************************************************************
; Mode, correspords to bits 0-5 in CPSR MODE_BITS DEFINE 0x1F ; Bit mask for mode bits in CPSR USR_MODE DEFINE 0x10 ; User mode FIQ_MODE DEFINE 0x11 ; Fast Interrupt Request mode IRQ_MODE DEFINE 0x12 ; Interrupt Request mode SVC_MODE DEFINE 0x13 ; Supervisor mode ABT_MODE DEFINE 0x17 ; Abort mode UND_MODE DEFINE 0x1B ; Undefined Instruction mode SYS_MODE DEFINE 0x1F ; System mode
;******************************************************************************************************** ; ARM EXCEPTION VECTORS ;********************************************************************************************************
SECTION .intvec:CODE:NOROOT(2) PUBLIC __vector PUBLIC __iar_program_start
IMPORT OS_CPU_ARM_ExceptUndefInstrHndlr IMPORT OS_CPU_ARM_ExceptSwiHndlr IMPORT OS_CPU_ARM_ExceptPrefetchAbortHndlr IMPORT OS_CPU_ARM_ExceptDataAbortHndlr IMPORT OS_CPU_ARM_ExceptIrqHndlr IMPORT OS_CPU_ARM_ExceptFiqHndlr
ARM
__vector: LDR PC, [PC,#24] ; Absolute jump can reach 4 GByte LDR PC, [PC,#24] ; Branch to undef_handler LDR PC, [PC,#24] ; Branch to swi_handler LDR PC, [PC,#24] ; Branch to prefetch_handler LDR PC, [PC,#24] ; Branch to data_handler __vector_0x14: DC32 0 ; Reserved LDR PC, [PC,#24] ; Branch to irq_handler LDR PC, [PC,#24] ; Branch to fiq_handler
DC32 __iar_program_start DC32 OS_CPU_ARM_ExceptUndefInstrHndlr DC32 OS_CPU_ARM_ExceptSwiHndlr DC32 OS_CPU_ARM_ExceptPrefetchAbortHndlr DC32 OS_CPU_ARM_ExceptDataAbortHndlr DC32 0 DC32 OS_CPU_ARM_ExceptIrqHndlr DC32 OS_CPU_ARM_ExceptFiqHndlr
;******************************************************************************************************** ; LOW-LEVEL INITIALIZATION ;********************************************************************************************************
SECTION FIQ_STACK:DATA:NOROOT(3) SECTION IRQ_STACK:DATA:NOROOT(3) SECTION SVC_STACK:DATA:NOROOT(3) SECTION ABT_STACK:DATA:NOROOT(3) SECTION UND_STACK:DATA:NOROOT(3) SECTION CSTACK:DATA:NOROOT(3) SECTION text:CODE:NOROOT(2) REQUIRE __vector EXTERN ?main PUBLIC __iar_program_start EXTERN lowlevel_init
__iar_program_start:
;******************************************************************************************************** ; STACK POINTER INITIALIZATION ;********************************************************************************************************
MRS r0,cpsr ; Original PSR value BIC r0,r0,#MODE_BITS ; Clear the mode bits ORR r0,r0,#SVC_MODE ; Set SVC mode bits MSR cpsr_c,r0 ; Change the mode LDR sp,=SFE(SVC_STACK) ; End of SVC_STACK
BIC r0,r0,#MODE_BITS ; Clear the mode bits ORR r0,r0,#UND_MODE ; Set UND mode bits MSR cpsr_c,r0 ; Change the mode LDR sp,=SFE(UND_STACK) ; End of UND_STACK
BIC r0,r0,#MODE_BITS ; Clear the mode bits ORR r0,r0,#ABT_MODE ; Set ABT mode bits MSR cpsr_c,r0 ; Change the mode LDR sp,=SFE(ABT_STACK) ; End of ABT_STACK
BIC r0,r0,#MODE_BITS ; Clear the mode bits ORR r0,r0,#FIQ_MODE ; Set FIQ mode bits MSR cpsr_c,r0 ; Change the mode LDR sp,=SFE(FIQ_STACK) ; End of FIQ_STACK
BIC r0,r0,#MODE_BITS ; Clear the mode bits ORR r0,r0,#IRQ_MODE ; Set IRQ mode bits MSR cpsr_c,r0 ; Change the mode LDR sp,=SFE(IRQ_STACK) ; End of IRQ_STACK
BIC r0,r0,#MODE_BITS ; Clear the mode bits ORR r0,r0,#SYS_MODE ; Set System mode bits MSR cpsr_c,r0 ; Change the mode LDR sp,=SFE(CSTACK) ; End of CSTACK
;******************************************************************************************************** ; ADDITIONAL INITIALIZATION ;********************************************************************************************************
;******************************************************************************************************** ; CONTINUE TO ?main FOR ADDITIONAL INITIALIZATION ;********************************************************************************************************
LDR r0,=?main BX r0
END |
|