Re: Sparc miss chance to fix recoverable fault in copy_from_user

From: David Miller
Date: Thu Aug 13 2009 - 15:48:39 EST


From: hyl <heyongli@xxxxxxxxx>
Date: Wed, 12 Aug 2009 09:53:01 +0800

Please post all Sparc patches and questions CC:'d to
sparclinux@xxxxxxxxxxxxxxx otherwise no Sparc experts are going to see
it.

> --- a/arch/sparc/kernel/sun4v_tlb_miss.S
> +++ b/arch/sparc/kernel/sun4v_tlb_miss.S
> @@ -124,7 +124,7 @@ sun4v_dtlb_load:
> mov %g3, %o2 ! PTE
> mov HV_MMU_DMMU, %o3 ! flags
> ta HV_MMU_MAP_ADDR_TRAP
> - brnz,pn %o0, sun4v_dtlb_error
> + brnz,pn %o0, sun4v_dtlb_prot
> mov %g2, %o1 ! restore %o1
> mov %g1, %o0 ! restore %o0
> mov %g5, %o2 ! restore %o2
>
>
>
> am i miss understanding the merged sparc/spar64?
>
> this problem found on sparc64, via a simple module just access address 0
> via copy_from_user. another simple test is kgdb, issue a cmd:
> x 0

That condition should never trigger, the problem is caused
elsewhere.

If the HV_MMU_MAP_ADDR_TRAP hypervisor call gives an error it means:

1) The PTE passed in is invalid

2) The PTE passed in translates to addresses outside of the
range accessible to the guest

3) The virtual address is invalid

And the kernel should never have such an illegal address or
PTE mapping here.

You need to figure out how the bad mapping gets into the kernel page
tables and/or translations in the first place.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/