Commit bb4bbbec authored by William Breathitt Gray's avatar William Breathitt Gray Committed by Greg Kroah-Hartman

counter: Consolidate Counter extension sysfs attribute creation

Counter extensions are handled for the Device, Counts, and Signals. The
code loops through each Counter extension and creates the expected sysfs
attributes. This patch consolidates that code into functions to reduce
redundancy and make the intention of the code clearer.

Link: https://lore.kernel.org/r/6f2121cf52073028c119dbf981a8b72f3eb625d2.1664204990.git.william.gray@linaro.org/Signed-off-by: default avatarWilliam Breathitt Gray <william.gray@linaro.org>
Link: https://lore.kernel.org/r/0469c3ae3fbccbca908993c78d94f221761a6a3a.1664318353.git.william.gray@linaro.orgSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 45d29185
...@@ -592,6 +592,46 @@ static int counter_comp_id_attr_create(struct device *const dev, ...@@ -592,6 +592,46 @@ static int counter_comp_id_attr_create(struct device *const dev,
return 0; return 0;
} }
static int counter_ext_attrs_create(struct device *const dev,
struct counter_attribute_group *const group,
const struct counter_comp *const ext,
const enum counter_scope scope,
void *const parent, const size_t id)
{
int err;
/* Create main extension attribute */
err = counter_attr_create(dev, group, ext, scope, parent);
if (err < 0)
return err;
/* Create extension id attribute */
return counter_comp_id_attr_create(dev, group, ext->name, id);
}
static int counter_sysfs_exts_add(struct device *const dev,
struct counter_attribute_group *const group,
const struct counter_comp *const exts,
const size_t num_ext,
const enum counter_scope scope,
void *const parent)
{
size_t i;
const struct counter_comp *ext;
int err;
/* Create attributes for each extension */
for (i = 0; i < num_ext; i++) {
ext = &exts[i];
err = counter_ext_attrs_create(dev, group, ext, scope, parent,
i);
if (err < 0)
return err;
}
return 0;
}
static struct counter_comp counter_signal_comp = { static struct counter_comp counter_signal_comp = {
.type = COUNTER_COMP_SIGNAL_LEVEL, .type = COUNTER_COMP_SIGNAL_LEVEL,
.name = "signal", .name = "signal",
...@@ -605,8 +645,6 @@ static int counter_signal_attrs_create(struct counter_device *const counter, ...@@ -605,8 +645,6 @@ static int counter_signal_attrs_create(struct counter_device *const counter,
struct device *const dev = &counter->dev; struct device *const dev = &counter->dev;
int err; int err;
struct counter_comp comp; struct counter_comp comp;
size_t i;
struct counter_comp *ext;
/* Create main Signal attribute */ /* Create main Signal attribute */
comp = counter_signal_comp; comp = counter_signal_comp;
...@@ -620,21 +658,9 @@ static int counter_signal_attrs_create(struct counter_device *const counter, ...@@ -620,21 +658,9 @@ static int counter_signal_attrs_create(struct counter_device *const counter,
if (err < 0) if (err < 0)
return err; return err;
/* Create an attribute for each extension */ /* Add Signal extensions */
for (i = 0; i < signal->num_ext; i++) { return counter_sysfs_exts_add(dev, cattr_group, signal->ext,
ext = &signal->ext[i]; signal->num_ext, scope, signal);
err = counter_attr_create(dev, cattr_group, ext, scope, signal);
if (err < 0)
return err;
err = counter_comp_id_attr_create(dev, cattr_group, ext->name,
i);
if (err < 0)
return err;
}
return 0;
} }
static int counter_sysfs_signals_add(struct counter_device *const counter, static int counter_sysfs_signals_add(struct counter_device *const counter,
...@@ -719,8 +745,6 @@ static int counter_count_attrs_create(struct counter_device *const counter, ...@@ -719,8 +745,6 @@ static int counter_count_attrs_create(struct counter_device *const counter,
struct device *const dev = &counter->dev; struct device *const dev = &counter->dev;
int err; int err;
struct counter_comp comp; struct counter_comp comp;
size_t i;
struct counter_comp *ext;
/* Create main Count attribute */ /* Create main Count attribute */
comp = counter_count_comp; comp = counter_count_comp;
...@@ -743,21 +767,9 @@ static int counter_count_attrs_create(struct counter_device *const counter, ...@@ -743,21 +767,9 @@ static int counter_count_attrs_create(struct counter_device *const counter,
if (err < 0) if (err < 0)
return err; return err;
/* Create an attribute for each extension */ /* Add Count extensions */
for (i = 0; i < count->num_ext; i++) { return counter_sysfs_exts_add(dev, cattr_group, count->ext,
ext = &count->ext[i]; count->num_ext, scope, count);
err = counter_attr_create(dev, cattr_group, ext, scope, count);
if (err < 0)
return err;
err = counter_comp_id_attr_create(dev, cattr_group, ext->name,
i);
if (err < 0)
return err;
}
return 0;
} }
static int counter_sysfs_counts_add(struct counter_device *const counter, static int counter_sysfs_counts_add(struct counter_device *const counter,
...@@ -850,8 +862,6 @@ static int counter_sysfs_attr_add(struct counter_device *const counter, ...@@ -850,8 +862,6 @@ static int counter_sysfs_attr_add(struct counter_device *const counter,
const enum counter_scope scope = COUNTER_SCOPE_DEVICE; const enum counter_scope scope = COUNTER_SCOPE_DEVICE;
struct device *const dev = &counter->dev; struct device *const dev = &counter->dev;
int err; int err;
size_t i;
struct counter_comp *ext;
/* Add Signals sysfs attributes */ /* Add Signals sysfs attributes */
err = counter_sysfs_signals_add(counter, cattr_group); err = counter_sysfs_signals_add(counter, cattr_group);
...@@ -888,19 +898,9 @@ static int counter_sysfs_attr_add(struct counter_device *const counter, ...@@ -888,19 +898,9 @@ static int counter_sysfs_attr_add(struct counter_device *const counter,
if (err < 0) if (err < 0)
return err; return err;
/* Create an attribute for each extension */ /* Add device extensions */
for (i = 0; i < counter->num_ext; i++) { return counter_sysfs_exts_add(dev, cattr_group, counter->ext,
ext = &counter->ext[i]; counter->num_ext, scope, NULL);
err = counter_attr_create(dev, cattr_group, ext, scope, NULL);
if (err < 0)
return err;
err = counter_comp_id_attr_create(dev, cattr_group, ext->name,
i);
if (err < 0)
return err;
}
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment