ocfs2/cluster: use per-attribute show and store methods

Signed-off-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
This commit is contained in:
Christoph Hellwig 2015-10-03 15:32:58 +02:00 committed by Nicholas Bellinger
parent 13a83fc909
commit 45b997737a
2 changed files with 100 additions and 346 deletions

View File

@ -1473,16 +1473,17 @@ static int o2hb_read_block_input(struct o2hb_region *reg,
return 0; return 0;
} }
static ssize_t o2hb_region_block_bytes_read(struct o2hb_region *reg, static ssize_t o2hb_region_block_bytes_show(struct config_item *item,
char *page) char *page)
{ {
return sprintf(page, "%u\n", reg->hr_block_bytes); return sprintf(page, "%u\n", to_o2hb_region(item)->hr_block_bytes);
} }
static ssize_t o2hb_region_block_bytes_write(struct o2hb_region *reg, static ssize_t o2hb_region_block_bytes_store(struct config_item *item,
const char *page, const char *page,
size_t count) size_t count)
{ {
struct o2hb_region *reg = to_o2hb_region(item);
int status; int status;
unsigned long block_bytes; unsigned long block_bytes;
unsigned int block_bits; unsigned int block_bits;
@ -1501,16 +1502,17 @@ static ssize_t o2hb_region_block_bytes_write(struct o2hb_region *reg,
return count; return count;
} }
static ssize_t o2hb_region_start_block_read(struct o2hb_region *reg, static ssize_t o2hb_region_start_block_show(struct config_item *item,
char *page) char *page)
{ {
return sprintf(page, "%llu\n", reg->hr_start_block); return sprintf(page, "%llu\n", to_o2hb_region(item)->hr_start_block);
} }
static ssize_t o2hb_region_start_block_write(struct o2hb_region *reg, static ssize_t o2hb_region_start_block_store(struct config_item *item,
const char *page, const char *page,
size_t count) size_t count)
{ {
struct o2hb_region *reg = to_o2hb_region(item);
unsigned long long tmp; unsigned long long tmp;
char *p = (char *)page; char *p = (char *)page;
@ -1526,16 +1528,16 @@ static ssize_t o2hb_region_start_block_write(struct o2hb_region *reg,
return count; return count;
} }
static ssize_t o2hb_region_blocks_read(struct o2hb_region *reg, static ssize_t o2hb_region_blocks_show(struct config_item *item, char *page)
char *page)
{ {
return sprintf(page, "%d\n", reg->hr_blocks); return sprintf(page, "%d\n", to_o2hb_region(item)->hr_blocks);
} }
static ssize_t o2hb_region_blocks_write(struct o2hb_region *reg, static ssize_t o2hb_region_blocks_store(struct config_item *item,
const char *page, const char *page,
size_t count) size_t count)
{ {
struct o2hb_region *reg = to_o2hb_region(item);
unsigned long tmp; unsigned long tmp;
char *p = (char *)page; char *p = (char *)page;
@ -1554,13 +1556,12 @@ static ssize_t o2hb_region_blocks_write(struct o2hb_region *reg,
return count; return count;
} }
static ssize_t o2hb_region_dev_read(struct o2hb_region *reg, static ssize_t o2hb_region_dev_show(struct config_item *item, char *page)
char *page)
{ {
unsigned int ret = 0; unsigned int ret = 0;
if (reg->hr_bdev) if (to_o2hb_region(item)->hr_bdev)
ret = sprintf(page, "%s\n", reg->hr_dev_name); ret = sprintf(page, "%s\n", to_o2hb_region(item)->hr_dev_name);
return ret; return ret;
} }
@ -1670,10 +1671,11 @@ static int o2hb_populate_slot_data(struct o2hb_region *reg)
} }
/* this is acting as commit; we set up all of hr_bdev and hr_task or nothing */ /* this is acting as commit; we set up all of hr_bdev and hr_task or nothing */
static ssize_t o2hb_region_dev_write(struct o2hb_region *reg, static ssize_t o2hb_region_dev_store(struct config_item *item,
const char *page, const char *page,
size_t count) size_t count)
{ {
struct o2hb_region *reg = to_o2hb_region(item);
struct task_struct *hb_task; struct task_struct *hb_task;
long fd; long fd;
int sectsize; int sectsize;
@ -1828,9 +1830,9 @@ static ssize_t o2hb_region_dev_write(struct o2hb_region *reg,
return ret; return ret;
} }
static ssize_t o2hb_region_pid_read(struct o2hb_region *reg, static ssize_t o2hb_region_pid_show(struct config_item *item, char *page)
char *page)
{ {
struct o2hb_region *reg = to_o2hb_region(item);
pid_t pid = 0; pid_t pid = 0;
spin_lock(&o2hb_live_lock); spin_lock(&o2hb_live_lock);
@ -1844,92 +1846,23 @@ static ssize_t o2hb_region_pid_read(struct o2hb_region *reg,
return sprintf(page, "%u\n", pid); return sprintf(page, "%u\n", pid);
} }
struct o2hb_region_attribute { CONFIGFS_ATTR(o2hb_region_, block_bytes);
struct configfs_attribute attr; CONFIGFS_ATTR(o2hb_region_, start_block);
ssize_t (*show)(struct o2hb_region *, char *); CONFIGFS_ATTR(o2hb_region_, blocks);
ssize_t (*store)(struct o2hb_region *, const char *, size_t); CONFIGFS_ATTR(o2hb_region_, dev);
}; CONFIGFS_ATTR_RO(o2hb_region_, pid);
static struct o2hb_region_attribute o2hb_region_attr_block_bytes = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "block_bytes",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2hb_region_block_bytes_read,
.store = o2hb_region_block_bytes_write,
};
static struct o2hb_region_attribute o2hb_region_attr_start_block = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "start_block",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2hb_region_start_block_read,
.store = o2hb_region_start_block_write,
};
static struct o2hb_region_attribute o2hb_region_attr_blocks = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "blocks",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2hb_region_blocks_read,
.store = o2hb_region_blocks_write,
};
static struct o2hb_region_attribute o2hb_region_attr_dev = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "dev",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2hb_region_dev_read,
.store = o2hb_region_dev_write,
};
static struct o2hb_region_attribute o2hb_region_attr_pid = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "pid",
.ca_mode = S_IRUGO | S_IRUSR },
.show = o2hb_region_pid_read,
};
static struct configfs_attribute *o2hb_region_attrs[] = { static struct configfs_attribute *o2hb_region_attrs[] = {
&o2hb_region_attr_block_bytes.attr, &o2hb_region_attr_block_bytes,
&o2hb_region_attr_start_block.attr, &o2hb_region_attr_start_block,
&o2hb_region_attr_blocks.attr, &o2hb_region_attr_blocks,
&o2hb_region_attr_dev.attr, &o2hb_region_attr_dev,
&o2hb_region_attr_pid.attr, &o2hb_region_attr_pid,
NULL, NULL,
}; };
static ssize_t o2hb_region_show(struct config_item *item,
struct configfs_attribute *attr,
char *page)
{
struct o2hb_region *reg = to_o2hb_region(item);
struct o2hb_region_attribute *o2hb_region_attr =
container_of(attr, struct o2hb_region_attribute, attr);
ssize_t ret = 0;
if (o2hb_region_attr->show)
ret = o2hb_region_attr->show(reg, page);
return ret;
}
static ssize_t o2hb_region_store(struct config_item *item,
struct configfs_attribute *attr,
const char *page, size_t count)
{
struct o2hb_region *reg = to_o2hb_region(item);
struct o2hb_region_attribute *o2hb_region_attr =
container_of(attr, struct o2hb_region_attribute, attr);
ssize_t ret = -EINVAL;
if (o2hb_region_attr->store)
ret = o2hb_region_attr->store(reg, page, count);
return ret;
}
static struct configfs_item_operations o2hb_region_item_ops = { static struct configfs_item_operations o2hb_region_item_ops = {
.release = o2hb_region_release, .release = o2hb_region_release,
.show_attribute = o2hb_region_show,
.store_attribute = o2hb_region_store,
}; };
static struct config_item_type o2hb_region_type = { static struct config_item_type o2hb_region_type = {
@ -2124,49 +2057,14 @@ static void o2hb_heartbeat_group_drop_item(struct config_group *group,
spin_unlock(&o2hb_live_lock); spin_unlock(&o2hb_live_lock);
} }
struct o2hb_heartbeat_group_attribute { static ssize_t o2hb_heartbeat_group_threshold_show(struct config_item *item,
struct configfs_attribute attr; char *page)
ssize_t (*show)(struct o2hb_heartbeat_group *, char *);
ssize_t (*store)(struct o2hb_heartbeat_group *, const char *, size_t);
};
static ssize_t o2hb_heartbeat_group_show(struct config_item *item,
struct configfs_attribute *attr,
char *page)
{
struct o2hb_heartbeat_group *reg = to_o2hb_heartbeat_group(to_config_group(item));
struct o2hb_heartbeat_group_attribute *o2hb_heartbeat_group_attr =
container_of(attr, struct o2hb_heartbeat_group_attribute, attr);
ssize_t ret = 0;
if (o2hb_heartbeat_group_attr->show)
ret = o2hb_heartbeat_group_attr->show(reg, page);
return ret;
}
static ssize_t o2hb_heartbeat_group_store(struct config_item *item,
struct configfs_attribute *attr,
const char *page, size_t count)
{
struct o2hb_heartbeat_group *reg = to_o2hb_heartbeat_group(to_config_group(item));
struct o2hb_heartbeat_group_attribute *o2hb_heartbeat_group_attr =
container_of(attr, struct o2hb_heartbeat_group_attribute, attr);
ssize_t ret = -EINVAL;
if (o2hb_heartbeat_group_attr->store)
ret = o2hb_heartbeat_group_attr->store(reg, page, count);
return ret;
}
static ssize_t o2hb_heartbeat_group_threshold_show(struct o2hb_heartbeat_group *group,
char *page)
{ {
return sprintf(page, "%u\n", o2hb_dead_threshold); return sprintf(page, "%u\n", o2hb_dead_threshold);
} }
static ssize_t o2hb_heartbeat_group_threshold_store(struct o2hb_heartbeat_group *group, static ssize_t o2hb_heartbeat_group_threshold_store(struct config_item *item,
const char *page, const char *page, size_t count)
size_t count)
{ {
unsigned long tmp; unsigned long tmp;
char *p = (char *)page; char *p = (char *)page;
@ -2181,17 +2079,15 @@ static ssize_t o2hb_heartbeat_group_threshold_store(struct o2hb_heartbeat_group
return count; return count;
} }
static static ssize_t o2hb_heartbeat_group_mode_show(struct config_item *item,
ssize_t o2hb_heartbeat_group_mode_show(struct o2hb_heartbeat_group *group, char *page)
char *page)
{ {
return sprintf(page, "%s\n", return sprintf(page, "%s\n",
o2hb_heartbeat_mode_desc[o2hb_heartbeat_mode]); o2hb_heartbeat_mode_desc[o2hb_heartbeat_mode]);
} }
static static ssize_t o2hb_heartbeat_group_mode_store(struct config_item *item,
ssize_t o2hb_heartbeat_group_mode_store(struct o2hb_heartbeat_group *group, const char *page, size_t count)
const char *page, size_t count)
{ {
unsigned int i; unsigned int i;
int ret; int ret;
@ -2216,33 +2112,15 @@ ssize_t o2hb_heartbeat_group_mode_store(struct o2hb_heartbeat_group *group,
} }
static struct o2hb_heartbeat_group_attribute o2hb_heartbeat_group_attr_threshold = { CONFIGFS_ATTR(o2hb_heartbeat_group_, threshold);
.attr = { .ca_owner = THIS_MODULE, CONFIGFS_ATTR(o2hb_heartbeat_group_, mode);
.ca_name = "dead_threshold",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2hb_heartbeat_group_threshold_show,
.store = o2hb_heartbeat_group_threshold_store,
};
static struct o2hb_heartbeat_group_attribute o2hb_heartbeat_group_attr_mode = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "mode",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2hb_heartbeat_group_mode_show,
.store = o2hb_heartbeat_group_mode_store,
};
static struct configfs_attribute *o2hb_heartbeat_group_attrs[] = { static struct configfs_attribute *o2hb_heartbeat_group_attrs[] = {
&o2hb_heartbeat_group_attr_threshold.attr, &o2hb_heartbeat_group_attr_threshold,
&o2hb_heartbeat_group_attr_mode.attr, &o2hb_heartbeat_group_attr_mode,
NULL, NULL,
}; };
static struct configfs_item_operations o2hb_heartbeat_group_item_ops = {
.show_attribute = o2hb_heartbeat_group_show,
.store_attribute = o2hb_heartbeat_group_store,
};
static struct configfs_group_operations o2hb_heartbeat_group_group_ops = { static struct configfs_group_operations o2hb_heartbeat_group_group_ops = {
.make_item = o2hb_heartbeat_group_make_item, .make_item = o2hb_heartbeat_group_make_item,
.drop_item = o2hb_heartbeat_group_drop_item, .drop_item = o2hb_heartbeat_group_drop_item,
@ -2250,7 +2128,6 @@ static struct configfs_group_operations o2hb_heartbeat_group_group_ops = {
static struct config_item_type o2hb_heartbeat_group_type = { static struct config_item_type o2hb_heartbeat_group_type = {
.ct_group_ops = &o2hb_heartbeat_group_group_ops, .ct_group_ops = &o2hb_heartbeat_group_group_ops,
.ct_item_ops = &o2hb_heartbeat_group_item_ops,
.ct_attrs = o2hb_heartbeat_group_attrs, .ct_attrs = o2hb_heartbeat_group_attrs,
.ct_owner = THIS_MODULE, .ct_owner = THIS_MODULE,
}; };

View File

@ -172,9 +172,9 @@ static void o2nm_node_release(struct config_item *item)
kfree(node); kfree(node);
} }
static ssize_t o2nm_node_num_read(struct o2nm_node *node, char *page) static ssize_t o2nm_node_num_show(struct config_item *item, char *page)
{ {
return sprintf(page, "%d\n", node->nd_num); return sprintf(page, "%d\n", to_o2nm_node(item)->nd_num);
} }
static struct o2nm_cluster *to_o2nm_cluster_from_node(struct o2nm_node *node) static struct o2nm_cluster *to_o2nm_cluster_from_node(struct o2nm_node *node)
@ -190,9 +190,10 @@ enum {
O2NM_NODE_ATTR_ADDRESS, O2NM_NODE_ATTR_ADDRESS,
}; };
static ssize_t o2nm_node_num_write(struct o2nm_node *node, const char *page, static ssize_t o2nm_node_num_store(struct config_item *item, const char *page,
size_t count) size_t count)
{ {
struct o2nm_node *node = to_o2nm_node(item);
struct o2nm_cluster *cluster = to_o2nm_cluster_from_node(node); struct o2nm_cluster *cluster = to_o2nm_cluster_from_node(node);
unsigned long tmp; unsigned long tmp;
char *p = (char *)page; char *p = (char *)page;
@ -230,14 +231,15 @@ static ssize_t o2nm_node_num_write(struct o2nm_node *node, const char *page,
return count; return count;
} }
static ssize_t o2nm_node_ipv4_port_read(struct o2nm_node *node, char *page) static ssize_t o2nm_node_ipv4_port_show(struct config_item *item, char *page)
{ {
return sprintf(page, "%u\n", ntohs(node->nd_ipv4_port)); return sprintf(page, "%u\n", ntohs(to_o2nm_node(item)->nd_ipv4_port));
} }
static ssize_t o2nm_node_ipv4_port_write(struct o2nm_node *node, static ssize_t o2nm_node_ipv4_port_store(struct config_item *item,
const char *page, size_t count) const char *page, size_t count)
{ {
struct o2nm_node *node = to_o2nm_node(item);
unsigned long tmp; unsigned long tmp;
char *p = (char *)page; char *p = (char *)page;
@ -257,15 +259,16 @@ static ssize_t o2nm_node_ipv4_port_write(struct o2nm_node *node,
return count; return count;
} }
static ssize_t o2nm_node_ipv4_address_read(struct o2nm_node *node, char *page) static ssize_t o2nm_node_ipv4_address_show(struct config_item *item, char *page)
{ {
return sprintf(page, "%pI4\n", &node->nd_ipv4_address); return sprintf(page, "%pI4\n", &to_o2nm_node(item)->nd_ipv4_address);
} }
static ssize_t o2nm_node_ipv4_address_write(struct o2nm_node *node, static ssize_t o2nm_node_ipv4_address_store(struct config_item *item,
const char *page, const char *page,
size_t count) size_t count)
{ {
struct o2nm_node *node = to_o2nm_node(item);
struct o2nm_cluster *cluster = to_o2nm_cluster_from_node(node); struct o2nm_cluster *cluster = to_o2nm_cluster_from_node(node);
int ret, i; int ret, i;
struct rb_node **p, *parent; struct rb_node **p, *parent;
@ -303,14 +306,15 @@ static ssize_t o2nm_node_ipv4_address_write(struct o2nm_node *node,
return count; return count;
} }
static ssize_t o2nm_node_local_read(struct o2nm_node *node, char *page) static ssize_t o2nm_node_local_show(struct config_item *item, char *page)
{ {
return sprintf(page, "%d\n", node->nd_local); return sprintf(page, "%d\n", to_o2nm_node(item)->nd_local);
} }
static ssize_t o2nm_node_local_write(struct o2nm_node *node, const char *page, static ssize_t o2nm_node_local_store(struct config_item *item, const char *page,
size_t count) size_t count)
{ {
struct o2nm_node *node = to_o2nm_node(item);
struct o2nm_cluster *cluster = to_o2nm_cluster_from_node(node); struct o2nm_cluster *cluster = to_o2nm_cluster_from_node(node);
unsigned long tmp; unsigned long tmp;
char *p = (char *)page; char *p = (char *)page;
@ -357,84 +361,21 @@ static ssize_t o2nm_node_local_write(struct o2nm_node *node, const char *page,
return count; return count;
} }
struct o2nm_node_attribute { CONFIGFS_ATTR(o2nm_node_, num);
struct configfs_attribute attr; CONFIGFS_ATTR(o2nm_node_, ipv4_port);
ssize_t (*show)(struct o2nm_node *, char *); CONFIGFS_ATTR(o2nm_node_, ipv4_address);
ssize_t (*store)(struct o2nm_node *, const char *, size_t); CONFIGFS_ATTR(o2nm_node_, local);
};
static struct o2nm_node_attribute o2nm_node_attr_num = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "num",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2nm_node_num_read,
.store = o2nm_node_num_write,
};
static struct o2nm_node_attribute o2nm_node_attr_ipv4_port = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "ipv4_port",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2nm_node_ipv4_port_read,
.store = o2nm_node_ipv4_port_write,
};
static struct o2nm_node_attribute o2nm_node_attr_ipv4_address = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "ipv4_address",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2nm_node_ipv4_address_read,
.store = o2nm_node_ipv4_address_write,
};
static struct o2nm_node_attribute o2nm_node_attr_local = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "local",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2nm_node_local_read,
.store = o2nm_node_local_write,
};
static struct configfs_attribute *o2nm_node_attrs[] = { static struct configfs_attribute *o2nm_node_attrs[] = {
&o2nm_node_attr_num.attr, &o2nm_node_attr_num,
&o2nm_node_attr_ipv4_port.attr, &o2nm_node_attr_ipv4_port,
&o2nm_node_attr_ipv4_address.attr, &o2nm_node_attr_ipv4_address,
&o2nm_node_attr_local.attr, &o2nm_node_attr_local,
NULL, NULL,
}; };
static ssize_t o2nm_node_show(struct config_item *item,
struct configfs_attribute *attr,
char *page)
{
struct o2nm_node *node = to_o2nm_node(item);
struct o2nm_node_attribute *o2nm_node_attr =
container_of(attr, struct o2nm_node_attribute, attr);
ssize_t ret = 0;
if (o2nm_node_attr->show)
ret = o2nm_node_attr->show(node, page);
return ret;
}
static ssize_t o2nm_node_store(struct config_item *item,
struct configfs_attribute *attr,
const char *page, size_t count)
{
struct o2nm_node *node = to_o2nm_node(item);
struct o2nm_node_attribute *o2nm_node_attr =
container_of(attr, struct o2nm_node_attribute, attr);
if (o2nm_node_attr->store == NULL)
return -EINVAL;
return o2nm_node_attr->store(node, page, count);
}
static struct configfs_item_operations o2nm_node_item_ops = { static struct configfs_item_operations o2nm_node_item_ops = {
.release = o2nm_node_release, .release = o2nm_node_release,
.show_attribute = o2nm_node_show,
.store_attribute = o2nm_node_store,
}; };
static struct config_item_type o2nm_node_type = { static struct config_item_type o2nm_node_type = {
@ -459,12 +400,6 @@ static struct o2nm_node_group *to_o2nm_node_group(struct config_group *group)
} }
#endif #endif
struct o2nm_cluster_attribute {
struct configfs_attribute attr;
ssize_t (*show)(struct o2nm_cluster *, char *);
ssize_t (*store)(struct o2nm_cluster *, const char *, size_t);
};
static ssize_t o2nm_cluster_attr_write(const char *page, ssize_t count, static ssize_t o2nm_cluster_attr_write(const char *page, ssize_t count,
unsigned int *val) unsigned int *val)
{ {
@ -485,15 +420,16 @@ static ssize_t o2nm_cluster_attr_write(const char *page, ssize_t count,
return count; return count;
} }
static ssize_t o2nm_cluster_attr_idle_timeout_ms_read( static ssize_t o2nm_cluster_idle_timeout_ms_show(struct config_item *item,
struct o2nm_cluster *cluster, char *page) char *page)
{ {
return sprintf(page, "%u\n", cluster->cl_idle_timeout_ms); return sprintf(page, "%u\n", to_o2nm_cluster(item)->cl_idle_timeout_ms);
} }
static ssize_t o2nm_cluster_attr_idle_timeout_ms_write( static ssize_t o2nm_cluster_idle_timeout_ms_store(struct config_item *item,
struct o2nm_cluster *cluster, const char *page, size_t count) const char *page, size_t count)
{ {
struct o2nm_cluster *cluster = to_o2nm_cluster(item);
ssize_t ret; ssize_t ret;
unsigned int val; unsigned int val;
@ -520,15 +456,17 @@ static ssize_t o2nm_cluster_attr_idle_timeout_ms_write(
return ret; return ret;
} }
static ssize_t o2nm_cluster_attr_keepalive_delay_ms_read( static ssize_t o2nm_cluster_keepalive_delay_ms_show(
struct o2nm_cluster *cluster, char *page) struct config_item *item, char *page)
{ {
return sprintf(page, "%u\n", cluster->cl_keepalive_delay_ms); return sprintf(page, "%u\n",
to_o2nm_cluster(item)->cl_keepalive_delay_ms);
} }
static ssize_t o2nm_cluster_attr_keepalive_delay_ms_write( static ssize_t o2nm_cluster_keepalive_delay_ms_store(
struct o2nm_cluster *cluster, const char *page, size_t count) struct config_item *item, const char *page, size_t count)
{ {
struct o2nm_cluster *cluster = to_o2nm_cluster(item);
ssize_t ret; ssize_t ret;
unsigned int val; unsigned int val;
@ -555,22 +493,24 @@ static ssize_t o2nm_cluster_attr_keepalive_delay_ms_write(
return ret; return ret;
} }
static ssize_t o2nm_cluster_attr_reconnect_delay_ms_read( static ssize_t o2nm_cluster_reconnect_delay_ms_show(
struct o2nm_cluster *cluster, char *page) struct config_item *item, char *page)
{ {
return sprintf(page, "%u\n", cluster->cl_reconnect_delay_ms); return sprintf(page, "%u\n",
to_o2nm_cluster(item)->cl_reconnect_delay_ms);
} }
static ssize_t o2nm_cluster_attr_reconnect_delay_ms_write( static ssize_t o2nm_cluster_reconnect_delay_ms_store(
struct o2nm_cluster *cluster, const char *page, size_t count) struct config_item *item, const char *page, size_t count)
{ {
return o2nm_cluster_attr_write(page, count, return o2nm_cluster_attr_write(page, count,
&cluster->cl_reconnect_delay_ms); &to_o2nm_cluster(item)->cl_reconnect_delay_ms);
} }
static ssize_t o2nm_cluster_attr_fence_method_read( static ssize_t o2nm_cluster_fence_method_show(
struct o2nm_cluster *cluster, char *page) struct config_item *item, char *page)
{ {
struct o2nm_cluster *cluster = to_o2nm_cluster(item);
ssize_t ret = 0; ssize_t ret = 0;
if (cluster) if (cluster)
@ -579,8 +519,8 @@ static ssize_t o2nm_cluster_attr_fence_method_read(
return ret; return ret;
} }
static ssize_t o2nm_cluster_attr_fence_method_write( static ssize_t o2nm_cluster_fence_method_store(
struct o2nm_cluster *cluster, const char *page, size_t count) struct config_item *item, const char *page, size_t count)
{ {
unsigned int i; unsigned int i;
@ -592,10 +532,10 @@ static ssize_t o2nm_cluster_attr_fence_method_write(
continue; continue;
if (strncasecmp(page, o2nm_fence_method_desc[i], count - 1)) if (strncasecmp(page, o2nm_fence_method_desc[i], count - 1))
continue; continue;
if (cluster->cl_fence_method != i) { if (to_o2nm_cluster(item)->cl_fence_method != i) {
printk(KERN_INFO "ocfs2: Changing fence method to %s\n", printk(KERN_INFO "ocfs2: Changing fence method to %s\n",
o2nm_fence_method_desc[i]); o2nm_fence_method_desc[i]);
cluster->cl_fence_method = i; to_o2nm_cluster(item)->cl_fence_method = i;
} }
return count; return count;
} }
@ -604,79 +544,18 @@ static ssize_t o2nm_cluster_attr_fence_method_write(
return -EINVAL; return -EINVAL;
} }
static struct o2nm_cluster_attribute o2nm_cluster_attr_idle_timeout_ms = { CONFIGFS_ATTR(o2nm_cluster_, idle_timeout_ms);
.attr = { .ca_owner = THIS_MODULE, CONFIGFS_ATTR(o2nm_cluster_, keepalive_delay_ms);
.ca_name = "idle_timeout_ms", CONFIGFS_ATTR(o2nm_cluster_, reconnect_delay_ms);
.ca_mode = S_IRUGO | S_IWUSR }, CONFIGFS_ATTR(o2nm_cluster_, fence_method);
.show = o2nm_cluster_attr_idle_timeout_ms_read,
.store = o2nm_cluster_attr_idle_timeout_ms_write,
};
static struct o2nm_cluster_attribute o2nm_cluster_attr_keepalive_delay_ms = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "keepalive_delay_ms",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2nm_cluster_attr_keepalive_delay_ms_read,
.store = o2nm_cluster_attr_keepalive_delay_ms_write,
};
static struct o2nm_cluster_attribute o2nm_cluster_attr_reconnect_delay_ms = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "reconnect_delay_ms",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2nm_cluster_attr_reconnect_delay_ms_read,
.store = o2nm_cluster_attr_reconnect_delay_ms_write,
};
static struct o2nm_cluster_attribute o2nm_cluster_attr_fence_method = {
.attr = { .ca_owner = THIS_MODULE,
.ca_name = "fence_method",
.ca_mode = S_IRUGO | S_IWUSR },
.show = o2nm_cluster_attr_fence_method_read,
.store = o2nm_cluster_attr_fence_method_write,
};
static struct configfs_attribute *o2nm_cluster_attrs[] = { static struct configfs_attribute *o2nm_cluster_attrs[] = {
&o2nm_cluster_attr_idle_timeout_ms.attr, &o2nm_cluster_attr_idle_timeout_ms,
&o2nm_cluster_attr_keepalive_delay_ms.attr, &o2nm_cluster_attr_keepalive_delay_ms,
&o2nm_cluster_attr_reconnect_delay_ms.attr, &o2nm_cluster_attr_reconnect_delay_ms,
&o2nm_cluster_attr_fence_method.attr, &o2nm_cluster_attr_fence_method,
NULL, NULL,
}; };
static ssize_t o2nm_cluster_show(struct config_item *item,
struct configfs_attribute *attr,
char *page)
{
struct o2nm_cluster *cluster = to_o2nm_cluster(item);
struct o2nm_cluster_attribute *o2nm_cluster_attr =
container_of(attr, struct o2nm_cluster_attribute, attr);
ssize_t ret = 0;
if (o2nm_cluster_attr->show)
ret = o2nm_cluster_attr->show(cluster, page);
return ret;
}
static ssize_t o2nm_cluster_store(struct config_item *item,
struct configfs_attribute *attr,
const char *page, size_t count)
{
struct o2nm_cluster *cluster = to_o2nm_cluster(item);
struct o2nm_cluster_attribute *o2nm_cluster_attr =
container_of(attr, struct o2nm_cluster_attribute, attr);
ssize_t ret;
if (o2nm_cluster_attr->store == NULL) {
ret = -EINVAL;
goto out;
}
ret = o2nm_cluster_attr->store(cluster, page, count);
if (ret < count)
goto out;
out:
return ret;
}
static struct config_item *o2nm_node_group_make_item(struct config_group *group, static struct config_item *o2nm_node_group_make_item(struct config_group *group,
const char *name) const char *name)
@ -757,8 +636,6 @@ static void o2nm_cluster_release(struct config_item *item)
static struct configfs_item_operations o2nm_cluster_item_ops = { static struct configfs_item_operations o2nm_cluster_item_ops = {
.release = o2nm_cluster_release, .release = o2nm_cluster_release,
.show_attribute = o2nm_cluster_show,
.store_attribute = o2nm_cluster_store,
}; };
static struct config_item_type o2nm_cluster_type = { static struct config_item_type o2nm_cluster_type = {