/* * drivers/video/tegra/host/nvhost_acm.h * * Tegra Graphics Host Automatic Clock Management * * Copyright (c) 2010-2017, NVIDIA Corporation. All rights reserved. * * This program is free software; you can redistribute it and/or modify it * under the terms and conditions of the GNU General Public License, * version 2, as published by the Free Software Foundation. * * This program is distributed in the hope 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 __NVHOST_ACM_H #define __NVHOST_ACM_H #include #include #include #include #include #include #include #include "nvhost_pd.h" /* Sets clocks and powergating state for a module */ int nvhost_clk_get(struct platform_device *dev, char *name, struct clk **clk); void nvhost_module_busy_noresume(struct platform_device *dev); void nvhost_module_reset(struct platform_device *dev, bool reboot); int nvhost_module_busy(struct platform_device *dev); void nvhost_module_idle_mult(struct platform_device *dev, int refs); int nvhost_module_add_client(struct platform_device *dev, void *priv); void nvhost_module_remove_client(struct platform_device *dev, void *priv); int nvhost_module_get_rate(struct platform_device *dev, unsigned long *rate, int index); int nvhost_module_set_rate(struct platform_device *dev, void *priv, unsigned long constraint, int index, unsigned long attr); int nvhost_module_do_idle(struct device *dev); int nvhost_module_do_unidle(struct device *dev); static inline bool nvhost_module_powered(struct platform_device *dev) { return !pm_runtime_status_suspended(&dev->dev); } /* common runtime pm and power domain APIs */ int nvhost_module_enable_clk(struct device *dev); int nvhost_module_disable_clk(struct device *dev); #endif