srp_transport: Simplify attribute initialization code
Eliminate the private_rport_attrs[] array and the SETUP_*() macros used to set up that array since the information in that array duplicates the information in the static device attributes. Also, verify whether SRP_RPORT_ATTRS is large enough since it is easy to forget to update that macro when adding new attributes. Signed-off-by: Bart Van Assche <bvanassche@acm.org> Cc: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp> Cc: Robert Jennings <rcj@linux.vnet.ibm.com> Acked-by: David Dillow <dillowda@ornl.gov> Signed-off-by: Roland Dreier <roland@purestorage.com>
This commit is contained in:
parent
ac9be30e91
commit
9134a85517
|
@ -47,7 +47,6 @@ struct srp_internal {
|
||||||
struct device_attribute *host_attrs[SRP_HOST_ATTRS + 1];
|
struct device_attribute *host_attrs[SRP_HOST_ATTRS + 1];
|
||||||
|
|
||||||
struct device_attribute *rport_attrs[SRP_RPORT_ATTRS + 1];
|
struct device_attribute *rport_attrs[SRP_RPORT_ATTRS + 1];
|
||||||
struct device_attribute private_rport_attrs[SRP_RPORT_ATTRS];
|
|
||||||
struct transport_container rport_attr_cont;
|
struct transport_container rport_attr_cont;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -72,24 +71,6 @@ static DECLARE_TRANSPORT_CLASS(srp_host_class, "srp_host", srp_host_setup,
|
||||||
static DECLARE_TRANSPORT_CLASS(srp_rport_class, "srp_remote_ports",
|
static DECLARE_TRANSPORT_CLASS(srp_rport_class, "srp_remote_ports",
|
||||||
NULL, NULL, NULL);
|
NULL, NULL, NULL);
|
||||||
|
|
||||||
#define SETUP_TEMPLATE(attrb, field, perm, test, ro_test, ro_perm) \
|
|
||||||
i->private_##attrb[count] = dev_attr_##field; \
|
|
||||||
i->private_##attrb[count].attr.mode = perm; \
|
|
||||||
if (ro_test) { \
|
|
||||||
i->private_##attrb[count].attr.mode = ro_perm; \
|
|
||||||
i->private_##attrb[count].store = NULL; \
|
|
||||||
} \
|
|
||||||
i->attrb[count] = &i->private_##attrb[count]; \
|
|
||||||
if (test) \
|
|
||||||
count++
|
|
||||||
|
|
||||||
#define SETUP_RPORT_ATTRIBUTE_RD(field) \
|
|
||||||
SETUP_TEMPLATE(rport_attrs, field, S_IRUGO, 1, 0, 0)
|
|
||||||
|
|
||||||
#define SETUP_RPORT_ATTRIBUTE_RW(field) \
|
|
||||||
SETUP_TEMPLATE(rport_attrs, field, S_IRUGO | S_IWUSR, \
|
|
||||||
1, 1, S_IRUGO)
|
|
||||||
|
|
||||||
#define SRP_PID(p) \
|
#define SRP_PID(p) \
|
||||||
(p)->port_id[0], (p)->port_id[1], (p)->port_id[2], (p)->port_id[3], \
|
(p)->port_id[0], (p)->port_id[1], (p)->port_id[2], (p)->port_id[3], \
|
||||||
(p)->port_id[4], (p)->port_id[5], (p)->port_id[6], (p)->port_id[7], \
|
(p)->port_id[4], (p)->port_id[5], (p)->port_id[6], (p)->port_id[7], \
|
||||||
|
@ -326,9 +307,10 @@ srp_attach_transport(struct srp_function_template *ft)
|
||||||
i->rport_attr_cont.ac.match = srp_rport_match;
|
i->rport_attr_cont.ac.match = srp_rport_match;
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
SETUP_RPORT_ATTRIBUTE_RD(port_id);
|
i->rport_attrs[count++] = &dev_attr_port_id;
|
||||||
SETUP_RPORT_ATTRIBUTE_RD(roles);
|
i->rport_attrs[count++] = &dev_attr_roles;
|
||||||
i->rport_attrs[count] = NULL;
|
i->rport_attrs[count++] = NULL;
|
||||||
|
BUG_ON(count > ARRAY_SIZE(i->rport_attrs));
|
||||||
|
|
||||||
transport_container_register(&i->rport_attr_cont);
|
transport_container_register(&i->rport_attr_cont);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue