--- 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;