Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 47047263 authored by Rex Zhu's avatar Rex Zhu Committed by Alex Deucher
Browse files

drm/amd/powerplay: delete eventmgr related files.

parent df1e6394
Loading
Loading
Loading
Loading
+0 −11
Original line number Diff line number Diff line
#
# Makefile for the 'event manager' sub-component of powerplay.
# It provides the event management services for the driver.

EVENT_MGR = eventmgr.o eventinit.o eventmanagement.o  \
		eventactionchains.o eventsubchains.o eventtasks.o psm.o

AMD_PP_EVENT = $(addprefix $(AMD_PP_PATH)/eventmgr/,$(EVENT_MGR))

AMD_POWERPLAY_FILES += $(AMD_PP_EVENT)
+0 −291
Original line number Diff line number Diff line
/*
 * 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 "eventmgr.h"
#include "eventactionchains.h"
#include "eventsubchains.h"

static const pem_event_action * const initialize_event[] = {
	block_adjust_power_state_tasks,
	power_budget_tasks,
	system_config_tasks,
	setup_asic_tasks,
	enable_dynamic_state_management_tasks,
	get_2d_performance_state_tasks,
	set_performance_state_tasks,
	initialize_thermal_controller_tasks,
	conditionally_force_3d_performance_state_tasks,
	process_vbios_eventinfo_tasks,
	broadcast_power_policy_tasks,
	NULL
};

const struct action_chain initialize_action_chain = {
	"Initialize",
	initialize_event
};

static const pem_event_action * const uninitialize_event[] = {
	ungate_all_display_phys_tasks,
	uninitialize_display_phy_access_tasks,
	disable_gfx_voltage_island_power_gating_tasks,
	disable_gfx_clock_gating_tasks,
	uninitialize_thermal_controller_tasks,
	set_boot_state_tasks,
	adjust_power_state_tasks,
	disable_dynamic_state_management_tasks,
	disable_clock_power_gatings_tasks,
	cleanup_asic_tasks,
	prepare_for_pnp_stop_tasks,
	NULL
};

const struct action_chain uninitialize_action_chain = {
	"Uninitialize",
	uninitialize_event
};

static const pem_event_action * const power_source_change_event_pp_enabled[] = {
	set_power_source_tasks,
	set_power_saving_state_tasks,
	adjust_power_state_tasks,
	enable_disable_fps_tasks,
	set_nbmcu_state_tasks,
	broadcast_power_policy_tasks,
	NULL
};

const struct action_chain power_source_change_action_chain_pp_enabled = {
	"Power source change - PowerPlay enabled",
	power_source_change_event_pp_enabled
};

static const pem_event_action * const power_source_change_event_pp_disabled[] = {
	set_power_source_tasks,
	set_nbmcu_state_tasks,
	NULL
};

const struct action_chain power_source_changes_action_chain_pp_disabled = {
	"Power source change - PowerPlay disabled",
	power_source_change_event_pp_disabled
};

static const pem_event_action * const power_source_change_event_hardware_dc[] = {
	set_power_source_tasks,
	set_power_saving_state_tasks,
	adjust_power_state_tasks,
	enable_disable_fps_tasks,
	reset_hardware_dc_notification_tasks,
	set_nbmcu_state_tasks,
	broadcast_power_policy_tasks,
	NULL
};

const struct action_chain power_source_change_action_chain_hardware_dc = {
	"Power source change - with Hardware DC switching",
	power_source_change_event_hardware_dc
};

static const pem_event_action * const suspend_event[] = {
	reset_display_phy_access_tasks,
	unregister_interrupt_tasks,
	disable_gfx_voltage_island_power_gating_tasks,
	disable_gfx_clock_gating_tasks,
	notify_smu_suspend_tasks,
	disable_smc_firmware_ctf_tasks,
	set_boot_state_tasks,
	adjust_power_state_tasks,
	disable_fps_tasks,
	vari_bright_suspend_tasks,
	reset_fan_speed_to_default_tasks,
	power_down_asic_tasks,
	disable_stutter_mode_tasks,
	set_connected_standby_tasks,
	block_hw_access_tasks,
	NULL
};

const struct action_chain suspend_action_chain = {
	"Suspend",
	suspend_event
};

static const pem_event_action * const resume_event[] = {
	unblock_hw_access_tasks,
	resume_connected_standby_tasks,
	notify_smu_resume_tasks,
	reset_display_configCounter_tasks,
	update_dal_configuration_tasks,
	vari_bright_resume_tasks,
	setup_asic_tasks,
	enable_stutter_mode_tasks, /*must do this in boot state and before SMC is started */
	enable_dynamic_state_management_tasks,
	enable_disable_bapm_tasks,
	initialize_thermal_controller_tasks,
	get_2d_performance_state_tasks,
	set_performance_state_tasks,
	adjust_power_state_tasks,
	enable_disable_fps_tasks,
	notify_hw_power_source_tasks,
	process_vbios_event_info_tasks,
	enable_gfx_clock_gating_tasks,
	enable_gfx_voltage_island_power_gating_tasks,
	reset_clock_gating_tasks,
	notify_smu_vpu_recovery_end_tasks,
	disable_vpu_cap_tasks,
	execute_escape_sequence_tasks,
	NULL
};


