projects
/
project
/
netifd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
IPv6: Set loopback-policy for output traffic
[project/netifd.git]
/
interface-ip.h
diff --git
a/interface-ip.h
b/interface-ip.h
index
054ed40
..
c2213fd
100644
(file)
--- a/
interface-ip.h
+++ b/
interface-ip.h
@@
-33,6
+33,15
@@
enum device_addr_flags {
/* route automatically added by kernel */
DEVADDR_KERNEL = (1 << 5),
/* route automatically added by kernel */
DEVADDR_KERNEL = (1 << 5),
+
+ /* address is off-link (no subnet-route) */
+ DEVADDR_OFFLINK = (1 << 6),
+
+ /* route resides in different table */
+ DEVROUTE_TABLE = (1 << 7),
+
+ /* route resides in default source-route table */
+ DEVROUTE_SRCTABLE = (1 << 8),
};
union if_addr {
};
union if_addr {
@@
-40,26
+49,27
@@
union if_addr {
struct in6_addr in6;
};
struct in6_addr in6;
};
+struct device_prefix_assignment {
+ struct list_head head;
+ int32_t assigned;
+ uint8_t length;
+ bool enabled;
+ char name[];
+};
+
struct device_prefix {
struct vlist_node node;
struct list_head head;
struct device_prefix {
struct vlist_node node;
struct list_head head;
- struct
vlist_tree *
assignments;
+ struct
list_head
assignments;
struct interface *iface;
struct interface *iface;
- uint64_t avail;
time_t valid_until;
time_t preferred_until;
struct in6_addr addr;
time_t valid_until;
time_t preferred_until;
struct in6_addr addr;
- uint8_t length;
-};
+ struct in6_addr excl_addr;
-struct device_prefix_assignment {
- struct vlist_node node;
- struct device_prefix *prefix;
- struct in6_addr addr;
- bool enabled;
uint8_t length;
uint8_t length;
-
char *name
;
+
uint8_t excl_length
;
};
struct device_addr {
};
struct device_addr {
@@
-88,11
+98,13
@@
struct device_route {
bool keep;
union if_addr nexthop;
bool keep;
union if_addr nexthop;
- int metric;
int mtu;
int mtu;
+ time_t valid_until;
/* must be last */
enum device_addr_flags flags;
/* must be last */
enum device_addr_flags flags;
+ int metric; // there can be multiple routes to the same target
+ unsigned int table;
unsigned int mask;
union if_addr addr;
};
unsigned int mask;
union if_addr addr;
};
@@
-125,12
+137,13
@@
void interface_ip_flush(struct interface_ip_settings *ip);
void interface_ip_set_enabled(struct interface_ip_settings *ip, bool enabled);
void interface_ip_update_metric(struct interface_ip_settings *ip, int metric);
void interface_ip_set_enabled(struct interface_ip_settings *ip, bool enabled);
void interface_ip_update_metric(struct interface_ip_settings *ip, int metric);
-struct interface *interface_ip_add_target_route(union if_addr *addr, bool v6);
+struct interface *interface_ip_add_target_route(union if_addr *addr, bool v6
, struct interface *iface
);
-void interface_ip_set_prefix_assignment(struct device_prefix *prefix,
- struct interface *iface, uint8_t length);
-void interface_ip_add_device_prefix(struct interface *iface, struct in6_addr *addr,
- uint8_t length, time_t valid_until, time_t preferred_until);
+struct device_prefix* interface_ip_add_device_prefix(struct interface *iface,
+ struct in6_addr *addr, uint8_t length, time_t valid_until, time_t preferred_until,
+ struct in6_addr *excl_addr, uint8_t excl_length);
void interface_ip_set_ula_prefix(const char *prefix);
void interface_ip_set_ula_prefix(const char *prefix);
+void interface_refresh_assignments(bool hint);
+int interface_ip_resolve_v6_rtable(int ifindex);
#endif
#endif