/* SPDX-License-Identifier: GPL-2.0-only */ /* * Copyright (c) 2012, 2015-2019, The Linux Foundation. All rights reserved. */ #ifndef __SDE_ROTATOR_IO_UTIL_H__ #define __SDE_ROTATOR_IO_UTIL_H__ #include #include #include #include #include #ifdef DEBUG #define DEV_DBG(fmt, args...) pr_err(" " fmt, ##args) #else #define DEV_DBG(fmt, args...) pr_debug(" " fmt, ##args) #endif #define DEV_INFO(fmt, args...) pr_info(" " fmt, ##args) #define DEV_WARN(fmt, args...) pr_warn(" " fmt, ##args) #define DEV_ERR(fmt, args...) pr_err(" " fmt, ##args) struct sde_io_data { u32 len; void __iomem *base; }; void sde_reg_w(struct sde_io_data *io, u32 offset, u32 value, u32 debug); u32 sde_reg_r(struct sde_io_data *io, u32 offset, u32 debug); void sde_reg_dump(void __iomem *base, u32 len, const char *prefix, u32 debug); #define SDE_REG_W_ND(io, offset, val) sde_reg_w(io, offset, val, false) #define SDE_REG_W(io, offset, val) sde_reg_w(io, offset, val, true) #define SDE_REG_R_ND(io, offset) sde_reg_r(io, offset, false) #define SDE_REG_R(io, offset) sde_reg_r(io, offset, true) enum sde_vreg_type { SDE_REG_LDO, SDE_REG_VS, }; struct sde_vreg { struct regulator *vreg; /* vreg handle */ char vreg_name[32]; int min_voltage; int max_voltage; int enable_load; int disable_load; int pre_on_sleep; int post_on_sleep; int pre_off_sleep; int post_off_sleep; }; struct sde_gpio { unsigned int gpio; unsigned int value; char gpio_name[32]; }; enum sde_clk_type { SDE_CLK_AHB, /* no set rate. rate controlled through rpm */ SDE_CLK_PCLK, SDE_CLK_OTHER, }; struct sde_clk { struct clk *clk; /* clk handle */ char clk_name[32]; enum sde_clk_type type; unsigned long rate; }; struct sde_module_power { unsigned int num_vreg; struct sde_vreg *vreg_config; unsigned int num_gpio; struct sde_gpio *gpio_config; unsigned int num_clk; struct sde_clk *clk_config; }; int sde_rot_ioremap_byname(struct platform_device *pdev, struct sde_io_data *io_data, const char *name); void sde_rot_iounmap(struct sde_io_data *io_data); int sde_rot_config_vreg(struct device *dev, struct sde_vreg *in_vreg, int num_vreg, int config); int sde_rot_enable_vreg(struct sde_vreg *in_vreg, int num_vreg, int enable); int sde_rot_get_clk(struct device *dev, struct sde_clk *clk_arry, int num_clk); void sde_rot_put_clk(struct sde_clk *clk_arry, int num_clk); int sde_rot_clk_set_rate(struct sde_clk *clk_arry, int num_clk); int sde_rot_enable_clk(struct sde_clk *clk_arry, int num_clk, int enable); #endif /* __SDE_ROTATOR_IO_UTIL_H__ */