const struct action_chain resume_action_chain = {
	"resume",
	resume_event
};

static const pem_event_action * const complete_init_event[] = {
	unblock_adjust_power_state_tasks,
	adjust_power_state_tasks,
	enable_gfx_clock_gating_tasks,
	enable_gfx_voltage_island_power_gating_tasks,
	notify_power_state_change_tasks,
	NULL
};

const struct action_chain complete_init_action_chain = {
	"complete init",
	complete_init_event
};

static const pem_event_action * const enable_gfx_clock_gating_event[] = {
	enable_gfx_clock_gating_tasks,
	NULL
};

const struct action_chain enable_gfx_clock_gating_action_chain = {
	"enable gfx clock gate",
	enable_gfx_clock_gating_event
};

static const pem_event_action * const disable_gfx_clock_gating_event[] = {
	disable_gfx_clock_gating_tasks,
	NULL
};

const struct action_chain disable_gfx_clock_gating_action_chain = {
	"disable gfx clock gate",
	disable_gfx_clock_gating_event
};

static const pem_event_action * const enable_cgpg_event[] = {
	enable_cgpg_tasks,
	NULL
};

const struct action_chain enable_cgpg_action_chain = {
	"eable cg pg",
	enable_cgpg_event
};

static const pem_event_action * const disable_cgpg_event[] = {
	disable_cgpg_tasks,
	NULL
};

const struct action_chain disable_cgpg_action_chain = {
	"disable cg pg",
	disable_cgpg_event
};


/* Enable user _2d performance and activate */

static const pem_event_action * const enable_user_state_event[] = {
	create_new_user_performance_state_tasks,
	adjust_power_state_tasks,
	NULL
};

const struct action_chain enable_user_state_action_chain = {
	"Enable user state",
	enable_user_state_event
};

static const pem_event_action * const enable_user_2d_performance_event[] = {
	enable_user_2d_performance_tasks,
	add_user_2d_performance_state_tasks,
	set_performance_state_tasks,
	adjust_power_state_tasks,
	delete_user_2d_performance_state_tasks,
	NULL
};

const struct action_chain enable_user_2d_performance_action_chain = {
	"enable_user_2d_performance_event_activate",
	enable_user_2d_performance_event
};


static const pem_event_action * const disable_user_2d_performance_event[] = {
	disable_user_2d_performance_tasks,
	delete_user_2d_performance_state_tasks,
	NULL
};

const struct action_chain disable_user_2d_performance_action_chain = {
	"disable_user_2d_performance_event",
	disable_user_2d_performance_event
};


static const pem_event_action * const display_config_change_event[] = {
	/* countDisplayConfigurationChangeEventTasks, */
	unblock_adjust_power_state_tasks,
	set_cpu_power_state,
	notify_hw_power_source_tasks,
	get_2d_performance_state_tasks,
	set_performance_state_tasks,
	/* updateDALConfigurationTasks,
	variBrightDisplayConfigurationChangeTasks, */
	adjust_power_state_tasks,
	/*enableDisableFPSTasks,
	setNBMCUStateTasks,
	notifyPCIEDeviceReadyTasks,*/
	NULL
};

const struct action_chain display_config_change_action_chain = {
	"Display configuration change",
	display_config_change_event
};

static const pem_event_action * const readjust_power_state_event[] = {
	adjust_power_state_tasks,
	NULL
};

const struct action_chain readjust_power_state_action_chain = {
	"re-adjust power state",
	readjust_power_state_event
};
+0 −62
Original line number Diff line number Diff line
/*
 * 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.
 *
 */
#ifndef _EVENT_ACTION_CHAINS_H_
#define _EVENT_ACTION_CHAINS_H_
#include "eventmgr.h"

extern const struct action_chain initialize_action_chain;

extern const struct action_chain uninitialize_action_chain;

extern const struct action_chain power_source_change_action_chain_pp_enabled;

extern const struct action_chain power_source_changes_action_chain_pp_disabled;

extern const struct action_chain power_source_change_action_chain_hardware_dc;

extern const struct action_chain suspend_action_chain;

extern const struct action_chain resume_action_chain;

extern const struct action_chain complete_init_action_chain;

extern const struct action_chain enable_gfx_clock_gating_action_chain;

extern const struct action_chain disable_gfx_clock_gating_action_chain;

extern const struct action_chain enable_cgpg_action_chain;

