--- a/src/linux/xt_coova.c
|
|
+++ b/src/linux/xt_coova.c
|
|
@@ -292,6 +292,8 @@ static int coova_mt_check(const struct x
|
|
struct coova_table *t;
|
|
#ifdef CONFIG_PROC_FS
|
|
struct proc_dir_entry *pde;
|
|
+ kuid_t uid;
|
|
+ kgid_t gid;
|
|
#endif
|
|
unsigned i;
|
|
int ret = 0;
|
|
@@ -330,8 +332,9 @@ static int coova_mt_check(const struct x
|
|
ret = -ENOMEM;
|
|
goto out;
|
|
}
|
|
- pde->uid = ip_list_uid;
|
|
- pde->gid = ip_list_gid;
|
|
+ uid = make_kuid(&init_user_ns, ip_list_uid);
|
|
+ gid = make_kgid(&init_user_ns, ip_list_gid);
|
|
+ proc_set_user(pde, uid, gid);
|
|
#endif
|
|
spin_lock_bh(&coova_lock);
|
|
list_add_tail(&t->list, &tables);
|
|
@@ -445,14 +448,13 @@ static const struct seq_operations coova
|
|
|
|
static int coova_seq_open(struct inode *inode, struct file *file)
|
|
{
|
|
- struct proc_dir_entry *pde = PDE(inode);
|
|
struct coova_iter_state *st;
|
|
|
|
st = __seq_open_private(file, &coova_seq_ops, sizeof(*st));
|
|
if (st == NULL)
|
|
return -ENOMEM;
|
|
|
|
- st->table = pde->data;
|
|
+ st->table = PDE_DATA(inode);
|
|
return 0;
|
|
}
|
|
|
|
@@ -460,8 +462,7 @@ static ssize_t
|
|
coova_mt_proc_write(struct file *file, const char __user *input,
|
|
size_t size, loff_t *loff)
|
|
{
|
|
- const struct proc_dir_entry *pde = PDE(file->f_path.dentry->d_inode);
|
|
- struct coova_table *t = pde->data;
|
|
+ struct coova_table *t = PDE_DATA(file->f_path.dentry->d_inode);
|
|
struct coova_entry *e;
|
|
char buf[sizeof("+b335:1d35:1e55:dead:c0de:1715:5afe:c0de")];
|
|
const char *c = buf;
|