|
@@ -44,7 +44,8 @@ void __nf_ct_ext_destroy(struct nf_conn *ct)
|
|
|
EXPORT_SYMBOL(__nf_ct_ext_destroy);
|
|
|
|
|
|
static void *
|
|
|
-nf_ct_ext_create(struct nf_ct_ext **ext, enum nf_ct_ext_id id, gfp_t gfp)
|
|
|
+nf_ct_ext_create(struct nf_ct_ext **ext, enum nf_ct_ext_id id,
|
|
|
+ size_t var_alloc_len, gfp_t gfp)
|
|
|
{
|
|
|
unsigned int off, len;
|
|
|
struct nf_ct_ext_type *t;
|
|
@@ -54,8 +55,8 @@ nf_ct_ext_create(struct nf_ct_ext **ext, enum nf_ct_ext_id id, gfp_t gfp)
|
|
|
t = rcu_dereference(nf_ct_ext_types[id]);
|
|
|
BUG_ON(t == NULL);
|
|
|
off = ALIGN(sizeof(struct nf_ct_ext), t->align);
|
|
|
- len = off + t->len;
|
|
|
- alloc_size = t->alloc_size;
|
|
|
+ len = off + t->len + var_alloc_len;
|
|
|
+ alloc_size = t->alloc_size + var_alloc_len;
|
|
|
rcu_read_unlock();
|
|
|
|
|
|
*ext = kzalloc(alloc_size, gfp);
|
|
@@ -68,7 +69,8 @@ nf_ct_ext_create(struct nf_ct_ext **ext, enum nf_ct_ext_id id, gfp_t gfp)
|
|
|
return (void *)(*ext) + off;
|
|
|
}
|
|
|
|
|
|
-void *__nf_ct_ext_add(struct nf_conn *ct, enum nf_ct_ext_id id, gfp_t gfp)
|
|
|
+void *__nf_ct_ext_add_length(struct nf_conn *ct, enum nf_ct_ext_id id,
|
|
|
+ size_t var_alloc_len, gfp_t gfp)
|
|
|
{
|
|
|
struct nf_ct_ext *old, *new;
|
|
|
int i, newlen, newoff;
|
|
@@ -79,7 +81,7 @@ void *__nf_ct_ext_add(struct nf_conn *ct, enum nf_ct_ext_id id, gfp_t gfp)
|
|
|
|
|
|
old = ct->ext;
|
|
|
if (!old)
|
|
|
- return nf_ct_ext_create(&ct->ext, id, gfp);
|
|
|
+ return nf_ct_ext_create(&ct->ext, id, var_alloc_len, gfp);
|
|
|
|
|
|
if (__nf_ct_ext_exist(old, id))
|
|
|
return NULL;
|
|
@@ -89,7 +91,7 @@ void *__nf_ct_ext_add(struct nf_conn *ct, enum nf_ct_ext_id id, gfp_t gfp)
|
|
|
BUG_ON(t == NULL);
|
|
|
|
|
|
newoff = ALIGN(old->len, t->align);
|
|
|
- newlen = newoff + t->len;
|
|
|
+ newlen = newoff + t->len + var_alloc_len;
|
|
|
rcu_read_unlock();
|
|
|
|
|
|
new = __krealloc(old, newlen, gfp);
|
|
@@ -117,7 +119,7 @@ void *__nf_ct_ext_add(struct nf_conn *ct, enum nf_ct_ext_id id, gfp_t gfp)
|
|
|
memset((void *)new + newoff, 0, newlen - newoff);
|
|
|
return (void *)new + newoff;
|
|
|
}
|
|
|
-EXPORT_SYMBOL(__nf_ct_ext_add);
|
|
|
+EXPORT_SYMBOL(__nf_ct_ext_add_length);
|
|
|
|
|
|
static void update_alloc_size(struct nf_ct_ext_type *type)
|
|
|
{
|