extern const struct action_chain disable_cgpg_action_chain;

extern const struct action_chain enable_user_2d_performance_action_chain;

extern const struct action_chain disable_user_2d_performance_action_chain;

extern const struct action_chain enable_user_state_action_chain;

extern const struct action_chain readjust_power_state_action_chain;

extern const struct action_chain display_config_change_action_chain;

#endif /*_EVENT_ACTION_CHAINS_H_*/
+0 −195
Original line number Diff line number Diff line
/*
 * 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 "eventmgr.h"
#include "eventinit.h"
#include "ppinterrupt.h"
#include "hardwaremanager.h"

void pem_init_feature_info(struct pp_eventmgr *eventmgr)
{

	/* PowerPlay info */
	eventmgr->ui_state_info[PP_PowerSource_AC].default_ui_lable =
					    PP_StateUILabel_Performance;

	eventmgr->ui_state_info[PP_PowerSource_AC].current_ui_label =
					    PP_StateUILabel_Performance;

	eventmgr->ui_state_info[PP_PowerSource_DC].default_ui_lable =
						  PP_StateUILabel_Battery;

	eventmgr->ui_state_info[PP_PowerSource_DC].current_ui_label =
						  PP_StateUILabel_Battery;

	if (phm_cap_enabled(eventmgr->platform_descriptor->platformCaps, PHM_PlatformCaps_PowerPlaySupport)) {
		eventmgr->features[PP_Feature_PowerPlay].supported = true;
		eventmgr->features[PP_Feature_PowerPlay].version = PEM_CURRENT_POWERPLAY_FEATURE_VERSION;
		eventmgr->features[PP_Feature_PowerPlay].enabled_default = true;
		eventmgr->features[PP_Feature_PowerPlay].enabled = true;
	} else {
		eventmgr->features[PP_Feature_PowerPlay].supported = false;
		eventmgr->features[PP_Feature_PowerPlay].enabled = false;
		eventmgr->features[PP_Feature_PowerPlay].enabled_default = false;
	}

	eventmgr->features[PP_Feature_Force3DClock].supported = true;
	eventmgr->features[PP_Feature_Force3DClock].enabled = false;
	eventmgr->features[PP_Feature_Force3DClock].enabled_default = false;
	eventmgr->features[PP_Feature_Force3DClock].version = 1;

	/* over drive*/
	eventmgr->features[PP_Feature_User2DPerformance].version = 4;
	eventmgr->features[PP_Feature_User3DPerformance].version = 4;
	eventmgr->features[PP_Feature_OverdriveTest].version = 4;

	eventmgr->features[PP_Feature_OverDrive].version = 4;
	eventmgr->features[PP_Feature_OverDrive].enabled = false;
	eventmgr->features[PP_Feature_OverDrive].enabled_default = false;

	eventmgr->features[PP_Feature_User2DPerformance].supported = false;
	eventmgr->features[PP_Feature_User2DPerformance].enabled = false;
	eventmgr->features[PP_Feature_User2DPerformance].enabled_default = false;

	eventmgr->features[PP_Feature_User3DPerformance].supported = false;
	eventmgr->features[PP_Feature_User3DPerformance].enabled = false;
	eventmgr->features[PP_Feature_User3DPerformance].enabled_default = false;

	eventmgr->features[PP_Feature_OverdriveTest].supported = false;
	eventmgr->features[PP_Feature_OverdriveTest].enabled = false;
	eventmgr->features[PP_Feature_OverdriveTest].enabled_default = false;

	eventmgr->features[PP_Feature_OverDrive].supported = false;

	eventmgr->features[PP_Feature_PowerBudgetWaiver].enabled_default = false;
	eventmgr->features[PP_Feature_PowerBudgetWaiver].version = 1;
	eventmgr->features[PP_Feature_PowerBudgetWaiver].supported = false;
	eventmgr->features[PP_Feature_PowerBudgetWaiver].enabled = false;

	/* Multi UVD States support */
	eventmgr->features[PP_Feature_MultiUVDState].supported = false;
	eventmgr->features[PP_Feature_MultiUVDState].enabled = false;
	eventmgr->features[PP_Feature_MultiUVDState].enabled_default = false;

	/* Dynamic UVD States support */
	eventmgr->features[PP_Feature_DynamicUVDState].supported = false;
	eventmgr->features[PP_Feature_DynamicUVDState].enabled = false;
	eventmgr->features[PP_Feature_DynamicUVDState].enabled_default = false;

	/* VCE DPM support */
	eventmgr->features[PP_Feature_VCEDPM].supported = false;
	eventmgr->features[PP_Feature_VCEDPM].enabled = false;
	eventmgr->features[PP_Feature_VCEDPM].enabled_default = false;

	/* ACP PowerGating support */
	eventmgr->features[PP_Feature_ACP_POWERGATING].supported = false;
	eventmgr->features[PP_Feature_ACP_POWERGATING].enabled = false;
	eventmgr->features[PP_Feature_ACP_POWERGATING].enabled_default = false;

	/* PPM support */
	eventmgr->features[PP_Feature_PPM].version = 1;
	eventmgr->features[PP_Feature_PPM].supported = false;
	eventmgr->features[PP_Feature_PPM].enabled = false;

	/* FFC support (enables fan and temp settings, Gemini needs temp settings) */
	if (phm_cap_enabled(eventmgr->platform_descriptor->platformCaps, PHM_PlatformCaps_ODFuzzyFanControlSupport) ||
	    phm_cap_enabled(eventmgr->platform_descriptor->platformCaps, PHM_PlatformCaps_GeminiRegulatorFanControlSupport)) {
		eventmgr->features[PP_Feature_FFC].version = 1;
		eventmgr->features[PP_Feature_FFC].supported = true;
		eventmgr->features[PP_Feature_FFC].enabled = true;
		eventmgr->features[PP_Feature_FFC].enabled_default = true;
	} else {
		eventmgr->features[PP_Feature_FFC].supported = false;
		eventmgr->features[PP_Feature_FFC].enabled = false;
		eventmgr->features[PP_Feature_FFC].enabled_default = false;
	}

	eventmgr->features[PP_Feature_VariBright].supported = false;
	eventmgr->features[PP_Feature_VariBright].enabled = false;
	eventmgr->features[PP_Feature_VariBright].enabled_default = false;

	eventmgr->features[PP_Feature_BACO].supported = false;
	eventmgr->features[PP_Feature_BACO].supported = false;
	eventmgr->features[PP_Feature_BACO].enabled_default = false;

	/* PowerDown feature support */
	eventmgr->features[PP_Feature_PowerDown].supported = false;
	eventmgr->features[PP_Feature_PowerDown].enabled = false;
	eventmgr->features[PP_Feature_PowerDown].enabled_default = false;

	eventmgr->features[PP_Feature_FPS].version = 1;
	eventmgr->features[PP_Feature_FPS].supported = false;
	eventmgr->features[PP_Feature_FPS].enabled_default = false;
	eventmgr->features[PP_Feature_FPS].enabled = false;

	eventmgr->features[PP_Feature_ViPG].version = 1;
	eventmgr->features[PP_Feature_ViPG].supported = false;
	eventmgr->features[PP_Feature_ViPG].enabled_default = false;
	eventmgr->features[PP_Feature_ViPG].enabled = false;
}

