From d45c5b0622ff2099402a09eae29a01e9fdb96bdf Mon Sep 17 00:00:00 2001 From: Alistair Strachan Date: Tue, 19 Jun 2012 17:58:12 +0100 Subject: gpu: pvr: Flush the whole CPU cache when allocating uncached. This is a workaround for range-based CPU cache invalidation apparently not working reliably. Change-Id: I62fe3d10a465ee630729d7edf054f7bc82a422d8 --- drivers/gpu/pvr/Makefile | 1 + drivers/gpu/pvr/mm.c | 4 ++++ 2 files changed, 5 insertions(+) (limited to 'drivers/gpu') diff --git a/drivers/gpu/pvr/Makefile b/drivers/gpu/pvr/Makefile index 10a89b8..d428d50 100644 --- a/drivers/gpu/pvr/Makefile +++ b/drivers/gpu/pvr/Makefile @@ -37,6 +37,7 @@ ccflags-y += \ -Idrivers/gpu/pvr/sgx \ -DSUPPORT_GET_DC_BUFFERS_SYS_PHYADDRS \ -DPVRSRV_MMU_MAKE_READWRITE_ON_DEMAND \ + -DPVRSRV_AVOID_RANGED_INVALIDATE \ -DPVR_LDM_DRIVER_REGISTRATION_NAME="\"pvrsrvkm\"" ccflags-$(CONFIG_PVR_BUILD_RELEASE) += \ diff --git a/drivers/gpu/pvr/mm.c b/drivers/gpu/pvr/mm.c index ecad206..80f0efe 100644 --- a/drivers/gpu/pvr/mm.c +++ b/drivers/gpu/pvr/mm.c @@ -983,7 +983,11 @@ NewVMallocLinuxMemArea(IMG_UINT32 ui32Bytes, IMG_UINT32 ui32AreaFlags) if (AreaIsUncached(ui32AreaFlags) && !bFromPagePool) { +#if !defined(PVRSRV_AVOID_RANGED_INVALIDATE) OSInvalidateCPUCacheRangeKM(psLinuxMemArea, pvCpuVAddr, ui32Bytes); +#else + OSFlushCPUCacheKM(); +#endif } return psLinuxMemArea; -- cgit v1.1