struct stack {
    u32 irq[3];
    u32 abt[3];
    u32 und[3];
} ____cacheline_aligned;
static struct stack stacks[NR_CPUS];
CPU 갯수만큼 stacks 이 만들어 진다.
IRQ_MODE, ABT_MODE, UND_MODE 의 sp 를 지정한다.
irq[0] <- IRQ_MODE 의 sp 시작
irq[1]
irq[2]
abt[0] <- ABT_MODE 의 sp 시작
abt[1]
abt[2]
und[0] <- UND_MODE 의 sp 시작
und[1]
und[2]

[ setup_per_cpu_areas ] init/main.c
 
DEFINE_PER_CPU 로 정의된 것들이 컴파일 되면서, __per_cpu_start ~__per_cpu_end 사이의 영역에 들어간다.
DEFINE_PER_CPU(struct cpuinfo_arm, cpu_data);

[ smp_prepare_boot_cpu ] arch/arm/kernel/smp.c
 
cpu_data.idle = current 를 저장한다.

 
[ sched_init ] kernel/sched.c
 
cpu_rq(cpu) 는 해당 cpu의 struct rq자료를 리턴한다.  각 cpu 의 run queue 자료를 초기화 한다.
 
[ preempt_disable ] include/linux/preempt.h
 
CONFIG_PREEMPT 가 정의 되어 있어야 한다. 정의 되어 있지 않다면, preempt_disable , preempt_enable 는 빈 함수로 구현된다.
 
// include/linux/preempt.h
#define preempt_disable() \
do { \
    inc_preempt_count(); \
    barrier(); \
} while (0)
#define preempt_enable() \
do { \
    preempt_enable_no_resched(); \
    barrier(); \
    preempt_check_resched(); \
} while (0)
#define add_preempt_count(val) do { preempt_count() += (val); } while (0)
#define sub_preempt_count(val) do { preempt_count() -= (val); } while (0)
#define inc_preempt_count() add_preempt_count(1)
#define dec_preempt_count() sub_preempt_count(1)
#define preempt_count() (current_thread_info()->preempt_count)
 
[ build_all_zonelists ] mm/page_alloc.c
 
system_state = SYSTEM_BOOTING 이면
__build_all_zonelists(NULL); 를 호출한다.

 
[ sort_main_extable ] kernel/extable.c
 
섹션 __start___ex_table 부터 __stop___ex_table 에 까지 등록되어 있는 struct exception_table_entryinsn 값으로 정열한다.
struct exception_table_entry
{
    unsigned long insn, fixup;
};

[ trap_init ] arch/arm/kernel/traps.c
 
0xffff0000 에 __vectors_start 부터 __vectors_end  를 복사한다.
0xffff0000 + 0x200 에 __stubs_start 부터 __stubs_end 를 복사한다.
0xffff0000 + 0x1000 - kuser_sz 에 __kuser_helper_start 부터 kuser_sz 만큼 복사한다.
kuser_sz = __kuser_helper_end - __kuser_helper_start

'리눅스커널' 카테고리의 다른 글

[ kmem_cache_init ] mm/slab.c  (0) 2009.10.02
[ IRQ 처리 ]  (0) 2009.10.02
[ devicemaps_init ] arch/arm/mm/mmu.c  (0) 2009.10.02
[ bootmem_bootmap_pages ] mm/bootmem.c  (0) 2009.10.02
[ create_mapping ] arch/arm/mm/mmu.c  (0) 2009.10.02
Posted by blee
,