[PATCH] pte_fsl_booke: fix instruction TLB error permission check
Benjamin Herrenschmidt
benh at kernel.crashing.org
Fri May 14 13:42:34 EST 2010
On Fri, 2010-05-14 at 08:53 +0800, Liu Dave-R63238 wrote:
> > I've updated the commit message to be a bit more clear on why
> > we need to do this.
>
> I'm curious why the _PAGE_EXEC have different definition in pte-book3e.h
> and pte-fsl-booke.h?
>
> It is UX permission in pte-book3e, but is SX permission in
> pte-fsl-booke.h.
Oh well, there's a whole history here :-)
I'm not 100% sure of the "old" fsl-booke, but pte-book3e uses UX since
that's what _PAGE_EXEC really represents from a kernel standpoint,
user-execute.
On book3e, we need to account for the HW tablewalk, which means that the
PTE can be loaded as-is by the HW. We thus don't get a chance to test
whether we are user or supervisor or change the bits accordingly. We
thus need _PAGE_EXEC to fall right into UX since that's really what the
kernel manipulates it for.
It also means that user pages will not get execute permission in
supervisor mode which is a good thing :-)
For kernel-execute, we have a specific permission, which should be
obtained via PAGE_KERNEL_EXEC in vmalloc_exec().
Cheers,
Ben.
More information about the Linuxppc-dev
mailing list