xfrm: ipcomp: add extack to ipcomp{4,6}_init_state
And the shared helper ipcomp_init_state. Signed-off-by: Sabrina Dubroca <sd@queasysnail.net> Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
This commit is contained in:
parent
25ec92cd04
commit
6ee5532052
@ -22,7 +22,7 @@ struct xfrm_state;
|
|||||||
int ipcomp_input(struct xfrm_state *x, struct sk_buff *skb);
|
int ipcomp_input(struct xfrm_state *x, struct sk_buff *skb);
|
||||||
int ipcomp_output(struct xfrm_state *x, struct sk_buff *skb);
|
int ipcomp_output(struct xfrm_state *x, struct sk_buff *skb);
|
||||||
void ipcomp_destroy(struct xfrm_state *x);
|
void ipcomp_destroy(struct xfrm_state *x);
|
||||||
int ipcomp_init_state(struct xfrm_state *x);
|
int ipcomp_init_state(struct xfrm_state *x, struct netlink_ext_ack *extack);
|
||||||
|
|
||||||
static inline struct ip_comp_hdr *ip_comp_hdr(const struct sk_buff *skb)
|
static inline struct ip_comp_hdr *ip_comp_hdr(const struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
|
@ -130,17 +130,20 @@ static int ipcomp4_init_state(struct xfrm_state *x,
|
|||||||
x->props.header_len += sizeof(struct iphdr);
|
x->props.header_len += sizeof(struct iphdr);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
NL_SET_ERR_MSG(extack, "Unsupported XFRM mode for IPcomp");
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = ipcomp_init_state(x);
|
err = ipcomp_init_state(x, extack);
|
||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (x->props.mode == XFRM_MODE_TUNNEL) {
|
if (x->props.mode == XFRM_MODE_TUNNEL) {
|
||||||
err = ipcomp_tunnel_attach(x);
|
err = ipcomp_tunnel_attach(x);
|
||||||
if (err)
|
if (err) {
|
||||||
|
NL_SET_ERR_MSG(extack, "Kernel error: failed to initialize the associated state");
|
||||||
goto out;
|
goto out;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
err = 0;
|
err = 0;
|
||||||
|
@ -149,17 +149,20 @@ static int ipcomp6_init_state(struct xfrm_state *x,
|
|||||||
x->props.header_len += sizeof(struct ipv6hdr);
|
x->props.header_len += sizeof(struct ipv6hdr);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
NL_SET_ERR_MSG(extack, "Unsupported XFRM mode for IPcomp");
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = ipcomp_init_state(x);
|
err = ipcomp_init_state(x, extack);
|
||||||
if (err)
|
if (err)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
if (x->props.mode == XFRM_MODE_TUNNEL) {
|
if (x->props.mode == XFRM_MODE_TUNNEL) {
|
||||||
err = ipcomp6_tunnel_attach(x);
|
err = ipcomp6_tunnel_attach(x);
|
||||||
if (err)
|
if (err) {
|
||||||
|
NL_SET_ERR_MSG(extack, "Kernel error: failed to initialize the associated state");
|
||||||
goto out;
|
goto out;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
err = 0;
|
err = 0;
|
||||||
|
@ -325,18 +325,22 @@ void ipcomp_destroy(struct xfrm_state *x)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(ipcomp_destroy);
|
EXPORT_SYMBOL_GPL(ipcomp_destroy);
|
||||||
|
|
||||||
int ipcomp_init_state(struct xfrm_state *x)
|
int ipcomp_init_state(struct xfrm_state *x, struct netlink_ext_ack *extack)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
struct ipcomp_data *ipcd;
|
struct ipcomp_data *ipcd;
|
||||||
struct xfrm_algo_desc *calg_desc;
|
struct xfrm_algo_desc *calg_desc;
|
||||||
|
|
||||||
err = -EINVAL;
|
err = -EINVAL;
|
||||||
if (!x->calg)
|
if (!x->calg) {
|
||||||
|
NL_SET_ERR_MSG(extack, "Missing required compression algorithm");
|
||||||
goto out;
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
if (x->encap)
|
if (x->encap) {
|
||||||
|
NL_SET_ERR_MSG(extack, "IPComp is not compatible with encapsulation");
|
||||||
goto out;
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
err = -ENOMEM;
|
err = -ENOMEM;
|
||||||
ipcd = kzalloc(sizeof(*ipcd), GFP_KERNEL);
|
ipcd = kzalloc(sizeof(*ipcd), GFP_KERNEL);
|
||||||
|
Loading…
Reference in New Issue
Block a user