|
@@ -374,7 +374,7 @@ static int collect_cpu_info(int cpu)
|
|
|
}
|
|
|
|
|
|
struct apply_microcode_ctx {
|
|
|
- int err;
|
|
|
+ enum ucode_state err;
|
|
|
};
|
|
|
|
|
|
static void apply_microcode_local(void *arg)
|
|
@@ -489,31 +489,29 @@ static void __exit microcode_dev_exit(void)
|
|
|
/* fake device for request_firmware */
|
|
|
static struct platform_device *microcode_pdev;
|
|
|
|
|
|
-static int reload_for_cpu(int cpu)
|
|
|
+static enum ucode_state reload_for_cpu(int cpu)
|
|
|
{
|
|
|
struct ucode_cpu_info *uci = ucode_cpu_info + cpu;
|
|
|
enum ucode_state ustate;
|
|
|
- int err = 0;
|
|
|
|
|
|
if (!uci->valid)
|
|
|
- return err;
|
|
|
+ return UCODE_OK;
|
|
|
|
|
|
ustate = microcode_ops->request_microcode_fw(cpu, µcode_pdev->dev, true);
|
|
|
- if (ustate == UCODE_OK)
|
|
|
- apply_microcode_on_target(cpu);
|
|
|
- else
|
|
|
- if (ustate == UCODE_ERROR)
|
|
|
- err = -EINVAL;
|
|
|
- return err;
|
|
|
+ if (ustate != UCODE_OK)
|
|
|
+ return ustate;
|
|
|
+
|
|
|
+ return apply_microcode_on_target(cpu);
|
|
|
}
|
|
|
|
|
|
static ssize_t reload_store(struct device *dev,
|
|
|
struct device_attribute *attr,
|
|
|
const char *buf, size_t size)
|
|
|
{
|
|
|
+ enum ucode_state tmp_ret = UCODE_OK;
|
|
|
unsigned long val;
|
|
|
+ ssize_t ret = 0;
|
|
|
int cpu;
|
|
|
- ssize_t ret = 0, tmp_ret;
|
|
|
|
|
|
ret = kstrtoul(buf, 0, &val);
|
|
|
if (ret)
|
|
@@ -526,15 +524,18 @@ static ssize_t reload_store(struct device *dev,
|
|
|
mutex_lock(µcode_mutex);
|
|
|
for_each_online_cpu(cpu) {
|
|
|
tmp_ret = reload_for_cpu(cpu);
|
|
|
- if (tmp_ret != 0)
|
|
|
+ if (tmp_ret > UCODE_NFOUND) {
|
|
|
pr_warn("Error reloading microcode on CPU %d\n", cpu);
|
|
|
|
|
|
- /* save retval of the first encountered reload error */
|
|
|
- if (!ret)
|
|
|
- ret = tmp_ret;
|
|
|
+ /* set retval for the first encountered reload error */
|
|
|
+ if (!ret)
|
|
|
+ ret = -EINVAL;
|
|
|
+ }
|
|
|
}
|
|
|
- if (!ret)
|
|
|
+
|
|
|
+ if (!ret && tmp_ret == UCODE_UPDATED)
|
|
|
perf_check_microcode();
|
|
|
+
|
|
|
mutex_unlock(µcode_mutex);
|
|
|
put_online_cpus();
|
|
|
|