| /* Copyright (c) 2017, The Linux Foundation. All rights reserved. |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 and |
| * only 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. |
| * |
| */ |
| |
| #ifndef _MSM_VIDC_CLOCKS_H_ |
| #define _MSM_VIDC_CLOCKS_H_ |
| #include "msm_vidc_internal.h" |
| |
| /* extra o/p buffers in case of encoder dcvs */ |
| #define DCVS_ENC_EXTRA_OUTPUT_BUFFERS 2 |
| |
| /* extra o/p buffers in case of decoder dcvs */ |
| #define DCVS_DEC_EXTRA_OUTPUT_BUFFERS 4 |
| |
| void msm_clock_data_reset(struct msm_vidc_inst *inst); |
| int msm_vidc_update_operating_rate(struct msm_vidc_inst *inst); |
| int msm_vidc_get_extra_buff_count(struct msm_vidc_inst *inst, |
| enum hal_buffer buffer_type); |
| int msm_dcvs_try_enable(struct msm_vidc_inst *inst); |
| int msm_comm_scale_clocks_and_bus(struct msm_vidc_inst *inst); |
| int msm_comm_init_clocks_and_bus_data(struct msm_vidc_inst *inst); |
| void msm_comm_free_freq_table(struct msm_vidc_inst *inst); |
| int msm_vidc_decide_work_mode(struct msm_vidc_inst *inst); |
| int msm_vidc_decide_core_and_power_mode(struct msm_vidc_inst *inst); |
| void msm_vidc_clear_freq_entry(struct msm_vidc_inst *inst, |
| u32 device_addr); |
| void update_recon_stats(struct msm_vidc_inst *inst, |
| struct recon_stats_type *recon_stats); |
| #endif |