diff options
Diffstat (limited to 'drivers/platform/x86/intel/telemetry/pltdrv.c')
| -rw-r--r-- | drivers/platform/x86/intel/telemetry/pltdrv.c | 231 | 
1 files changed, 0 insertions, 231 deletions
| diff --git a/drivers/platform/x86/intel/telemetry/pltdrv.c b/drivers/platform/x86/intel/telemetry/pltdrv.c index 9a499efa1e4d..f23c170a55dc 100644 --- a/drivers/platform/x86/intel/telemetry/pltdrv.c +++ b/drivers/platform/x86/intel/telemetry/pltdrv.c @@ -639,231 +639,6 @@ static int telemetry_setup(struct platform_device *pdev)  	return 0;  } -static int telemetry_plt_update_events(struct telemetry_evtconfig pss_evtconfig, -				struct telemetry_evtconfig ioss_evtconfig) -{ -	int ret; - -	if ((pss_evtconfig.num_evts > 0) && -	    (TELEM_SAMPLE_PERIOD_INVALID(pss_evtconfig.period))) { -		pr_err("PSS Sampling Period Out of Range\n"); -		return -EINVAL; -	} - -	if ((ioss_evtconfig.num_evts > 0) && -	    (TELEM_SAMPLE_PERIOD_INVALID(ioss_evtconfig.period))) { -		pr_err("IOSS Sampling Period Out of Range\n"); -		return -EINVAL; -	} - -	ret = telemetry_setup_evtconfig(pss_evtconfig, ioss_evtconfig, -					TELEM_UPDATE); -	if (ret) -		pr_err("TELEMETRY Config Failed\n"); - -	return ret; -} - - -static int telemetry_plt_set_sampling_period(u8 pss_period, u8 ioss_period) -{ -	u32 telem_ctrl = 0; -	int ret = 0; - -	mutex_lock(&(telm_conf->telem_lock)); -	if (ioss_period) { -		struct intel_scu_ipc_dev *scu = telm_conf->scu; - -		if (TELEM_SAMPLE_PERIOD_INVALID(ioss_period)) { -			pr_err("IOSS Sampling Period Out of Range\n"); -			ret = -EINVAL; -			goto out; -		} - -		/* Get telemetry EVENT CTL */ -		ret = intel_scu_ipc_dev_command(scu, IOSS_TELEM, -					    IOSS_TELEM_EVENT_CTL_READ, NULL, 0, -					    &telem_ctrl, sizeof(telem_ctrl)); -		if (ret) { -			pr_err("IOSS TELEM_CTRL Read Failed\n"); -			goto out; -		} - -		/* Disable Telemetry */ -		TELEM_DISABLE(telem_ctrl); - -		ret = intel_scu_ipc_dev_command(scu, IOSS_TELEM, -						IOSS_TELEM_EVENT_CTL_WRITE, -						&telem_ctrl, sizeof(telem_ctrl), -						NULL, 0); -		if (ret) { -			pr_err("IOSS TELEM_CTRL Event Disable Write Failed\n"); -			goto out; -		} - -		/* Enable Periodic Telemetry Events and enable SRAM trace */ -		TELEM_CLEAR_SAMPLE_PERIOD(telem_ctrl); -		TELEM_ENABLE_SRAM_EVT_TRACE(telem_ctrl); -		TELEM_ENABLE_PERIODIC(telem_ctrl); -		telem_ctrl |= ioss_period; - -		ret = intel_scu_ipc_dev_command(scu, IOSS_TELEM, -						IOSS_TELEM_EVENT_CTL_WRITE, -						&telem_ctrl, sizeof(telem_ctrl), -						NULL, 0); -		if (ret) { -			pr_err("IOSS TELEM_CTRL Event Enable Write Failed\n"); -			goto out; -		} -		telm_conf->ioss_config.curr_period = ioss_period; -	} - -	if (pss_period) { -		if (TELEM_SAMPLE_PERIOD_INVALID(pss_period)) { -			pr_err("PSS Sampling Period Out of Range\n"); -			ret = -EINVAL; -			goto out; -		} - -		/* Get telemetry EVENT CTL */ -		ret = intel_punit_ipc_command( -				IPC_PUNIT_BIOS_READ_TELE_EVENT_CTRL, -				0, 0, NULL, &telem_ctrl); -		if (ret) { -			pr_err("PSS TELEM_CTRL Read Failed\n"); -			goto out; -		} - -		/* Disable Telemetry */ -		TELEM_DISABLE(telem_ctrl); -		ret = intel_punit_ipc_command( -				IPC_PUNIT_BIOS_WRITE_TELE_EVENT_CTRL, -				0, 0, &telem_ctrl, NULL); -		if (ret) { -			pr_err("PSS TELEM_CTRL Event Disable Write Failed\n"); -			goto out; -		} - -		/* Enable Periodic Telemetry Events and enable SRAM trace */ -		TELEM_CLEAR_SAMPLE_PERIOD(telem_ctrl); -		TELEM_ENABLE_SRAM_EVT_TRACE(telem_ctrl); -		TELEM_ENABLE_PERIODIC(telem_ctrl); -		telem_ctrl |= pss_period; - -		ret = intel_punit_ipc_command( -				IPC_PUNIT_BIOS_WRITE_TELE_EVENT_CTRL, -				0, 0, &telem_ctrl, NULL); -		if (ret) { -			pr_err("PSS TELEM_CTRL Event Enable Write Failed\n"); -			goto out; -		} -		telm_conf->pss_config.curr_period = pss_period; -	} - -out: -	mutex_unlock(&(telm_conf->telem_lock)); -	return ret; -} - - -static int telemetry_plt_get_sampling_period(u8 *pss_min_period, -					     u8 *pss_max_period, -					     u8 *ioss_min_period, -					     u8 *ioss_max_period) -{ -	*pss_min_period = telm_conf->pss_config.min_period; -	*pss_max_period = telm_conf->pss_config.max_period; -	*ioss_min_period = telm_conf->ioss_config.min_period; -	*ioss_max_period = telm_conf->ioss_config.max_period; - -	return 0; -} - - -static int telemetry_plt_reset_events(void) -{ -	struct telemetry_evtconfig pss_evtconfig, ioss_evtconfig; -	int ret; - -	pss_evtconfig.evtmap = NULL; -	pss_evtconfig.num_evts = TELEM_MAX_OS_ALLOCATED_EVENTS; -	pss_evtconfig.period = TELEM_SAMPLING_DEFAULT_PERIOD; - -	ioss_evtconfig.evtmap = NULL; -	ioss_evtconfig.num_evts = TELEM_MAX_OS_ALLOCATED_EVENTS; -	ioss_evtconfig.period = TELEM_SAMPLING_DEFAULT_PERIOD; - -	ret = telemetry_setup_evtconfig(pss_evtconfig, ioss_evtconfig, -					TELEM_RESET); -	if (ret) -		pr_err("TELEMETRY Reset Failed\n"); - -	return ret; -} - - -static int telemetry_plt_get_eventconfig(struct telemetry_evtconfig *pss_config, -					struct telemetry_evtconfig *ioss_config, -					int pss_len, int ioss_len) -{ -	u32 *pss_evtmap, *ioss_evtmap; -	u32 index; - -	pss_evtmap = pss_config->evtmap; -	ioss_evtmap = ioss_config->evtmap; - -	mutex_lock(&(telm_conf->telem_lock)); -	pss_config->num_evts = telm_conf->pss_config.ssram_evts_used; -	ioss_config->num_evts = telm_conf->ioss_config.ssram_evts_used; - -	pss_config->period = telm_conf->pss_config.curr_period; -	ioss_config->period = telm_conf->ioss_config.curr_period; - -	if ((pss_len < telm_conf->pss_config.ssram_evts_used) || -	    (ioss_len < telm_conf->ioss_config.ssram_evts_used)) { -		mutex_unlock(&(telm_conf->telem_lock)); -		return -EINVAL; -	} - -	for (index = 0; index < telm_conf->pss_config.ssram_evts_used; -	     index++) { -		pss_evtmap[index] = -		telm_conf->pss_config.telem_evts[index].evt_id; -	} - -	for (index = 0; index < telm_conf->ioss_config.ssram_evts_used; -	     index++) { -		ioss_evtmap[index] = -		telm_conf->ioss_config.telem_evts[index].evt_id; -	} - -	mutex_unlock(&(telm_conf->telem_lock)); -	return 0; -} - - -static int telemetry_plt_add_events(u8 num_pss_evts, u8 num_ioss_evts, -				    u32 *pss_evtmap, u32 *ioss_evtmap) -{ -	struct telemetry_evtconfig pss_evtconfig, ioss_evtconfig; -	int ret; - -	pss_evtconfig.evtmap = pss_evtmap; -	pss_evtconfig.num_evts = num_pss_evts; -	pss_evtconfig.period = telm_conf->pss_config.curr_period; - -	ioss_evtconfig.evtmap = ioss_evtmap; -	ioss_evtconfig.num_evts = num_ioss_evts; -	ioss_evtconfig.period = telm_conf->ioss_config.curr_period; - -	ret = telemetry_setup_evtconfig(pss_evtconfig, ioss_evtconfig, -					TELEM_ADD); -	if (ret) -		pr_err("TELEMETRY ADD Failed\n"); - -	return ret; -} -  static int telem_evtlog_read(enum telemetry_unit telem_unit,  			     struct telem_ssram_region *ssram_region, u8 len)  { @@ -1093,14 +868,8 @@ out:  static const struct telemetry_core_ops telm_pltops = {  	.get_trace_verbosity = telemetry_plt_get_trace_verbosity,  	.set_trace_verbosity = telemetry_plt_set_trace_verbosity, -	.set_sampling_period = telemetry_plt_set_sampling_period, -	.get_sampling_period = telemetry_plt_get_sampling_period,  	.raw_read_eventlog = telemetry_plt_raw_read_eventlog, -	.get_eventconfig = telemetry_plt_get_eventconfig, -	.update_events = telemetry_plt_update_events,  	.read_eventlog = telemetry_plt_read_eventlog, -	.reset_events = telemetry_plt_reset_events, -	.add_events = telemetry_plt_add_events,  };  static int telemetry_pltdrv_probe(struct platform_device *pdev) | 
