===== arch/ia64/kernel/entry.S 1.61 vs edited ===== --- 1.61/arch/ia64/kernel/entry.S Wed Jun 16 18:09:33 2004 +++ edited/arch/ia64/kernel/entry.S Thu Jun 24 12:12:01 2004 @@ -179,19 +179,17 @@ .body adds r22=IA64_TASK_THREAD_KSP_OFFSET,r13 - movl r25=init_task mov r27=IA64_KR(CURRENT_STACK) - adds r21=IA64_TASK_THREAD_KSP_OFFSET,in0 dep r20=0,in0,61,3 // physical address of "current" ;; st8 [r22]=sp // save kernel stack pointer of old task shr.u r26=r20,IA64_GRANULE_SHIFT - cmp.eq p7,p6=r25,in0 + adds r21=IA64_TASK_THREAD_KSP_OFFSET,in0 ;; /* * If we've already mapped this task's page, we can skip doing it again. */ -(p6) cmp.eq p7,p6=r26,r27 + cmp.eq p7,p6=r26,r27 (p6) br.cond.dpnt .map ;; .done: ===== arch/ia64/kernel/head.S 1.24 vs edited ===== --- 1.24/arch/ia64/kernel/head.S Wed Jun 16 18:09:33 2004 +++ edited/arch/ia64/kernel/head.S Thu Jun 24 12:12:02 2004 @@ -154,10 +154,6 @@ #endif ;; tpa r3=r2 // r3 == phys addr of task struct - ;; - shr.u r16=r3,IA64_GRANULE_SHIFT -(isBP) br.cond.dpnt .load_current // BP stack is on region 5 --- no need to map it - // load mapping for stack (virtaddr in r2, physaddr in r3) rsm psr.ic movl r17=PAGE_KERNEL @@ -169,6 +165,7 @@ dep r2=-1,r3,61,3 // IMVA of task ;; mov r17=rr[r2] + shr.u r16=r3,IA64_GRANULE_SHIFT ;; dep r17=0,r17,8,24 ;; @@ -183,7 +180,6 @@ srlz.d ;; -.load_current: // load the "current" pointer (r13) and ar.k6 with the current task mov IA64_KR(CURRENT)=r2 // virtual address mov IA64_KR(CURRENT_STACK)=r16