/* * Copyright (C) 2013 Red Hat * Author: Rob Clark * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 as published by * the Free Software Foundation. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along with * this program. If not, see . */ #ifndef __A3XX_GPU_H__ #define __A3XX_GPU_H__ #include "adreno_gpu.h" #include "a3xx.xml.h" struct a3xx_gpu { struct adreno_gpu base; /* Power Control: */ struct regulator *gpu_reg, *gpu_cx; struct clk *ebi1_clk, *grp_clks[5]; uint32_t fast_rate, slow_rate, bus_freq; uint32_t bsc; }; #define to_a3xx_gpu(x) container_of(x, struct a3xx_gpu, base) int a3xx_gpu_pm_suspend(struct adreno_gpu *gpu); int a3xx_gpu_pm_resume(struct adreno_gpu *gpu); void a3xx_bs_init(struct a3xx_gpu *gpu, struct platform_device *pdev); void a3xx_bs_fini(struct a3xx_gpu *gpu); #endif /* __A3XX_GPU_H__ */