|
|
@ -73,10 +73,11 @@ |
|
|
|
|
|
|
|
|
|
|
|
counters = alloc_counters(table);
|
|
|
|
counters = alloc_counters(table);
|
|
|
|
if (IS_ERR(counters))
|
|
|
|
if (IS_ERR(counters))
|
|
|
|
@@ -962,6 +988,14 @@ copy_entries_to_user(unsigned int total_
|
|
|
|
@@ -961,6 +987,14 @@ copy_entries_to_user(unsigned int total_
|
|
|
|
|
|
|
|
ret = -EFAULT;
|
|
|
|
goto free_counters;
|
|
|
|
goto free_counters;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
+
|
|
|
|
+ flags = e->ip.flags & IPT_F_MASK;
|
|
|
|
+ flags = e->ip.flags & IPT_F_MASK;
|
|
|
|
+ if (copy_to_user(userptr + off
|
|
|
|
+ if (copy_to_user(userptr + off
|
|
|
|
+ + offsetof(struct ipt_entry, ip.flags),
|
|
|
|
+ + offsetof(struct ipt_entry, ip.flags),
|
|
|
@ -84,7 +85,6 @@ |
|
|
|
+ ret = -EFAULT;
|
|
|
|
+ ret = -EFAULT;
|
|
|
|
+ goto free_counters;
|
|
|
|
+ goto free_counters;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
|
|
|
|
for (i = sizeof(struct ipt_entry);
|
|
|
|
for (i = sizeof(struct ipt_entry);
|
|
|
|
i < e->target_offset;
|
|
|
|
i < e->target_offset;
|
|
|
|
i += m->u.match_size) {
|
|
|
|
|
|
|
|