|
@@ -190,7 +190,6 @@ static void ipcomp6_err(struct sk_buff *skb, struct inet6_skb_parm *opt,
|
|
static struct xfrm_state *ipcomp6_tunnel_create(struct xfrm_state *x)
|
|
static struct xfrm_state *ipcomp6_tunnel_create(struct xfrm_state *x)
|
|
{
|
|
{
|
|
struct xfrm_state *t = NULL;
|
|
struct xfrm_state *t = NULL;
|
|
- u8 mode = XFRM_MODE_TUNNEL;
|
|
|
|
|
|
|
|
t = xfrm_state_alloc();
|
|
t = xfrm_state_alloc();
|
|
if (!t)
|
|
if (!t)
|
|
@@ -204,9 +203,7 @@ static struct xfrm_state *ipcomp6_tunnel_create(struct xfrm_state *x)
|
|
memcpy(t->id.daddr.a6, x->id.daddr.a6, sizeof(struct in6_addr));
|
|
memcpy(t->id.daddr.a6, x->id.daddr.a6, sizeof(struct in6_addr));
|
|
memcpy(&t->sel, &x->sel, sizeof(t->sel));
|
|
memcpy(&t->sel, &x->sel, sizeof(t->sel));
|
|
t->props.family = AF_INET6;
|
|
t->props.family = AF_INET6;
|
|
- if (x->props.mode == XFRM_MODE_BEET)
|
|
|
|
- mode = x->props.mode;
|
|
|
|
- t->props.mode = mode;
|
|
|
|
|
|
+ t->props.mode = x->props.mode;
|
|
memcpy(t->props.saddr.a6, x->props.saddr.a6, sizeof(struct in6_addr));
|
|
memcpy(t->props.saddr.a6, x->props.saddr.a6, sizeof(struct in6_addr));
|
|
|
|
|
|
if (xfrm_init_state(t))
|
|
if (xfrm_init_state(t))
|
|
@@ -405,22 +402,22 @@ static int ipcomp6_init_state(struct xfrm_state *x)
|
|
if (x->encap)
|
|
if (x->encap)
|
|
goto out;
|
|
goto out;
|
|
|
|
|
|
- err = -ENOMEM;
|
|
|
|
- ipcd = kzalloc(sizeof(*ipcd), GFP_KERNEL);
|
|
|
|
- if (!ipcd)
|
|
|
|
- goto out;
|
|
|
|
-
|
|
|
|
x->props.header_len = 0;
|
|
x->props.header_len = 0;
|
|
switch (x->props.mode) {
|
|
switch (x->props.mode) {
|
|
- case XFRM_MODE_BEET:
|
|
|
|
case XFRM_MODE_TRANSPORT:
|
|
case XFRM_MODE_TRANSPORT:
|
|
break;
|
|
break;
|
|
case XFRM_MODE_TUNNEL:
|
|
case XFRM_MODE_TUNNEL:
|
|
x->props.header_len += sizeof(struct ipv6hdr);
|
|
x->props.header_len += sizeof(struct ipv6hdr);
|
|
|
|
+ break;
|
|
default:
|
|
default:
|
|
- goto error;
|
|
|
|
|
|
+ goto out;
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ err = -ENOMEM;
|
|
|
|
+ ipcd = kzalloc(sizeof(*ipcd), GFP_KERNEL);
|
|
|
|
+ if (!ipcd)
|
|
|
|
+ goto out;
|
|
|
|
+
|
|
mutex_lock(&ipcomp6_resource_mutex);
|
|
mutex_lock(&ipcomp6_resource_mutex);
|
|
if (!ipcomp6_alloc_scratches())
|
|
if (!ipcomp6_alloc_scratches())
|
|
goto error;
|
|
goto error;
|