powerpc/cell: Move data segment faulting code out of cell platform
authorIan Munsie <imunsie@au1.ibm.com>
Wed, 8 Oct 2014 08:54:51 +0000 (19:54 +1100)
committerMichael Ellerman <mpe@ellerman.id.au>
Wed, 8 Oct 2014 09:14:55 +0000 (20:14 +1100)
commit73d16a6e0e51990cbe13f8d8f43bd5329bbab30a
treed151865457d0653072ee8dd2fbc23fb84f05fe23
parente83d01697583d8610d1d62279758c2a881e3396f
powerpc/cell: Move data segment faulting code out of cell platform

__spu_trap_data_seg() currently contains code to determine the VSID and ESID
required for a particular EA and mm struct.

This code is generically useful for other co-processors. This moves the code of
the cell platform so it can be used by other powerpc code. It also adds 1TB
segment handling which Cell didn't support.  The new function is called
copro_calculate_slb().

This also moves the internal struct spu_slb to a generic struct copro_slb which
is now used in the Cell and copro code.  We use this new struct instead of
passing around esid and vsid parameters.

Signed-off-by: Ian Munsie <imunsie@au1.ibm.com>
Signed-off-by: Michael Neuling <mikey@neuling.org>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/include/asm/copro.h
arch/powerpc/include/asm/mmu-hash64.h
arch/powerpc/mm/copro_fault.c
arch/powerpc/mm/slb.c
arch/powerpc/platforms/cell/spu_base.c