summaryrefslogtreecommitdiff
path: root/ubus.c
diff options
context:
space:
mode:
authorSteven Barth <steven@midlink.org>2013-04-03 20:03:15 +0200
committerSteven Barth <steven@midlink.org>2013-04-03 20:03:15 +0200
commit48ffedb4a2b6701eec99e32e91b8a66a0a4be950 (patch)
tree1b6bbf54657783f07cc346c1bb912dd64938fba4 /ubus.c
parent059242dea7a7c1e51314cf41ad27aac853a385f3 (diff)
downloadnetifd-48ffedb4a2b6701eec99e32e91b8a66a0a4be950.tar.gz
Rewrite IPv6 prefix assignment
Diffstat (limited to 'ubus.c')
-rw-r--r--ubus.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/ubus.c b/ubus.c
index f2421cc..1036899 100644
--- a/ubus.c
+++ b/ubus.c
@@ -457,11 +457,17 @@ interface_ip_dump_prefix_list(struct interface_ip_settings *ip)
c = blobmsg_open_table(&b, "assigned");
struct device_prefix_assignment *assign;
- vlist_for_each_element(prefix->assignments, assign, node) {
+ list_for_each_entry(assign, &prefix->assignments, head) {
+ if (!assign->name[0])
+ continue;
+
+ struct in6_addr addr = prefix->addr;
+ addr.s6_addr32[1] |= htonl(assign->assigned);
+
void *d = blobmsg_open_table(&b, assign->name);
buf = blobmsg_alloc_string_buffer(&b, "address", buflen);
- inet_ntop(AF_INET6, &assign->addr, buf, buflen);
+ inet_ntop(AF_INET6, &addr, buf, buflen);
blobmsg_add_string_buffer(&b);
blobmsg_add_u32(&b, "mask", assign->length);
@@ -486,14 +492,17 @@ interface_ip_dump_prefix_assignment_list(struct interface *iface)
struct device_prefix *prefix;
list_for_each_entry(prefix, &prefixes, head) {
struct device_prefix_assignment *assign;
- vlist_for_each_element(prefix->assignments, assign, node) {
+ list_for_each_entry(assign, &prefix->assignments, head) {
if (strcmp(assign->name, iface->name))
continue;
+ struct in6_addr addr = prefix->addr;
+ addr.s6_addr32[1] |= htonl(assign->assigned);
+
a = blobmsg_open_table(&b, NULL);
buf = blobmsg_alloc_string_buffer(&b, "address", buflen);
- inet_ntop(AF_INET6, &assign->addr, buf, buflen);
+ inet_ntop(AF_INET6, &addr, buf, buflen);
blobmsg_add_string_buffer(&b);
blobmsg_add_u32(&b, "mask", assign->length);