hwmon: (amd_energy) Move label out of accumulation structure
authorAkshay Gupta <Akshay.Gupta@amd.com>
Tue, 29 Sep 2020 10:53:19 +0000 (16:23 +0530)
committerGuenter Roeck <linux@roeck-us.net>
Wed, 30 Sep 2020 05:06:34 +0000 (22:06 -0700)
At present, core & socket labels are defined in struct sensor_accumulator
This patch moves it to the amd_energy_data structure, which will
help in calling memset on struct sensor_accumulator to optimize the code.

Signed-off-by: Akshay Gupta <Akshay.Gupta@amd.com>
Link: https://lore.kernel.org/r/20200929105322.8919-2-nchatrad@amd.com
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
drivers/hwmon/amd_energy.c

index 2960374..9580a16 100644 (file)
@@ -35,7 +35,6 @@
 struct sensor_accumulator {
        u64 energy_ctr;
        u64 prev_value;
-       char label[10];
 };
 
 struct amd_energy_data {
@@ -52,6 +51,7 @@ struct amd_energy_data {
        int nr_cpus;
        int nr_socks;
        int core_id;
+       char (*label)[10];
 };
 
 static int amd_energy_read_labels(struct device *dev,
@@ -61,7 +61,7 @@ static int amd_energy_read_labels(struct device *dev,
 {
        struct amd_energy_data *data = dev_get_drvdata(dev);
 
-       *str = data->accums[channel].label;
+       *str = data->label[channel];
        return 0;
 }
 
@@ -253,6 +253,7 @@ static int amd_create_sensor(struct device *dev,
        struct sensor_accumulator *accums;
        int i, num_siblings, cpus, sockets;
        u32 *s_config;
+       char (*label_l)[10];
 
        /* Identify the number of siblings per core */
        num_siblings = ((cpuid_ebx(0x8000001e) >> 8) & 0xff) + 1;
@@ -276,21 +277,25 @@ static int amd_create_sensor(struct device *dev,
        if (!accums)
                return -ENOMEM;
 
+       label_l = devm_kcalloc(dev, cpus + sockets,
+                              sizeof(*label_l), GFP_KERNEL);
+       if (!label_l)
+               return -ENOMEM;
+
        info->type = type;
        info->config = s_config;
 
        data->nr_cpus = cpus;
        data->nr_socks = sockets;
        data->accums = accums;
+       data->label = label_l;
 
        for (i = 0; i < cpus + sockets; i++) {
                s_config[i] = config;
                if (i < cpus)
-                       scnprintf(accums[i].label, 10,
-                                 "Ecore%03u", i);
+                       scnprintf(label_l[i], 10, "Ecore%03u", i);
                else
-                       scnprintf(accums[i].label, 10,
-                                 "Esocket%u", (i - cpus));
+                       scnprintf(label_l[i], 10, "Esocket%u", (i - cpus));
        }
 
        return 0;