[PATCH] Stop snd-powermac oopsing on non-pmac hardware.
[safe/jmp/linux-2.6] / arch / ia64 / kernel / fsys.S
index d09a5b8..7d7684a 100644 (file)
@@ -460,9 +460,9 @@ EX(.fail_efault, ld8 r14=[r33])                     // r14 <- *set
        ;;
 
        st8 [r2]=r14                            // update current->blocked with new mask
-       cmpxchg4.acq r14=[r9],r18,ar.ccv        // current->thread_info->flags <- r18
+       cmpxchg4.acq r8=[r9],r18,ar.ccv         // current->thread_info->flags <- r18
        ;;
-       cmp.ne p6,p0=r17,r14                    // update failed?
+       cmp.ne p6,p0=r17,r                    // update failed?
 (p6)   br.cond.spnt.few 1b                     // yes -> retry
 
 #ifdef CONFIG_SMP
@@ -630,10 +630,10 @@ GLOBAL_ENTRY(fsys_bubble_down)
        ;;
        mov ar.rsc=0x3                          // M2   set eager mode, pl 0, LE, loadrs=0
        mov rp=r14                              // I0   set the real return addr
-       nop.i 0
+       and r3=_TIF_SYSCALL_TRACEAUDIT,r3       // A
        ;;
        ssm psr.i                               // M2   we're on kernel stacks now, reenable irqs
-       tbit.z p8,p0=r3,TIF_SYSCALL_TRACE       // I0
+       cmp.eq p8,p0=r3,r0                      // A
 (p10)  br.cond.spnt.many ia64_ret_from_syscall // B    return if bad call-frame or r15 is a NaT
 
        nop.m 0