cregit-Linux how code gets into the kernel

Release 4.12 drivers/gpu/drm/amd/powerplay/amd_powerplay.c

/*
 * Copyright 2015 Advanced Micro Devices, Inc.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
 * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 * OTHER DEALINGS IN THE SOFTWARE.
 *
 */
#include "pp_debug.h"
#include <linux/types.h>
#include <linux/kernel.h>
#include <linux/gfp.h>
#include <linux/slab.h>
#include "amd_shared.h"
#include "amd_powerplay.h"
#include "pp_instance.h"
#include "power_state.h"
#include "eventmanager.h"



static inline int pp_check(struct pp_instance *handle) { if (handle == NULL || handle->pp_valid != PP_VALID) return -EINVAL; if (handle->smu_mgr == NULL || handle->smu_mgr->smumgr_funcs == NULL) return -EINVAL; if (handle->pm_en == 0) return PP_DPM_DISABLED; if (handle->hwmgr == NULL || handle->hwmgr->hwmgr_func == NULL || handle->eventmgr == NULL) return PP_DPM_DISABLED; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu7687.36%150.00%
Alex Deucher1112.64%150.00%
Total87100.00%2100.00%


static int pp_early_init(void *handle) { int ret; struct pp_instance *pp_handle = (struct pp_instance *)handle; ret = smum_early_init(pp_handle); if (ret) return ret; if ((pp_handle->pm_en == 0) || cgs_is_virtualization_enabled(pp_handle->device)) return PP_DPM_DISABLED; ret = hwmgr_early_init(pp_handle); if (ret) { pp_handle->pm_en = 0; return PP_DPM_DISABLED; } ret = eventmgr_early_init(pp_handle); if (ret) { kfree(pp_handle->hwmgr); pp_handle->hwmgr = NULL; pp_handle->pm_en = 0; return PP_DPM_DISABLED; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu6957.98%233.33%
Jammy Zhou3428.57%116.67%
Alex Deucher1310.92%233.33%
Huang Rui32.52%116.67%
Total119100.00%6100.00%


static int pp_sw_init(void *handle) { struct pp_smumgr *smumgr; int ret = 0; struct pp_instance *pp_handle = (struct pp_instance *)handle; ret = pp_check(pp_handle); if (ret == 0 || ret == PP_DPM_DISABLED) { smumgr = pp_handle->smu_mgr; if (smumgr->smumgr_funcs->smu_init == NULL) return -EINVAL; ret = smumgr->smumgr_funcs->smu_init(smumgr); pr_info("amdgpu: powerplay sw initialized\n"); } return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu6066.67%114.29%
Huang Rui1314.44%228.57%
Monk Liu1011.11%114.29%
Alex Deucher55.56%228.57%
Jammy Zhou22.22%114.29%
Total90100.00%7100.00%


static int pp_sw_fini(void *handle) { struct pp_smumgr *smumgr; int ret = 0; struct pp_instance *pp_handle = (struct pp_instance *)handle; ret = pp_check(pp_handle); if (ret == 0 || ret == PP_DPM_DISABLED) { smumgr = pp_handle->smu_mgr; if (smumgr->smumgr_funcs->smu_fini == NULL) return -EINVAL; ret = smumgr->smumgr_funcs->smu_fini(smumgr); } return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu3743.53%233.33%
Jammy Zhou2327.06%116.67%
Alex Deucher1214.12%116.67%
Huang Rui89.41%116.67%
Monk Liu55.88%116.67%
Total85100.00%6100.00%


static int pp_hw_init(void *handle) { struct pp_smumgr *smumgr; struct pp_eventmgr *eventmgr; int ret = 0; struct pp_instance *pp_handle = (struct pp_instance *)handle; ret = pp_check(pp_handle); if (ret == 0 || ret == PP_DPM_DISABLED) { smumgr = pp_handle->smu_mgr; if (smumgr->smumgr_funcs->start_smu == NULL) return -EINVAL; if(smumgr->smumgr_funcs->start_smu(smumgr)) { pr_err("smc start failed\n"); smumgr->smumgr_funcs->smu_fini(smumgr); return -EINVAL;; } if (ret == PP_DPM_DISABLED) return PP_DPM_DISABLED; } ret = hwmgr_hw_init(pp_handle); if (ret) goto err; eventmgr = pp_handle->eventmgr; if (eventmgr->pp_eventmgr_init == NULL || eventmgr->pp_eventmgr_init(eventmgr)) goto err; return 0; err: pp_handle->pm_en = 0; kfree(pp_handle->eventmgr); kfree(pp_handle->hwmgr); pp_handle->hwmgr = NULL; pp_handle->eventmgr = NULL; return PP_DPM_DISABLED; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu11458.46%342.86%
Jammy Zhou6734.36%228.57%
Alex Deucher126.15%114.29%
Huang Rui21.03%114.29%
Total195100.00%7100.00%


static int pp_hw_fini(void *handle) { struct pp_eventmgr *eventmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret == 0) { eventmgr = pp_handle->eventmgr; if (eventmgr->pp_eventmgr_fini != NULL) eventmgr->pp_eventmgr_fini(eventmgr); hwmgr_hw_fini(pp_handle); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu5167.11%250.00%
Alex Deucher1317.11%125.00%
Jammy Zhou1215.79%125.00%
Total76100.00%4100.00%


static bool pp_is_idle(void *handle) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
Alex Deucher1292.31%150.00%
Edward O'Callaghan17.69%150.00%
Total13100.00%2100.00%


static int pp_wait_for_idle(void *handle) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Alex Deucher13100.00%1100.00%
Total13100.00%1100.00%


static int pp_sw_reset(void *handle) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Alex Deucher13100.00%1100.00%
Total13100.00%1100.00%


int amd_set_clockgating_by_smu(void *handle, uint32_t msg_id) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->update_clock_gatings == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } return hwmgr->hwmgr_func->update_clock_gatings(hwmgr, &msg_id); }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu4145.05%342.86%
Eric Huang3639.56%114.29%
Alex Deucher1010.99%114.29%
Flora Cui33.30%114.29%
Huang Rui11.10%114.29%
Total91100.00%7100.00%


static int pp_set_powergating_state(void *handle, enum amd_powergating_state state) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->enable_per_cu_power_gating == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } /* Enable/disable GFX per cu powergating through SMU */ return hwmgr->hwmgr_func->enable_per_cu_power_gating(hwmgr, state == AMD_PG_STATE_GATE); }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang4042.11%120.00%
Rex Zhu3840.00%240.00%
Alex Deucher1616.84%120.00%
Huang Rui11.05%120.00%
Total95100.00%5100.00%


static int pp_suspend(void *handle) { struct pp_eventmgr *eventmgr; struct pem_event_data event_data = { {0} }; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret == PP_DPM_DISABLED) return 0; else if (ret != 0) return ret; eventmgr = pp_handle->eventmgr; pem_handle_event(eventmgr, AMD_PP_EVENT_SUSPEND, &event_data); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu6473.56%250.00%
Alex Deucher1314.94%125.00%
Huang Rui1011.49%125.00%
Total87100.00%4100.00%


static int pp_resume(void *handle) { struct pp_eventmgr *eventmgr; struct pem_event_data event_data = { {0} }; struct pp_smumgr *smumgr; int ret, ret1; struct pp_instance *pp_handle = (struct pp_instance *)handle; ret1 = pp_check(pp_handle); if (ret1 != 0 && ret1 != PP_DPM_DISABLED) return ret1; smumgr = pp_handle->smu_mgr; if (smumgr->smumgr_funcs->start_smu == NULL) return -EINVAL; ret = smumgr->smumgr_funcs->start_smu(smumgr); if (ret) { pr_err("smc start failed\n"); smumgr->smumgr_funcs->smu_fini(smumgr); return ret; } if (ret1 == PP_DPM_DISABLED) return 0; eventmgr = pp_handle->eventmgr; pem_handle_event(eventmgr, AMD_PP_EVENT_RESUME, &event_data); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu13389.26%350.00%
Alex Deucher138.72%116.67%
Huang Rui21.34%116.67%
Monk Liu10.67%116.67%
Total149100.00%6100.00%

const struct amd_ip_funcs pp_ip_funcs = { .name = "powerplay", .early_init = pp_early_init, .late_init = NULL, .sw_init = pp_sw_init, .sw_fini = pp_sw_fini, .hw_init = pp_hw_init, .hw_fini = pp_hw_fini, .suspend = pp_suspend, .resume = pp_resume, .is_idle = pp_is_idle, .wait_for_idle = pp_wait_for_idle, .soft_reset = pp_sw_reset, .set_clockgating_state = NULL, .set_powergating_state = pp_set_powergating_state, };
static int pp_dpm_load_fw(void *handle) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Alex Deucher13100.00%1100.00%
Total13100.00%1100.00%


static int pp_dpm_fw_loading_complete(void *handle) { return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Alex Deucher13100.00%1100.00%
Total13100.00%1100.00%


static int pp_dpm_force_performance_level(void *handle, enum amd_dpm_forced_level level) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->force_dpm_level == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); hwmgr->hwmgr_func->force_dpm_level(hwmgr, level); mutex_unlock(&pp_handle->pp_lock); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu9283.64%466.67%
Alex Deucher1715.45%116.67%
Huang Rui10.91%116.67%
Total110100.00%6100.00%


static enum amd_dpm_forced_level pp_dpm_get_performance_level( void *handle) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; enum amd_dpm_forced_level level; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; mutex_lock(&pp_handle->pp_lock); level = hwmgr->dpm_level; mutex_unlock(&pp_handle->pp_lock); return level; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu7285.71%480.00%
Alex Deucher1214.29%120.00%
Total84100.00%5100.00%


static int pp_dpm_get_sclk(void *handle, bool low) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->get_sclk == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->get_sclk(hwmgr, low); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu9585.59%466.67%
Alex Deucher1513.51%116.67%
Huang Rui10.90%116.67%
Total111100.00%6100.00%


static int pp_dpm_get_mclk(void *handle, bool low) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->get_mclk == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->get_mclk(hwmgr, low); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu11099.10%480.00%
Huang Rui10.90%120.00%
Total111100.00%5100.00%


static int pp_dpm_powergate_vce(void *handle, bool gate) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->powergate_vce == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->powergate_vce(hwmgr, gate); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu9585.59%466.67%
Alex Deucher1513.51%116.67%
Huang Rui10.90%116.67%
Total111100.00%6100.00%


static int pp_dpm_powergate_uvd(void *handle, bool gate) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->powergate_uvd == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->powergate_uvd(hwmgr, gate); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu9585.59%466.67%
Alex Deucher1513.51%116.67%
Huang Rui10.90%116.67%
Total111100.00%6100.00%


static enum PP_StateUILabel power_state_convert(enum amd_pm_state_type state) { switch (state) { case POWER_STATE_TYPE_BATTERY: return PP_StateUILabel_Battery; case POWER_STATE_TYPE_BALANCED: return PP_StateUILabel_Balanced; case POWER_STATE_TYPE_PERFORMANCE: return PP_StateUILabel_Performance; default: return PP_StateUILabel_None; } }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu39100.00%1100.00%
Total39100.00%1100.00%


static int pp_dpm_dispatch_tasks(void *handle, enum amd_pp_event event_id, void *input, void *output) { int ret = 0; struct pem_event_data data = { {0} }; struct pp_instance *pp_handle = (struct pp_instance *)handle; ret = pp_check(pp_handle); if (ret != 0) return ret; mutex_lock(&pp_handle->pp_lock); switch (event_id) { case AMD_PP_EVENT_DISPLAY_CONFIG_CHANGE: ret = pem_handle_event(pp_handle->eventmgr, event_id, &data); break; case AMD_PP_EVENT_ENABLE_USER_STATE: { enum amd_pm_state_type ps; if (input == NULL) { ret = -EINVAL; break; } ps = *(unsigned long *)input; data.requested_ui_label = power_state_convert(ps); ret = pem_handle_event(pp_handle->eventmgr, event_id, &data); break; } case AMD_PP_EVENT_COMPLETE_INIT: ret = pem_handle_event(pp_handle->eventmgr, event_id, &data); break; case AMD_PP_EVENT_READJUST_POWER_STATE: ret = pem_handle_event(pp_handle->eventmgr, event_id, &data); break; default: break; } mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu15576.35%555.56%
Alex Deucher2311.33%111.11%
Eric Huang188.87%111.11%
Dan Carpenter62.96%111.11%
Baoyou Xie10.49%111.11%
Total203100.00%9100.00%


static enum amd_pm_state_type pp_dpm_get_current_power_state(void *handle) { struct pp_hwmgr *hwmgr; struct pp_power_state *state; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; enum amd_pm_state_type pm_type; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->current_ps == NULL) return -EINVAL; mutex_lock(&pp_handle->pp_lock); state = hwmgr->current_ps; switch (state->classification.ui_label) { case PP_StateUILabel_Battery: pm_type = POWER_STATE_TYPE_BATTERY; break; case PP_StateUILabel_Balanced: pm_type = POWER_STATE_TYPE_BALANCED; break; case PP_StateUILabel_Performance: pm_type = POWER_STATE_TYPE_PERFORMANCE; break; default: if (state->classification.flags & PP_StateClassificationFlag_Boot) pm_type = POWER_STATE_TYPE_INTERNAL_BOOT; else pm_type = POWER_STATE_TYPE_DEFAULT; break; } mutex_unlock(&pp_handle->pp_lock); return pm_type; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu12882.05%342.86%
Eric Huang127.69%114.29%
Alex Deucher117.05%114.29%
Dan Carpenter42.56%114.29%
Baoyou Xie10.64%114.29%
Total156100.00%7100.00%


static int pp_dpm_set_fan_control_mode(void *handle, uint32_t mode) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->set_fan_control_mode == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->set_fan_control_mode(hwmgr, mode); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu11099.10%480.00%
Huang Rui10.90%120.00%
Total111100.00%5100.00%


static int pp_dpm_get_fan_control_mode(void *handle) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->get_fan_control_mode == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->get_fan_control_mode(hwmgr); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu10599.06%480.00%
Huang Rui10.94%120.00%
Total106100.00%5100.00%


static int pp_dpm_set_fan_speed_percent(void *handle, uint32_t percent) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->set_fan_speed_percent == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->set_fan_speed_percent(hwmgr, percent); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu11099.10%480.00%
Huang Rui10.90%120.00%
Total111100.00%5100.00%


static int pp_dpm_get_fan_speed_percent(void *handle, uint32_t *speed) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->get_fan_speed_percent == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->get_fan_speed_percent(hwmgr, speed); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu11199.11%480.00%
Huang Rui10.89%120.00%
Total112100.00%5100.00%


static int pp_dpm_get_fan_speed_rpm(void *handle, uint32_t *rpm) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->get_fan_speed_rpm == NULL) return -EINVAL; mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->get_fan_speed_rpm(hwmgr, rpm); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Grazvydas Ignotas5451.92%133.33%
Rex Zhu5048.08%266.67%
Total104100.00%3100.00%


static int pp_dpm_get_temperature(void *handle) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->get_temperature == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->get_temperature(hwmgr); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu10599.06%480.00%
Huang Rui10.94%120.00%
Total106100.00%5100.00%


static int pp_dpm_get_pp_num_states(void *handle, struct pp_states_info *data) { struct pp_hwmgr *hwmgr; int i; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->ps == NULL) return -EINVAL; mutex_lock(&pp_handle->pp_lock); data->nums = hwmgr->num_ps; for (i = 0; i < hwmgr->num_ps; i++) { struct pp_power_state *state = (struct pp_power_state *) ((unsigned long)hwmgr->ps + i * hwmgr->ps_size); switch (state->classification.ui_label) { case PP_StateUILabel_Battery: data->states[i] = POWER_STATE_TYPE_BATTERY; break; case PP_StateUILabel_Balanced: data->states[i] = POWER_STATE_TYPE_BALANCED; break; case PP_StateUILabel_Performance: data->states[i] = POWER_STATE_TYPE_PERFORMANCE; break; default: if (state->classification.flags & PP_StateClassificationFlag_Boot) data->states[i] = POWER_STATE_TYPE_INTERNAL_BOOT; else data->states[i] = POWER_STATE_TYPE_DEFAULT; } } mutex_unlock(&pp_handle->pp_lock); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang17879.82%133.33%
Rex Zhu4520.18%266.67%
Total223100.00%3100.00%


static int pp_dpm_get_pp_table(void *handle, char **table) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; int size = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (!hwmgr->soft_pp_table) return -EINVAL; mutex_lock(&pp_handle->pp_lock); *table = (char *)hwmgr->soft_pp_table; size = hwmgr->soft_pp_table_size; mutex_unlock(&pp_handle->pp_lock); return size; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang5650.45%250.00%
Rex Zhu5549.55%250.00%
Total111100.00%4100.00%


static int pp_dpm_set_pp_table(void *handle, const char *buf, size_t size) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; mutex_lock(&pp_handle->pp_lock); if (!hwmgr->hardcode_pp_table) { hwmgr->hardcode_pp_table = kmemdup(hwmgr->soft_pp_table, hwmgr->soft_pp_table_size, GFP_KERNEL); if (!hwmgr->hardcode_pp_table) { mutex_unlock(&pp_handle->pp_lock); return -ENOMEM; } } memcpy(hwmgr->hardcode_pp_table, buf, size); hwmgr->soft_pp_table = hwmgr->hardcode_pp_table; mutex_unlock(&pp_handle->pp_lock); ret = amd_powerplay_reset(handle); if (ret) return ret; if (hwmgr->hwmgr_func->avfs_control) { ret = hwmgr->hwmgr_func->avfs_control(hwmgr, false); if (ret) return ret; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang12565.45%342.86%
Rex Zhu6131.94%342.86%
Edward O'Callaghan52.62%114.29%
Total191100.00%7100.00%


static int pp_dpm_force_clock_level(void *handle, enum pp_clock_type type, uint32_t mask) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->force_clock_level == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); hwmgr->hwmgr_func->force_clock_level(hwmgr, type, mask); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu5749.57%350.00%
Eric Huang5749.57%233.33%
Huang Rui10.87%116.67%
Total115100.00%6100.00%


static int pp_dpm_print_clock_levels(void *handle, enum pp_clock_type type, char *buf) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->print_clock_levels == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->print_clock_levels(hwmgr, type, buf); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu5950.00%360.00%
Eric Huang5849.15%120.00%
Huang Rui10.85%120.00%
Total118100.00%5100.00%


static int pp_dpm_get_sclk_od(void *handle) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->get_sclk_od == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->get_sclk_od(hwmgr); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang5551.89%125.00%
Rex Zhu5047.17%250.00%
Huang Rui10.94%125.00%
Total106100.00%4100.00%


static int pp_dpm_set_sclk_od(void *handle, uint32_t value) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->set_sclk_od == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->set_sclk_od(hwmgr, value); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang6054.05%120.00%
Rex Zhu4944.14%240.00%
Alex Deucher10.90%120.00%
Huang Rui10.90%120.00%
Total111100.00%5100.00%


static int pp_dpm_get_mclk_od(void *handle) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->get_mclk_od == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->get_mclk_od(hwmgr); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang5450.94%125.00%
Rex Zhu5148.11%250.00%
Huang Rui10.94%125.00%
Total106100.00%4100.00%


static int pp_dpm_set_mclk_od(void *handle, uint32_t value) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->set_mclk_od == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->set_mclk_od(hwmgr, value); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang6054.05%125.00%
Rex Zhu5045.05%250.00%
Huang Rui10.90%125.00%
Total111100.00%4100.00%


static int pp_dpm_read_sensor(void *handle, int idx, void *value, int *size) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->read_sensor == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } mutex_lock(&pp_handle->pp_lock); ret = hwmgr->hwmgr_func->read_sensor(hwmgr, idx, value, size); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Tom St Denis7157.72%233.33%
Rex Zhu5040.65%233.33%
Eric Huang10.81%116.67%
Huang Rui10.81%116.67%
Total123100.00%6100.00%


static struct amd_vce_state* pp_dpm_get_vce_clock_state(void *handle, unsigned idx) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return NULL; hwmgr = pp_handle->hwmgr; if (hwmgr && idx < hwmgr->num_vce_state_tables) return &hwmgr->vce_states[idx]; return NULL; }

Contributors

PersonTokensPropCommitsCommitProp
Alex Deucher5162.96%150.00%
Rex Zhu3037.04%150.00%
Total81100.00%2100.00%


static int pp_dpm_reset_power_profile_state(void *handle, struct amd_pp_profile *request) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; if (!request || pp_check(pp_handle)) return -EINVAL; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->set_power_profile_state == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } if (request->type == AMD_PP_GFX_PROFILE) { hwmgr->gfx_power_profile = hwmgr->default_gfx_power_profile; return hwmgr->hwmgr_func->set_power_profile_state(hwmgr, &hwmgr->gfx_power_profile); } else if (request->type == AMD_PP_COMPUTE_PROFILE) { hwmgr->compute_power_profile = hwmgr->default_compute_power_profile; return hwmgr->hwmgr_func->set_power_profile_state(hwmgr, &hwmgr->compute_power_profile); } else return -EINVAL; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang146100.00%1100.00%
Total146100.00%1100.00%


static int pp_dpm_get_power_profile_state(void *handle, struct amd_pp_profile *query) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; if (!query || pp_check(pp_handle)) return -EINVAL; hwmgr = pp_handle->hwmgr; if (query->type == AMD_PP_GFX_PROFILE) memcpy(query, &hwmgr->gfx_power_profile, sizeof(struct amd_pp_profile)); else if (query->type == AMD_PP_COMPUTE_PROFILE) memcpy(query, &hwmgr->compute_power_profile, sizeof(struct amd_pp_profile)); else return -EINVAL; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang109100.00%1100.00%
Total109100.00%1100.00%


static int pp_dpm_set_power_profile_state(void *handle, struct amd_pp_profile *request) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = -1; if (!request || pp_check(pp_handle)) return -EINVAL; hwmgr = pp_handle->hwmgr; if (hwmgr->hwmgr_func->set_power_profile_state == NULL) { pr_info("%s was not implemented.\n", __func__); return 0; } if (request->min_sclk || request->min_mclk || request->activity_threshold || request->up_hyst || request->down_hyst) { if (request->type == AMD_PP_GFX_PROFILE) memcpy(&hwmgr->gfx_power_profile, request, sizeof(struct amd_pp_profile)); else if (request->type == AMD_PP_COMPUTE_PROFILE) memcpy(&hwmgr->compute_power_profile, request, sizeof(struct amd_pp_profile)); else return -EINVAL; if (request->type == hwmgr->current_power_profile) ret = hwmgr->hwmgr_func->set_power_profile_state( hwmgr, request); } else { /* set power profile if it exists */ switch (request->type) { case AMD_PP_GFX_PROFILE: ret = hwmgr->hwmgr_func->set_power_profile_state( hwmgr, &hwmgr->gfx_power_profile); break; case AMD_PP_COMPUTE_PROFILE: ret = hwmgr->hwmgr_func->set_power_profile_state( hwmgr, &hwmgr->compute_power_profile); break; default: return -EINVAL; } } if (!ret) hwmgr->current_power_profile = request->type; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang254100.00%1100.00%
Total254100.00%1100.00%


static int pp_dpm_switch_power_profile(void *handle, enum amd_pp_profile_type type) { struct pp_hwmgr *hwmgr; struct amd_pp_profile request = {0}; struct pp_instance *pp_handle = (struct pp_instance *)handle; if (pp_check(pp_handle)) return -EINVAL; hwmgr = pp_handle->hwmgr; if (hwmgr->current_power_profile != type) { request.type = type; pp_dpm_set_power_profile_state(handle, &request); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang83100.00%1100.00%
Total83100.00%1100.00%

const struct amd_powerplay_funcs pp_dpm_funcs = { .get_temperature = pp_dpm_get_temperature, .load_firmware = pp_dpm_load_fw, .wait_for_fw_loading_complete = pp_dpm_fw_loading_complete, .force_performance_level = pp_dpm_force_performance_level, .get_performance_level = pp_dpm_get_performance_level, .get_current_power_state = pp_dpm_get_current_power_state, .get_sclk = pp_dpm_get_sclk, .get_mclk = pp_dpm_get_mclk, .powergate_vce = pp_dpm_powergate_vce, .powergate_uvd = pp_dpm_powergate_uvd, .dispatch_tasks = pp_dpm_dispatch_tasks, .set_fan_control_mode = pp_dpm_set_fan_control_mode, .get_fan_control_mode = pp_dpm_get_fan_control_mode, .set_fan_speed_percent = pp_dpm_set_fan_speed_percent, .get_fan_speed_percent = pp_dpm_get_fan_speed_percent, .get_fan_speed_rpm = pp_dpm_get_fan_speed_rpm, .get_pp_num_states = pp_dpm_get_pp_num_states, .get_pp_table = pp_dpm_get_pp_table, .set_pp_table = pp_dpm_set_pp_table, .force_clock_level = pp_dpm_force_clock_level, .print_clock_levels = pp_dpm_print_clock_levels, .get_sclk_od = pp_dpm_get_sclk_od, .set_sclk_od = pp_dpm_set_sclk_od, .get_mclk_od = pp_dpm_get_mclk_od, .set_mclk_od = pp_dpm_set_mclk_od, .read_sensor = pp_dpm_read_sensor, .get_vce_clock_state = pp_dpm_get_vce_clock_state, .reset_power_profile_state = pp_dpm_reset_power_profile_state, .get_power_profile_state = pp_dpm_get_power_profile_state, .set_power_profile_state = pp_dpm_set_power_profile_state, .switch_power_profile = pp_dpm_switch_power_profile, };
int amd_powerplay_create(struct amd_pp_init *pp_init, void **handle) { struct pp_instance *instance; if (pp_init == NULL || handle == NULL) return -EINVAL; instance = kzalloc(sizeof(struct pp_instance), GFP_KERNEL); if (instance == NULL) return -ENOMEM; instance->pp_valid = PP_VALID; instance->chip_family = pp_init->chip_family; instance->chip_id = pp_init->chip_id; instance->pm_en = pp_init->pm_en; instance->feature_mask = pp_init->feature_mask; instance->device = pp_init->device; mutex_init(&instance->pp_lock); *handle = instance; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu9277.31%466.67%
Jammy Zhou2722.69%233.33%
Total119100.00%6100.00%


int amd_powerplay_destroy(void *handle) { struct pp_instance *instance = (struct pp_instance *)handle; if (instance->pm_en) { kfree(instance->eventmgr); kfree(instance->hwmgr); instance->hwmgr = NULL; instance->eventmgr = NULL; } kfree(instance->smu_mgr); instance->smu_mgr = NULL; kfree(instance); instance = NULL; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Jammy Zhou3746.25%228.57%
Rex Zhu3341.25%342.86%
Alex Deucher911.25%114.29%
Trigger Huang11.25%114.29%
Total80100.00%7100.00%


int amd_powerplay_reset(void *handle) { struct pp_instance *instance = (struct pp_instance *)handle; struct pp_eventmgr *eventmgr; struct pem_event_data event_data = { {0} }; int ret; if (cgs_is_virtualization_enabled(instance->smu_mgr->device)) return PP_DPM_DISABLED; ret = pp_check(instance); if (ret != 0) return ret; ret = pp_hw_fini(handle); if (ret) return ret; ret = hwmgr_hw_init(instance); if (ret) return PP_DPM_DISABLED; eventmgr = instance->eventmgr; if (eventmgr->pp_eventmgr_init == NULL) return PP_DPM_DISABLED; ret = eventmgr->pp_eventmgr_init(eventmgr); if (ret) return ret; return pem_handle_event(eventmgr, AMD_PP_EVENT_COMPLETE_INIT, &event_data); }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang10775.89%120.00%
Rex Zhu2819.86%240.00%
Xiangliang Yu32.13%120.00%
Trigger Huang32.13%120.00%
Total141100.00%5100.00%

/* export this function to DAL */
int amd_powerplay_display_configuration_change(void *handle, const struct amd_pp_display_configuration *display_config) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; mutex_lock(&pp_handle->pp_lock); phm_store_dal_configuration_data(hwmgr, display_config); mutex_unlock(&pp_handle->pp_lock); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu8296.47%480.00%
David Rokhvarg33.53%120.00%
Total85100.00%5100.00%


int amd_powerplay_get_display_power_level(void *handle, struct amd_pp_simple_clock_info *output) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (output == NULL) return -EINVAL; mutex_lock(&pp_handle->pp_lock); ret = phm_get_dal_power_level(hwmgr, output); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu6163.54%466.67%
Vitaly Prosyak3536.46%233.33%
Total96100.00%6100.00%


int amd_powerplay_get_current_clocks(void *handle, struct amd_pp_clock_info *clocks) { struct amd_pp_simple_clock_info simple_clocks; struct pp_clock_info hw_clocks; struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; mutex_lock(&pp_handle->pp_lock); phm_get_dal_power_level(hwmgr, &simple_clocks); if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps, PHM_PlatformCaps_PowerContainment)) ret = phm_get_clock_info(hwmgr, &hwmgr->current_ps->hardware, &hw_clocks, PHM_PerformanceLevelDesignation_PowerContainment); else ret = phm_get_clock_info(hwmgr, &hwmgr->current_ps->hardware, &hw_clocks, PHM_PerformanceLevelDesignation_Activity); if (ret != 0) { pr_info("Error in phm_get_clock_info \n"); mutex_unlock(&pp_handle->pp_lock); return -EINVAL; } clocks->min_engine_clock = hw_clocks.min_eng_clk; clocks->max_engine_clock = hw_clocks.max_eng_clk; clocks->min_memory_clock = hw_clocks.min_mem_clk; clocks->max_memory_clock = hw_clocks.max_mem_clk; clocks->min_bus_bandwidth = hw_clocks.min_bus_bandwidth; clocks->max_bus_bandwidth = hw_clocks.max_bus_bandwidth; clocks->max_engine_clock_in_sr = hw_clocks.max_eng_clk; clocks->min_engine_clock_in_sr = hw_clocks.min_eng_clk; clocks->max_clocks_state = simple_clocks.level; if (0 == phm_get_current_shallow_sleep_clocks(hwmgr, &hwmgr->current_ps->hardware, &hw_clocks)) { clocks->max_engine_clock_in_sr = hw_clocks.max_eng_clk; clocks->min_engine_clock_in_sr = hw_clocks.min_eng_clk; } mutex_unlock(&pp_handle->pp_lock); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu27698.92%480.00%
David Rokhvarg31.08%120.00%
Total279100.00%5100.00%


int amd_powerplay_get_clock_by_type(void *handle, enum amd_pp_clock_type type, struct amd_pp_clocks *clocks) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (clocks == NULL) return -EINVAL; mutex_lock(&pp_handle->pp_lock); ret = phm_get_clock_by_type(hwmgr, type, clocks); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu102100.00%4100.00%
Total102100.00%4100.00%


int amd_powerplay_get_clock_by_type_with_latency(void *handle, enum amd_pp_clock_type type, struct pp_clock_levels_with_latency *clocks) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; if (!clocks) return -EINVAL; mutex_lock(&pp_handle->pp_lock); hwmgr = ((struct pp_instance *)handle)->hwmgr; ret = phm_get_clock_by_type_with_latency(hwmgr, type, clocks); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang108100.00%1100.00%
Total108100.00%1100.00%


int amd_powerplay_get_clock_by_type_with_voltage(void *handle, enum amd_pp_clock_type type, struct pp_clock_levels_with_voltage *clocks) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; if (!clocks) return -EINVAL; hwmgr = ((struct pp_instance *)handle)->hwmgr; mutex_lock(&pp_handle->pp_lock); ret = phm_get_clock_by_type_with_voltage(hwmgr, type, clocks); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang108100.00%1100.00%
Total108100.00%1100.00%


int amd_powerplay_set_watermarks_for_clocks_ranges(void *handle, struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; if (!wm_with_clock_ranges) return -EINVAL; hwmgr = ((struct pp_instance *)handle)->hwmgr; mutex_lock(&pp_handle->pp_lock); ret = phm_set_watermarks_for_clocks_ranges(hwmgr, wm_with_clock_ranges); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang102100.00%1100.00%
Total102100.00%1100.00%


int amd_powerplay_display_clock_voltage_request(void *handle, struct pp_display_clock_request *clock) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; if (!clock) return -EINVAL; hwmgr = ((struct pp_instance *)handle)->hwmgr; mutex_lock(&pp_handle->pp_lock); ret = phm_display_clock_voltage_request(hwmgr, clock); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Eric Huang102100.00%1100.00%
Total102100.00%1100.00%


int amd_powerplay_get_display_mode_validation_clocks(void *handle, struct amd_pp_simple_clock_info *clocks) { struct pp_hwmgr *hwmgr; struct pp_instance *pp_handle = (struct pp_instance *)handle; int ret = 0; ret = pp_check(pp_handle); if (ret != 0) return ret; hwmgr = pp_handle->hwmgr; if (clocks == NULL) return -EINVAL; mutex_lock(&pp_handle->pp_lock); if (phm_cap_enabled(hwmgr->platform_descriptor.platformCaps, PHM_PlatformCaps_DynamicPatchPowerState)) ret = phm_get_max_high_clocks(hwmgr, clocks); mutex_unlock(&pp_handle->pp_lock); return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu10697.25%480.00%
David Rokhvarg32.75%120.00%
Total109100.00%5100.00%


Overall Contributors

PersonTokensPropCommitsCommitProp
Rex Zhu351954.01%1527.78%
Eric Huang199430.61%1120.37%
Alex Deucher5067.77%47.41%
Jammy Zhou2083.19%23.70%
Tom St Denis811.24%35.56%
Huang Rui600.92%59.26%
Grazvydas Ignotas590.91%11.85%
Vitaly Prosyak350.54%23.70%
Monk Liu160.25%23.70%
Dan Carpenter100.15%23.70%
David Rokhvarg90.14%11.85%
Edward O'Callaghan60.09%23.70%
Trigger Huang40.06%11.85%
Xiangliang Yu30.05%11.85%
Flora Cui30.05%11.85%
Baoyou Xie20.03%11.85%
Total6515100.00%54100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.