projects
/
project
/
netifd.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
530d9f3
)
implement a dump status call for bridge devices
author
Felix Fietkau
<nbd@openwrt.org>
Sun, 27 Mar 2011 17:12:27 +0000
(19:12 +0200)
committer
Felix Fietkau
<nbd@openwrt.org>
Sun, 27 Mar 2011 17:12:27 +0000
(19:12 +0200)
bridge.c
patch
|
blob
|
history
diff --git
a/bridge.c
b/bridge.c
index
2aa0e68
..
6b6562c
100644
(file)
--- a/
bridge.c
+++ b/
bridge.c
@@
-292,12
+292,29
@@
bridge_free(struct device *dev)
free(bst);
}
free(bst);
}
+static void
+bridge_dump_status(struct device *dev, struct blob_buf *b)
+{
+ struct bridge_state *bst;
+ struct bridge_member *bm;
+ void *list;
+
+ bst = container_of(dev, struct bridge_state, dev);
+
+ list = blobmsg_open_array(b, "bridge-members");
+ list_for_each_entry(bm, &bst->members, list) {
+ blobmsg_add_string(b, NULL, bm->dev.dev->ifname);
+ }
+ blobmsg_close_array(b, list);
+}
+
struct device *
bridge_create(const char *name, struct uci_section *s)
{
static const struct device_type bridge_type = {
.name = "Bridge",
.free = bridge_free,
struct device *
bridge_create(const char *name, struct uci_section *s)
{
static const struct device_type bridge_type = {
.name = "Bridge",
.free = bridge_free,
+ .dump_status = bridge_dump_status,
};
struct bridge_state *bst;
struct device *dev;
};
struct bridge_state *bst;
struct device *dev;