Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

[IPSEC]: Add xfrm_init_state

This patch adds xfrm_init_state which is simply a wrapper that calls
xfrm_get_type and subsequently x->type->init_state. It also gets rid
of the unused args argument.

Abstracting it out allows us to add common initialisation code, e.g.,
to set family-specific flags.

The add_time setting in xfrm_user.c was deleted because it's already
set by xfrm_state_alloc.

Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Acked-by: James Morris <jmorris@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>

authored by

Herbert Xu and committed by
David S. Miller
72cb6962 3f7a87d2

+38 -40
+2 -1
include/net/xfrm.h
··· 225 225 struct module *owner; 226 226 __u8 proto; 227 227 228 - int (*init_state)(struct xfrm_state *x, void *args); 228 + int (*init_state)(struct xfrm_state *x); 229 229 void (*destructor)(struct xfrm_state *); 230 230 int (*input)(struct xfrm_state *, struct xfrm_decap_state *, struct sk_buff *skb); 231 231 int (*post_input)(struct xfrm_state *, struct xfrm_decap_state *, struct sk_buff *skb); ··· 839 839 extern void xfrm_replay_advance(struct xfrm_state *x, u32 seq); 840 840 extern int xfrm_state_check(struct xfrm_state *x, struct sk_buff *skb); 841 841 extern int xfrm_state_mtu(struct xfrm_state *x, int mtu); 842 + extern int xfrm_init_state(struct xfrm_state *x); 842 843 extern int xfrm4_rcv(struct sk_buff *skb); 843 844 extern int xfrm4_output(struct sk_buff *skb); 844 845 extern int xfrm4_tunnel_register(struct xfrm_tunnel *handler);
+1 -1
net/ipv4/ah4.c
··· 200 200 xfrm_state_put(x); 201 201 } 202 202 203 - static int ah_init_state(struct xfrm_state *x, void *args) 203 + static int ah_init_state(struct xfrm_state *x) 204 204 { 205 205 struct ah_data *ahp = NULL; 206 206 struct xfrm_algo_desc *aalg_desc;
+1 -1
net/ipv4/esp4.c
··· 362 362 kfree(esp); 363 363 } 364 364 365 - static int esp_init_state(struct xfrm_state *x, void *args) 365 + static int esp_init_state(struct xfrm_state *x) 366 366 { 367 367 struct esp_data *esp = NULL; 368 368
+3 -8
net/ipv4/ipcomp.c
··· 236 236 t->props.mode = 1; 237 237 t->props.saddr.a4 = x->props.saddr.a4; 238 238 t->props.flags = x->props.flags; 239 - 240 - t->type = xfrm_get_type(IPPROTO_IPIP, t->props.family); 241 - if (t->type == NULL) 242 - goto error; 243 - 244 - if (t->type->init_state(t, NULL)) 239 + 240 + if (xfrm_init_state(t)) 245 241 goto error; 246 242 247 - t->km.state = XFRM_STATE_VALID; 248 243 atomic_set(&t->tunnel_users, 1); 249 244 out: 250 245 return t; ··· 417 422 kfree(ipcd); 418 423 } 419 424 420 - static int ipcomp_init_state(struct xfrm_state *x, void *args) 425 + static int ipcomp_init_state(struct xfrm_state *x) 421 426 { 422 427 int err; 423 428 struct ipcomp_data *ipcd;
+1 -1
net/ipv4/xfrm4_tunnel.c
··· 84 84 handler->err_handler(skb, &arg); 85 85 } 86 86 87 - static int ipip_init_state(struct xfrm_state *x, void *args) 87 + static int ipip_init_state(struct xfrm_state *x) 88 88 { 89 89 if (!x->props.mode) 90 90 return -EINVAL;
+1 -1
net/ipv6/ah6.c
··· 339 339 xfrm_state_put(x); 340 340 } 341 341 342 - static int ah6_init_state(struct xfrm_state *x, void *args) 342 + static int ah6_init_state(struct xfrm_state *x) 343 343 { 344 344 struct ah_data *ahp = NULL; 345 345 struct xfrm_algo_desc *aalg_desc;
+1 -1
net/ipv6/esp6.c
··· 296 296 kfree(esp); 297 297 } 298 298 299 - static int esp6_init_state(struct xfrm_state *x, void *args) 299 + static int esp6_init_state(struct xfrm_state *x) 300 300 { 301 301 struct esp_data *esp = NULL; 302 302
+2 -7
net/ipv6/ipcomp6.c
··· 234 234 t->props.mode = 1; 235 235 memcpy(t->props.saddr.a6, x->props.saddr.a6, sizeof(struct in6_addr)); 236 236 237 - t->type = xfrm_get_type(IPPROTO_IPV6, t->props.family); 238 - if (t->type == NULL) 237 + if (xfrm_init_state(t)) 239 238 goto error; 240 239 241 - if (t->type->init_state(t, NULL)) 242 - goto error; 243 - 244 - t->km.state = XFRM_STATE_VALID; 245 240 atomic_set(&t->tunnel_users, 1); 246 241 247 242 out: ··· 415 420 xfrm6_tunnel_free_spi((xfrm_address_t *)&x->props.saddr); 416 421 } 417 422 418 - static int ipcomp6_init_state(struct xfrm_state *x, void *args) 423 + static int ipcomp6_init_state(struct xfrm_state *x) 419 424 { 420 425 int err; 421 426 struct ipcomp_data *ipcd;
+1 -1
net/ipv6/xfrm6_tunnel.c
··· 466 466 return; 467 467 } 468 468 469 - static int xfrm6_tunnel_init_state(struct xfrm_state *x, void *args) 469 + static int xfrm6_tunnel_init_state(struct xfrm_state *x) 470 470 { 471 471 if (!x->props.mode) 472 472 return -EINVAL;
+3 -9
net/key/af_key.c
··· 1096 1096 } 1097 1097 } 1098 1098 1099 - x->type = xfrm_get_type(proto, x->props.family); 1100 - if (x->type == NULL) { 1101 - err = -ENOPROTOOPT; 1099 + err = xfrm_init_state(x); 1100 + if (err) 1102 1101 goto out; 1103 - } 1104 - if (x->type->init_state(x, NULL)) { 1105 - err = -EINVAL; 1106 - goto out; 1107 - } 1102 + 1108 1103 x->km.seq = hdr->sadb_msg_seq; 1109 - x->km.state = XFRM_STATE_VALID; 1110 1104 return x; 1111 1105 1112 1106 out:
-1
net/xfrm/xfrm_policy.c
··· 118 118 xfrm_policy_put_afinfo(afinfo); 119 119 return type; 120 120 } 121 - EXPORT_SYMBOL(xfrm_get_type); 122 121 123 122 int xfrm_dst_lookup(struct xfrm_dst **dst, struct flowi *fl, 124 123 unsigned short family)
+21
net/xfrm/xfrm_state.c
··· 1055 1055 } 1056 1056 1057 1057 EXPORT_SYMBOL(xfrm_state_mtu); 1058 + 1059 + int xfrm_init_state(struct xfrm_state *x) 1060 + { 1061 + int err; 1062 + 1063 + err = -ENOENT; 1064 + x->type = xfrm_get_type(x->id.proto, x->props.family); 1065 + if (x->type == NULL) 1066 + goto error; 1067 + 1068 + err = x->type->init_state(x); 1069 + if (err) 1070 + goto error; 1071 + 1072 + x->km.state = XFRM_STATE_VALID; 1073 + 1074 + error: 1075 + return err; 1076 + } 1077 + 1078 + EXPORT_SYMBOL(xfrm_init_state); 1058 1079 1059 1080 void __init xfrm_state_init(void) 1060 1081 {
+1 -8
net/xfrm/xfrm_user.c
··· 249 249 if ((err = attach_encap_tmpl(&x->encap, xfrma[XFRMA_ENCAP-1]))) 250 250 goto error; 251 251 252 - err = -ENOENT; 253 - x->type = xfrm_get_type(x->id.proto, x->props.family); 254 - if (x->type == NULL) 255 - goto error; 256 - 257 - err = x->type->init_state(x, NULL); 252 + err = xfrm_init_state(x); 258 253 if (err) 259 254 goto error; 260 255 261 - x->curlft.add_time = (unsigned long) xtime.tv_sec; 262 - x->km.state = XFRM_STATE_VALID; 263 256 x->km.seq = p->seq; 264 257 265 258 return x;