thermal: intel: hfi: Refactor enabling code into helper functions
In preparation for the addition of a suspend notifier, wrap the logic to enable HFI and program its memory buffer into helper functions. Both the CPU hotplug callback and the suspend notifier will use them. This refactoring does not introduce functional changes. Signed-off-by: Ricardo Neri <ricardo.neri-calderon@linux.intel.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
parent
d654362d53
commit
8a8b6bb93c
@ -347,6 +347,26 @@ static void init_hfi_instance(struct hfi_instance *hfi_instance)
|
||||
hfi_instance->data = hfi_instance->hdr + hfi_features.hdr_size;
|
||||
}
|
||||
|
||||
/* Caller must hold hfi_instance_lock. */
|
||||
static void hfi_enable(void)
|
||||
{
|
||||
u64 msr_val;
|
||||
|
||||
rdmsrl(MSR_IA32_HW_FEEDBACK_CONFIG, msr_val);
|
||||
msr_val |= HW_FEEDBACK_CONFIG_HFI_ENABLE_BIT;
|
||||
wrmsrl(MSR_IA32_HW_FEEDBACK_CONFIG, msr_val);
|
||||
}
|
||||
|
||||
static void hfi_set_hw_table(struct hfi_instance *hfi_instance)
|
||||
{
|
||||
phys_addr_t hw_table_pa;
|
||||
u64 msr_val;
|
||||
|
||||
hw_table_pa = virt_to_phys(hfi_instance->hw_table);
|
||||
msr_val = hw_table_pa | HW_FEEDBACK_PTR_VALID_BIT;
|
||||
wrmsrl(MSR_IA32_HW_FEEDBACK_PTR, msr_val);
|
||||
}
|
||||
|
||||
/**
|
||||
* intel_hfi_online() - Enable HFI on @cpu
|
||||
* @cpu: CPU in which the HFI will be enabled
|
||||
@ -364,8 +384,6 @@ void intel_hfi_online(unsigned int cpu)
|
||||
{
|
||||
struct hfi_instance *hfi_instance;
|
||||
struct hfi_cpu_info *info;
|
||||
phys_addr_t hw_table_pa;
|
||||
u64 msr_val;
|
||||
u16 die_id;
|
||||
|
||||
/* Nothing to do if hfi_instances are missing. */
|
||||
@ -409,8 +427,6 @@ void intel_hfi_online(unsigned int cpu)
|
||||
if (!hfi_instance->hw_table)
|
||||
goto unlock;
|
||||
|
||||
hw_table_pa = virt_to_phys(hfi_instance->hw_table);
|
||||
|
||||
/*
|
||||
* Allocate memory to keep a local copy of the table that
|
||||
* hardware generates.
|
||||
@ -420,16 +436,6 @@ void intel_hfi_online(unsigned int cpu)
|
||||
if (!hfi_instance->local_table)
|
||||
goto free_hw_table;
|
||||
|
||||
/*
|
||||
* Program the address of the feedback table of this die/package. On
|
||||
* some processors, hardware remembers the old address of the HFI table
|
||||
* even after having been reprogrammed and re-enabled. Thus, do not free
|
||||
* the pages allocated for the table or reprogram the hardware with a
|
||||
* new base address. Namely, program the hardware only once.
|
||||
*/
|
||||
msr_val = hw_table_pa | HW_FEEDBACK_PTR_VALID_BIT;
|
||||
wrmsrl(MSR_IA32_HW_FEEDBACK_PTR, msr_val);
|
||||
|
||||
init_hfi_instance(hfi_instance);
|
||||
|
||||
INIT_DELAYED_WORK(&hfi_instance->update_work, hfi_update_work_fn);
|
||||
@ -438,13 +444,8 @@ void intel_hfi_online(unsigned int cpu)
|
||||
|
||||
cpumask_set_cpu(cpu, hfi_instance->cpus);
|
||||
|
||||
/*
|
||||
* Enable the hardware feedback interface and never disable it. See
|
||||
* comment on programming the address of the table.
|
||||
*/
|
||||
rdmsrl(MSR_IA32_HW_FEEDBACK_CONFIG, msr_val);
|
||||
msr_val |= HW_FEEDBACK_CONFIG_HFI_ENABLE_BIT;
|
||||
wrmsrl(MSR_IA32_HW_FEEDBACK_CONFIG, msr_val);
|
||||
hfi_set_hw_table(hfi_instance);
|
||||
hfi_enable();
|
||||
|
||||
unlock:
|
||||
mutex_unlock(&hfi_instance_lock);
|
||||
|
Loading…
Reference in New Issue
Block a user