mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-23 23:32:14 +00:00
flow: Extend flow informations with xfrm interface id.
Add a new flowi_xfrm structure with informations needed to do a xfrm lookup. At the moment it keeps the informations about the new xfrm interface id needed to lookup xfrm interfaces that are introduced with a followup patch. We need this new lookup key as other possible keys, like the ifindex is already part of the xfrm selector and used as a key to enforce the output device after the transformation in the policy/state lookup. Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com> Acked-by: Shannon Nelson <shannon.nelson@oracle.com> Acked-by: Benedict Wong <benedictwong@google.com> Tested-by: Benedict Wong <benedictwong@google.com> Tested-by: Antony Antony <antony@phenome.org> Reviewed-by: Eyal Birger <eyal.birger@gmail.com>
This commit is contained in:
parent
9b42c1f179
commit
d159ce7957
1 changed files with 9 additions and 0 deletions
|
@ -26,6 +26,10 @@ struct flowi_tunnel {
|
||||||
__be64 tun_id;
|
__be64 tun_id;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct flowi_xfrm {
|
||||||
|
__u32 if_id;
|
||||||
|
};
|
||||||
|
|
||||||
struct flowi_common {
|
struct flowi_common {
|
||||||
int flowic_oif;
|
int flowic_oif;
|
||||||
int flowic_iif;
|
int flowic_iif;
|
||||||
|
@ -39,6 +43,7 @@ struct flowi_common {
|
||||||
#define FLOWI_FLAG_SKIP_NH_OIF 0x04
|
#define FLOWI_FLAG_SKIP_NH_OIF 0x04
|
||||||
__u32 flowic_secid;
|
__u32 flowic_secid;
|
||||||
struct flowi_tunnel flowic_tun_key;
|
struct flowi_tunnel flowic_tun_key;
|
||||||
|
struct flowi_xfrm xfrm;
|
||||||
kuid_t flowic_uid;
|
kuid_t flowic_uid;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -78,6 +83,7 @@ struct flowi4 {
|
||||||
#define flowi4_secid __fl_common.flowic_secid
|
#define flowi4_secid __fl_common.flowic_secid
|
||||||
#define flowi4_tun_key __fl_common.flowic_tun_key
|
#define flowi4_tun_key __fl_common.flowic_tun_key
|
||||||
#define flowi4_uid __fl_common.flowic_uid
|
#define flowi4_uid __fl_common.flowic_uid
|
||||||
|
#define flowi4_xfrm __fl_common.xfrm
|
||||||
|
|
||||||
/* (saddr,daddr) must be grouped, same order as in IP header */
|
/* (saddr,daddr) must be grouped, same order as in IP header */
|
||||||
__be32 saddr;
|
__be32 saddr;
|
||||||
|
@ -109,6 +115,7 @@ static inline void flowi4_init_output(struct flowi4 *fl4, int oif,
|
||||||
fl4->flowi4_flags = flags;
|
fl4->flowi4_flags = flags;
|
||||||
fl4->flowi4_secid = 0;
|
fl4->flowi4_secid = 0;
|
||||||
fl4->flowi4_tun_key.tun_id = 0;
|
fl4->flowi4_tun_key.tun_id = 0;
|
||||||
|
fl4->flowi4_xfrm.if_id = 0;
|
||||||
fl4->flowi4_uid = uid;
|
fl4->flowi4_uid = uid;
|
||||||
fl4->daddr = daddr;
|
fl4->daddr = daddr;
|
||||||
fl4->saddr = saddr;
|
fl4->saddr = saddr;
|
||||||
|
@ -138,6 +145,7 @@ struct flowi6 {
|
||||||
#define flowi6_secid __fl_common.flowic_secid
|
#define flowi6_secid __fl_common.flowic_secid
|
||||||
#define flowi6_tun_key __fl_common.flowic_tun_key
|
#define flowi6_tun_key __fl_common.flowic_tun_key
|
||||||
#define flowi6_uid __fl_common.flowic_uid
|
#define flowi6_uid __fl_common.flowic_uid
|
||||||
|
#define flowi6_xfrm __fl_common.xfrm
|
||||||
struct in6_addr daddr;
|
struct in6_addr daddr;
|
||||||
struct in6_addr saddr;
|
struct in6_addr saddr;
|
||||||
/* Note: flowi6_tos is encoded in flowlabel, too. */
|
/* Note: flowi6_tos is encoded in flowlabel, too. */
|
||||||
|
@ -185,6 +193,7 @@ struct flowi {
|
||||||
#define flowi_secid u.__fl_common.flowic_secid
|
#define flowi_secid u.__fl_common.flowic_secid
|
||||||
#define flowi_tun_key u.__fl_common.flowic_tun_key
|
#define flowi_tun_key u.__fl_common.flowic_tun_key
|
||||||
#define flowi_uid u.__fl_common.flowic_uid
|
#define flowi_uid u.__fl_common.flowic_uid
|
||||||
|
#define flowi_xfrm u.__fl_common.xfrm
|
||||||
} __attribute__((__aligned__(BITS_PER_LONG/8)));
|
} __attribute__((__aligned__(BITS_PER_LONG/8)));
|
||||||
|
|
||||||
static inline struct flowi *flowi4_to_flowi(struct flowi4 *fl4)
|
static inline struct flowi *flowi4_to_flowi(struct flowi4 *fl4)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue