projects
/
project
/
netifd.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add prelocal table to manipulate locally destinated traffic
[project/netifd.git]
/
interface-ip.h
diff --git
a/interface-ip.h
b/interface-ip.h
index
5cc5665
..
7c4a8ae
100644
(file)
--- a/
interface-ip.h
+++ b/
interface-ip.h
@@
-42,6
+42,12
@@
enum device_addr_flags {
/* route resides in default source-route table */
DEVROUTE_SRCTABLE = (1 << 8),
/* route resides in default source-route table */
DEVROUTE_SRCTABLE = (1 << 8),
+
+ /* route is on-link */
+ DEVROUTE_ONLINK = (1 << 9),
+
+ /* route overrides the default route type */
+ DEVROUTE_TYPE = (1 << 10),
};
union if_addr {
};
union if_addr {
@@
-53,6
+59,7
@@
struct device_prefix_assignment {
struct list_head head;
int32_t assigned;
uint8_t length;
struct list_head head;
int32_t assigned;
uint8_t length;
+ struct in6_addr addr;
bool enabled;
char name[];
};
bool enabled;
char name[];
};
@@
-77,6
+84,7
@@
struct device_prefix {
struct device_addr {
struct vlist_node node;
bool enabled;
struct device_addr {
struct vlist_node node;
bool enabled;
+ bool failed;
/* ipv4 only */
uint32_t broadcast;
/* ipv4 only */
uint32_t broadcast;
@@
-85,6
+93,7
@@
struct device_addr {
/* ipv6 only */
time_t valid_until;
time_t preferred_until;
/* ipv6 only */
time_t valid_until;
time_t preferred_until;
+ char *pclass;
/* must be last */
enum device_addr_flags flags;
/* must be last */
enum device_addr_flags flags;
@@
-98,9
+107,11
@@
struct device_route {
bool enabled;
bool keep;
bool enabled;
bool keep;
+ bool failed;
union if_addr nexthop;
int mtu;
union if_addr nexthop;
int mtu;
+ unsigned int type;
time_t valid_until;
/* must be last */
time_t valid_until;
/* must be last */
@@
-108,6
+119,17
@@
struct device_route {
int metric; // there can be multiple routes to the same target
unsigned int table;
unsigned int mask;
int metric; // there can be multiple routes to the same target
unsigned int table;
unsigned int mask;
+ unsigned int sourcemask;
+ union if_addr addr;
+ union if_addr source;
+};
+
+struct device_source_table {
+ struct list_head head;
+ uint32_t table;
+ uint16_t refcount;
+ uint8_t v6;
+ uint8_t mask;
union if_addr addr;
};
union if_addr addr;
};
@@
-122,7
+144,7
@@
struct dns_search_domain {
char name[];
};
char name[];
};
-extern const struct
config
_param_list route_attr_list;
+extern const struct
uci_blob
_param_list route_attr_list;
extern struct list_head prefixes;
void interface_ip_init(struct interface *iface);
extern struct list_head prefixes;
void interface_ip_init(struct interface *iface);