From: Loren Huang Date: Mon, 21 May 2012 07:32:25 +0000 (+0800) Subject: ENGR00209716-2 Revert "ENGR00209022 Update gpu clock management code" X-Git-Tag: v3.0.35-fsl_4.1.0~1160 X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=176e5bda5cc8f4b9ad98859f2229302455f6b535;p=karo-tx-linux.git ENGR00209716-2 Revert "ENGR00209022 Update gpu clock management code" This code is in 4.6.8 package. This patch will cause suspend/resume failure and data abort for vg applications. Signed-off-by: Loren Huang Acked-by: Lily Zhang --- diff --git a/drivers/mxc/gpu-viv/hal/os/linux/kernel/gc_hal_kernel_os.c b/drivers/mxc/gpu-viv/hal/os/linux/kernel/gc_hal_kernel_os.c index 6b97aa0d14ad..399234aff707 100644 --- a/drivers/mxc/gpu-viv/hal/os/linux/kernel/gc_hal_kernel_os.c +++ b/drivers/mxc/gpu-viv/hal/os/linux/kernel/gc_hal_kernel_os.c @@ -6934,55 +6934,46 @@ gckOS_SetGPUPower( struct clk *clk_2dcore = Os->device->clk_2d_core; struct clk *clk_2d_axi = Os->device->clk_2d_axi; struct clk *clk_vg_axi = Os->device->clk_vg_axi; - - gctBOOL oldClockState = gcvFALSE; gcmkHEADER_ARG("Os=0x%X Core=%d Clock=%d Power=%d", Os, Core, Clock, Power); - - if (Os->device->kernels[Core] != NULL) - oldClockState = Os->device->kernels[Core]->hardware->clockState; - if (Clock == gcvTRUE) { - if (oldClockState == gcvFALSE) { - switch (Core) { - case gcvCORE_MAJOR: - clk_enable(clk_3dcore); - if (cpu_is_mx6q()) - clk_enable(clk_3dshader); - break; - case gcvCORE_2D: - clk_enable(clk_2dcore); - clk_enable(clk_2d_axi); - break; - case gcvCORE_VG: - clk_enable(clk_2dcore); - clk_enable(clk_vg_axi); - break; - default: - break; - } + switch (Core) { + case gcvCORE_MAJOR: + clk_enable(clk_3dcore); + if (cpu_is_mx6q()) + clk_enable(clk_3dshader); + break; + case gcvCORE_2D: + clk_enable(clk_2dcore); + clk_enable(clk_2d_axi); + break; + case gcvCORE_VG: + clk_enable(clk_2dcore); + clk_enable(clk_vg_axi); + break; + default: + break; } } else { - if (oldClockState == gcvTRUE) { - switch (Core) { - case gcvCORE_MAJOR: - if (cpu_is_mx6q()) - clk_disable(clk_3dshader); - clk_disable(clk_3dcore); - break; - case gcvCORE_2D: - clk_disable(clk_2dcore); - clk_disable(clk_2d_axi); - break; - case gcvCORE_VG: - clk_disable(clk_2dcore); - clk_disable(clk_vg_axi); - break; - default: - break; - } + switch (Core) { + case gcvCORE_MAJOR: + if (cpu_is_mx6q()) + clk_disable(clk_3dshader); + clk_disable(clk_3dcore); + break; + case gcvCORE_2D: + clk_disable(clk_2dcore); + clk_disable(clk_2d_axi); + break; + case gcvCORE_VG: + clk_disable(clk_2dcore); + clk_disable(clk_vg_axi); + break; + default: + break; } } + /* TODO: Put your code here. */ gcmkFOOTER_NO(); return gcvSTATUS_OK;