If nft sets an invalid type, nftnl_obj_ops_lookup will return NULL.
In this case we must not set NFTNL_OBJ_TYPE flag, else we later get
crash in nftnl_obj_nlmsg_build_payload as it dereferences obj->ops.
Signed-off-by: Florian Westphal <fw@strlen.de>
Acked-by: Pablo Neira Ayuso <pablo@netfilter.org>
break;
case NFTNL_OBJ_TYPE:
obj->ops = nftnl_obj_ops_lookup(*((uint32_t *)data));
+ if (!obj->ops)
+ return;
break;
case NFTNL_OBJ_FAMILY:
obj->family = *((uint32_t *)data);
uint32_t type = ntohl(mnl_attr_get_u32(tb[NFTA_OBJ_TYPE]));
obj->ops = nftnl_obj_ops_lookup(type);
- obj->flags |= (1 << NFTNL_OBJ_TYPE);
+ if (obj->ops)
+ obj->flags |= (1 << NFTNL_OBJ_TYPE);
}
if (tb[NFTA_OBJ_DATA]) {
if (obj->ops) {