>  config LOCKDEP_SUPPORT
> diff --git a/arch/powerpc/kernel/entry_32.S b/arch/powerpc/kernel/entry_32.S
> index 69a91bd..bd3ce0f 100644
> --- a/arch/powerpc/kernel/entry_32.S
> +++ b/arch/powerpc/kernel/entry_32.S
> @@ -144,6 +144,47 @@ transfer_to_handler:
>       .globl transfer_to_handler_cont
>  transfer_to_handler_cont:
>  3:
> +#ifdef CONFIG_TRACE_IRQFLAGS
> +     lis     r11,[EMAIL PROTECTED]
> +     ori     r11,r11,[EMAIL PROTECTED]
> +     mtspr   SPRN_SRR0,r11
> +     mtspr   SPRN_SRR1,r10
> +     SYNC
> +     RFI

I don't think we need that on 4xx/BookE when using AS0 (that is also
true of the existing transfer_to_handler_cont, could be improved there.

> +reenable_mmu:                                /* re-enable mmu so we can */
> +     mflr    r9                      /* call C code, if necessary */
> +     mfmsr   r10
> +     lwz     r11,_MSR(r1)
> +     xor     r10,r10,r11
> +     andi.   r10,r10,MSR_EE          /* Did EE change? */
> +     beq     1f
> +     stwu    r1,-48(r1)              /* Yes, it must have been cleared */
> +     stw     r9,52(r1)
> +     stw     r0,16(r1)
> +     stw     r3,20(r1)
> +     stw     r4,24(r1)
> +     stw     r5,28(r1)
> +     stw     r6,32(r1)
> +     stw     r7,36(r1)
> +     stw     r8,40(r1)
> +     bl      trace_hardirqs_off
> +     lwz     r0,16(r1)
> +     lwz     r3,20(r1)
> +     lwz     r4,24(r1)
> +     lwz     r5,28(r1)
> +     lwz     r6,32(r1)
> +     lwz     r7,36(r1)
> +     lwz     r8,40(r1)
> +     lwz     r9,52(r1)
> +     addi    r1,r1,48

Why do yo save all the volatile regs ? They should have been saved on
the stack already by the exception prolog (the ptregs on the stack).

Also, only the system call really cares about -restoring- them. Maybe
you could stick that in an ifdef CONFIG_TRACE_IRQFLAGS section in
DoSyscall pulling them back off the ptregs in the stackframe. 

> +     tovirt(r9,r9)
> +     lwz     r11,0(r9)               /* virtual address of handler */
> +     lwz     r9,4(r9)                /* where to go when done */
> +     mtctr   r11
> +     mtlr    r9
> +     bctr                            /* jump to handler */
> +#else /* CONFIG_TRACE_IRQFLAGS */
>       mflr    r9
>       lwz     r11,0(r9)               /* virtual address of handler */
>       lwz     r9,4(r9)                /* where to go when done */
> @@ -152,6 +193,7 @@ transfer_to_handler_cont:
>       mtlr    r9
>       SYNC
>       RFI                             /* jump to handler, enable MMU */
> +#endif /* CONFIG_TRACE_IRQFLAGS */
>  
>  #ifdef CONFIG_6xx
>  4:   rlwinm  r12,r12,0,~_TLF_NAPPING
> @@ -220,12 +262,20 @@ ret_from_syscall:
>  #ifdef SHOW_SYSCALLS
>       bl      do_show_syscall_exit
>  #endif
> -     mr      r6,r3
>       rlwinm  r12,r1,0,0,(31-THREAD_SHIFT)    /* current_thread_info() */
>       /* disable interrupts so current_thread_info()->flags can't change */
>       LOAD_MSR_KERNEL(r10,MSR_KERNEL) /* doesn't include MSR_EE */
>       SYNC
>       MTMSRD(r10)
> +#ifdef CONFIG_TRACE_IRQFLAGS
> +     stwu    r1,-16(r1)
> +     stw     r3,12(r1)
> +     bl      trace_hardirqs_off
> +     lwz     r3,12(r1)
> +     addi    r1,r1,16
> +     LOAD_MSR_KERNEL(r10,MSR_KERNEL)
> +#endif

You may get away with pre-storing r3 in RESULT(r1), I'll have to double
check on monday... the 32 bits syscall exit code is a bit scary :-)

I'm pretty sure there's no need to allocate a stackframe. At worst,
there must be some ptregs field in the existing one that can be used.

That's all for today, I'll have another close look on monday.

Cheers,
Ben.


_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to