int.S:
-
;************************************************************************
-
;*
-
;* FUNCTION
-
;*
-
;* INT_Initialize
-
;*
-
;* DESCRIPTION
-
;*
-
;* This function sets up the global system stack variable and
-
;* transfers control to the target independent initialization
-
;* function INC_Initialize. Responsibilities of this function
-
;* include the following:
-
;*
-
;* - Setup necessary processor/system control registers
-
;* - Initialize the vector table
-
;* - Setup the system stack pointers
-
;* - Setup the timer interrupt
-
;* - Calculate the timer HISR stack and priority
-
;* - Calculate the first available memory address
-
;* - Transfer control to INC_Initialize to initialize all of
-
;* the system components.
-
;*
-
;* Major Revision:
-
;*
-
;* M. Kyle Craig, Accelerated Technology, Inc.
-
;*
-
;*
-
;*
-
;*
-
;* CALLED BY
-
;*
-
;* Nothing. This function is the ENTRY point for Nucleus PLUS.
-
;*
-
;* CALLS
-
;*
-
;* INC_Initialize Common initialization
-
;*
-
;* INPUTS
-
;*
-
;* None
-
;*
-
;* OUTPUTS
-
;*
-
;* None
-
;*
-
;* HISTORY
-
;*
-
;* NAME DATE REMARKS
-
;*
-
;* W. Lamie 08-27-1994 Created initial version 1.0
-
;* D. Lamie 08-27-1994 Verified version 1.0
-
;*
-
;************************************************************************
-
;VOID INT_Initialize(void)
-
;{
-
-
.def _c_int00
-
_c_int00
-
-
.def _INT_Initialize
-
_INT_Initialize:
-
-
; Insure that the processor is in supervisor mode. //设置了arm的svc模式
-
MRS r0,CPSR ; Pickup current CPSR
-
BIC r0,r0,#MODE_MASK ; Clear the mode bits
-
ORR r0,r0,#SUP_MODE ; Set the supervisor mode bits
-
ORR r0,r0,#LOCKOUT ; Insure IRQ/FIQ interrupts are //关闭中断
-
; locked out
-
MSR CPSR,r0 ; Setup the new CPSR
-
-
; Clear the un-initialized global and static C data areas.
-
LDR r0,BSS_Start ; Pickup the start of the BSS area
-
MOV r2,#0 ; Clear value in r2
-
LDR r1,BSS_End ; Pickup the end of the BSS area
-
-
INT_BSS_Clear_Loop
-
STR r2,[r0],#4 ; Clear a word //初始化Bss段
-
-
INT_BSS_Clear_Check
-
CMP r0,r1 ; Are the start and end equal?
-
BNE INT_BSS_Clear_Loop ; If so, continue with BSS clear
-
-
; Perform auto-initialization. if cinit is -1, then there is none.
-
LDR r0, c_cinit
-
CMN r0, #1
-
BLNE _auto_init
-
-
-
; Turn-on the I-Cache for the TI 925T Processor //开启I-Cache
-
-
MRC p15,#0,r1,C1,C0,#0 ; Read the control register.
-
ORR r1,r1,#0x1000 ; Set the I bit to enable Instruction Cache
-
NOP
-
MCR p15,#0,r1,C1,C0,#0 ; Write the control register.
-
-
-
; Setup the vectors loaded flag to indicate to other routines in the
-
; system whether or not all of the default vectors have been loaded.
-
; If INT_Loaded_Flag is 1, all of the default vectors have been loaded.
-
; Otherwise, if INT_Loaded_Flag is 0, registering an LISR cause the
-
; default vector to be loaded. In the ARM60 this variable is always
-
; set to 1. All vectors must be setup by this function.
-
; INT_Loaded_Flag = 0;
-
-
MOV r0,#1 ; All vectors are assumed loaded
-
LDR r1,Loaded_Flag ; Build address of loaded flag
-
STR r0,[r1,#0] ; Initialize loaded flag
-
-
-
; Initialize the system stack pointers. This is done after the BSS is
-
; clear because the TCD_System_Stack pointer is a BSS It is
-
; assumed that available memory starts immediately after the end of the
-
; BSS section. //建立sys stack
-
-
LDR r10,System_Stk_Limit ; Pickup the system stack limit (bottom of system stack)
-
LDR r3,System_Limit ; Pickup sys stack limit addr
-
STR r10,[r3, #0] ; Save stack limit
-
-
LDR sp,System_Stack_SP ; Set-up the system stack pointer
-
LDR r3,System_Stack ; Pickup system stack address
-
STR sp,[r3, #0] ; Save stack pointer
-
-
MRS r0,CPSR ; Pickup current CPSR
-
BIC r0,r0,#MODE_MASK ; Clear the mode bits
-
ORR r0,r0,#IRQ_MODE ; Set the IRQ mode bits
-
MSR CPSR,r0 ; Move to IRQ mode
-
-
LDR sp,IRQ_Stack_SP ; Setup IRQ stack pointer
-
-
MRS r0,CPSR ; Pickup current CPSR
-
BIC r0,r0,#MODE_MASK ; Clear the mode bits
-
ORR r0,r0,#FIQ_MODE ; Set the FIQ mode bits
-
MSR CPSR,r0 ; Move to the FIQ mode
-
-
LDR sp,FIQ_Stack_SP ; Setup FIQ stack pointer
-
-
MRS r0,CPSR ; Pickup current CPSR
-
BIC r0,r0,#MODE_MASK ; Clear mode bits
-
ORR r0,r0,#SUP_MODE ; Set the supervisor mode bits
-
MSR CPSR,r0 ; All interrupt stacks are setup,
-
; return to supervisor mode
-
-
; Define the global data structures that need to be initialized by this //设置中断
-
; routine. These structures are used to define the system timer
-
; management HISR.
-
; TMD_HISR_Stack_Ptr = (VOID *) r2;
-
; TMD_HISR_Stack_Size = TIMER_SIZE;
-
; TMD_HISR_Priority = TIMER_PRIORITY;
-
-
LDR r2,HISR_Stack_Mem ; Get HISR stack memory address
-
LDR r3,HISR_Stack_Ptr ; Pickup variable's address
-
STR r2,[r3, #0] ; Setup timer HISR stack pointer
-
MOV r1,#HISR_STACK_SIZE ; Pickup the timer HISR stack size
-
LDR r3,HISR_Stack_Size ; Pickup variable's address
-
STR r1,[r3, #0] ; Setup timer HISR stack size
-
MOV r1,#HISR_PRIORITY ; Pickup timer HISR priority (0-2)
-
LDR r3,HISR_Priority ; Pickup variable's address
-
STR r1,[r3, #0] ; Setup timer HISR priority
-
-
; Make a call to begin all board specific initialization. //初始化时钟
-
; Begin with Initializing the Vector table and replacing
-
; default interrupts with Plus IRQs. Then setup the timer
-
; and begin the system clock.
-
-
.if $$isdefed("NU_ROM_SUPPORT")
-
-
BL _INT_Timer_Initialize ; Initialize the timer
-
-
.else
-
-
BL INT_Install_Vector_Table ; Install the vector table
-
BL _INT_Timer_Initialize ; Initialize the timer
-
-
.endif
-
-
; Call INC_Initialize with a pointer to the first available memory
-
; address after the compiler's global data. This memory may be used
-
; by the application.
-
; INC_Initialize(first_available_memory);
-
-
LDR r0,First_Avail_Mem ; Get address of first available memory
-
-
B _INC_Initialize ; to high-level initialization //最后跳转到_INC_Initialize,找不到函数在哪
-
;}
-
-
。。。。。。
-
。。。。。。
-
初始化组件由三个部分组成,硬件在reset后首先进入INT_initialize(),进行板级的相关初始化,首先设置SVC mode,关中断,然后将内核从rom中拷贝至ram中,建立bss段,依次建立sys stack, irq stack和fiq stack,最后初始化timer,建立timer HISR的栈空间,看了一下2410平台的代码,一个tick大概是15.8ms,完成板级的初始化后就进入了INC_initialize。
inc.c:
到这里找不到函数了。。。
csc.c:包含nucleus plus系统中使用的连接表处理工具,采用双向循环链表(doubley-linked circulat lists)
dmc.c:包含动态内存管理组件的
核心事务
dmce.c:包含动态内存管理组件中的函数错误检查例程,可以关闭?
dmd.c:包含动态内存管理组件中的全局数据结构
dmf.c:包含获取管理动态内存管理组件的事实的例程
dmi.c:包含动态内存管理组件的初始化例程
dms.c:包含动态内存管理组件的补充例程
erc.c:包含错误管理组件的
核心事务
erd.c:包含错误管理组件的官居数据结构
eri.c:包含错误管理组件初始化例程
evc.c:包含事件组管理组件
核心事务
evce.c:包含事件组错误检查
evd.c:事件组全局数据结构
evf.c
evi.c
hic.c:包含历史管理组件的
核心事务
hid.c
hii.c
inc.c
int.s
ioc.c:I/O驱动管理
核心事务
ioce.c
iod.c
iof.c
ioi.c
lic.c:license informations组件
核心事务
lid.c
mbc.c:邮箱管理组件
核心事务
mbce.c
mbd.c
mbf.c
mbi.c
mbs.c
mbse.c
pic.c:管道管理核心事务
pice.c
pid.c
pif.c
pii.c
pis.c
pise.c
pmc.c:内存管理划分(partition)核心事务
pmce.c
pmd.c
pmf.c
pmi.c
quc.c:队列管理核心事务
quce.c
qud.c
quf.c
qui.c
qus.c
quse.c
rlc.c:版本信息(Release Information)核心事务
rld.c
sdc.c:包含串行驱动特定功能
smc.c:信号量管理核心事务
smce.c
smd.c
smd.c
smf.c
smi.c
sms.c
smse.c
tcc.c:进程控制
tcce.c
tcd.c
tcf.c
tci.c
tcs.c
tcse.c
tct.s
tmc.c:此函数负责提供初始化的任务定时器,此程序必须在svc/usr模式下内核切换成svc模式运行。
tmd.c
tmf.c
tmi.c
tms.c
tmse.c
tmt.s
文件命名前2个字母是组件的缩写,后面的字母是不同的文件。
d包含了相关全局变量,i是初始化部分,f是组件管理的对象的信息,c是核心函数,ce是错误处理,se是补充。
阅读(858) | 评论(0) | 转发(0) |