static int thermal_interrupt_callback(void *private_data,
				      unsigned src_id, const uint32_t *iv_entry)
{
	/* TO DO hanle PEM_Event_ThermalNotification (struct pp_eventmgr *)private_data*/
	pr_info("current thermal is out of range \n");
	return 0;
}

int pem_register_interrupts(struct pp_eventmgr *eventmgr)
{
	int result = 0;
	struct pp_interrupt_registration_info info;

	info.call_back = thermal_interrupt_callback;
	info.context = eventmgr;

	result = phm_register_thermal_interrupt(eventmgr->hwmgr, &info);

	/* TODO:
	 * 2. Register CTF event interrupt
	 * 3. Register for vbios events interrupt
	 * 4. Register External Throttle Interrupt
	 * 5. Register Smc To Host Interrupt
	 * */
	return result;
}


int pem_unregister_interrupts(struct pp_eventmgr *eventmgr)
{
	return 0;
}


void pem_uninit_featureInfo(struct pp_eventmgr *eventmgr)
{
	eventmgr->features[PP_Feature_MultiUVDState].supported = false;
	eventmgr->features[PP_Feature_VariBright].supported = false;
	eventmgr->features[PP_Feature_PowerBudgetWaiver].supported = false;
	eventmgr->features[PP_Feature_OverDrive].supported = false;
	eventmgr->features[PP_Feature_OverdriveTest].supported = false;
	eventmgr->features[PP_Feature_User3DPerformance].supported = false;
	eventmgr->features[PP_Feature_User2DPerformance].supported = false;
	eventmgr->features[PP_Feature_PowerPlay].supported = false;
	eventmgr->features[PP_Feature_Force3DClock].supported = false;
}
+0 −34
Original line number Diff line number Diff line
/*
 * 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.
 *
 */

#ifndef _EVENTINIT_H_
#define _EVENTINIT_H_

#define PEM_CURRENT_POWERPLAY_FEATURE_VERSION 4

void pem_init_feature_info(struct pp_eventmgr *eventmgr);
void pem_uninit_featureInfo(struct pp_eventmgr *eventmgr);
int pem_register_interrupts(struct pp_eventmgr *eventmgr);
int pem_unregister_interrupts(struct pp_eventmgr *eventmgr);

#endif /* _EVENTINIT_H_ */
Loading