/** * Copyright (C) 2010-2011 ARM Limited. All rights reserved. * * This program is free software and is provided to you under the terms of the GNU General Public License version 2 * as published by the Free Software Foundation, and any use by you of this program is subject to the terms of such GNU licence. * * A copy of the licence is included with the program, and can also be obtained from Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ /** * @file mali_osk_pm.c * Implementation of the callback functions from common power management */ #include #ifdef CONFIG_PM_RUNTIME #include #endif /* CONFIG_PM_RUNTIME */ #include #include "mali_platform.h" #include "mali_osk.h" #include "mali_uk_types.h" #include "mali_pmm.h" #include "mali_ukk.h" #include "mali_kernel_common.h" #include "mali_kernel_license.h" #include "mali_kernel_pm.h" #include "mali_device_pause_resume.h" #include "mali_linux_pm.h" #include "mali_linux_pm_testsuite.h" #if MALI_PMM_RUNTIME_JOB_CONTROL_ON #ifdef CONFIG_PM_RUNTIME static int is_runtime =0; #endif /* CONFIG_PM_RUNTIME */ #endif /* MALI_PMM_RUNTIME_JOB_CONTROL_ON */ #if MALI_POWER_MGMT_TEST_SUITE #ifdef CONFIG_PM unsigned int mali_pmm_events_triggered_mask = 0; #endif /* CONFIG_PM */ void _mali_osk_pmm_policy_events_notifications(mali_pmm_event_id mali_pmm_event) { #if MALI_LICENSE_IS_GPL #ifdef CONFIG_PM switch (mali_pmm_event) { case MALI_PMM_EVENT_JOB_QUEUED: if (mali_job_scheduling_events_recording_on == 1) { mali_pmm_events_triggered_mask |= (1<<0); } break; case MALI_PMM_EVENT_JOB_SCHEDULED: if (mali_job_scheduling_events_recording_on == 1) { mali_pmm_events_triggered_mask |= (1<<1); } break; case MALI_PMM_EVENT_JOB_FINISHED: if (mali_job_scheduling_events_recording_on == 1) { mali_pmm_events_triggered_mask |= (1<<2); mali_job_scheduling_events_recording_on = 0; pwr_mgmt_status_reg = mali_pmm_events_triggered_mask; } break; case MALI_PMM_EVENT_TIMEOUT: if (mali_timeout_event_recording_on == 1) { pwr_mgmt_status_reg = (1<<3); mali_timeout_event_recording_on = 0; } break; default: break; } #endif /* CONFIG_PM */ #endif /* MALI_LICENSE_IS_GPL */ } #endif /* MALI_POWER_MGMT_TEST_SUITE */ /** This function is called when the Mali device has completed power up * operation. */ void _mali_osk_pmm_power_up_done(mali_pmm_message_data data) { #if MALI_LICENSE_IS_GPL #ifdef CONFIG_PM is_wake_up_needed = 1; wake_up_process(pm_thread); MALI_DEBUG_PRINT(4, ("OSPMM: MALI OSK Power up Done\n" )); return; #endif /* CONFIG_PM */ #endif /* MALI_LICENSE_IS_GPL */ } /** This function is called when the Mali device has completed power down * operation. */ void _mali_osk_pmm_power_down_done(mali_pmm_message_data data) { #if MALI_LICENSE_IS_GPL #ifdef CONFIG_PM is_wake_up_needed = 1; #if MALI_POWER_MGMT_TEST_SUITE if (is_mali_pmu_present == 0) { pwr_mgmt_status_reg = _mali_pmm_cores_list(); } #endif /* MALI_POWER_MGMT_TEST_SUITE */ wake_up_process(pm_thread); MALI_DEBUG_PRINT(4, ("OSPMM: MALI Power down Done\n" )); return; #endif /* CONFIG_PM */ #endif /* MALI_LICENSE_IS_GPL */ } /** This function is invoked when mali device is idle. */ _mali_osk_errcode_t _mali_osk_pmm_dev_idle(void) { _mali_osk_errcode_t err = 0; #if MALI_LICENSE_IS_GPL #ifdef CONFIG_PM_RUNTIME #if MALI_PMM_RUNTIME_JOB_CONTROL_ON err = pm_runtime_put_sync(&(mali_gpu_device.dev)); if(err) { MALI_DEBUG_PRINT(4, ("OSPMM: Error in _mali_osk_pmm_dev_idle\n" )); } #endif /* MALI_PMM_RUNTIME_JOB_CONTROL_ON */ #endif /* CONFIG_PM_RUNTIME */ #endif /* MALI_LICENSE_IS_GPL */ return err; } /** This funtion is invoked when mali device needs to be activated. */ void _mali_osk_pmm_dev_activate(void) { #if MALI_LICENSE_IS_GPL #ifdef CONFIG_PM_RUNTIME #if MALI_PMM_RUNTIME_JOB_CONTROL_ON int err = 0; if(is_runtime == 0) { pm_suspend_ignore_children(&(mali_gpu_device.dev), true); pm_runtime_enable(&(mali_gpu_device.dev)); pm_runtime_get_sync(&(mali_gpu_device.dev)); is_runtime = 1; } else { err = pm_runtime_get_sync(&(mali_gpu_device.dev)); } if(err) { MALI_DEBUG_PRINT(4, ("OSPMM: Error in _mali_osk_pmm_dev_activate\n" )); } #endif /* MALI_PMM_RUNTIME_JOB_CONTROL_ON */ #endif /* CONFIG_PM_RUNTIME */ #endif /* MALI_LICENSE_IS_GPL */ } void _mali_osk_pmm_dvfs_operation_done(mali_pmm_message_data data) { #if MALI_LICENSE_IS_GPL #ifdef CONFIG_PM is_wake_up_needed = 1; wake_up_process(dvfs_pm_thread); MALI_DEBUG_PRINT(4, ("OSPMM: MALI OSK DVFS Operation done\n" )); return; #endif /* CONFIG_PM */ #endif /* MALI_LICENSE_IS_GPL */ }