Commit c037773c authored by Al Viro's avatar Al Viro

rtl8192e: switch to proc_create()

Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent e3e7b40c
...@@ -208,39 +208,34 @@ static int debug = \ ...@@ -208,39 +208,34 @@ static int debug = \
; ;
static struct proc_dir_entry *rtllib_proc; static struct proc_dir_entry *rtllib_proc;
static int show_debug_level(char *page, char **start, off_t offset, static int show_debug_level(struct seq_file *m, void *v)
int count, int *eof, void *data)
{ {
return snprintf(page, count, "0x%08X\n", rtllib_debug_level); return seq_printf(m, "0x%08X\n", rtllib_debug_level);
} }
static int store_debug_level(struct file *file, const char __user *buffer, static ssize_t write_debug_level(struct file *file, const char __user *buffer,
unsigned long count, void *data) size_t count, loff_t *ppos)
{ {
char buf[] = "0x00000000";
unsigned long len = min((unsigned long)sizeof(buf) - 1, count);
char *p = (char *)buf;
unsigned long val; unsigned long val;
int err = kstrtoul_from_user(buffer, count, 0, &val);
if (copy_from_user(buf, buffer, len)) if (err)
return count; return err;
buf[len] = 0;
if (p[1] == 'x' || p[1] == 'X' || p[0] == 'x' || p[0] == 'X') {
p++;
if (p[0] == 'x' || p[0] == 'X')
p++;
val = simple_strtoul(p, &p, 16);
} else
val = simple_strtoul(p, &p, 10);
if (p == buf)
printk(KERN_INFO DRV_NAME
": %s is not in hex or decimal form.\n", buf);
else
rtllib_debug_level = val; rtllib_debug_level = val;
return count;
}
return strnlen(buf, count); static int open_debug_level(struct inode *inode, struct file *file)
{
return single_open(file, show_debug_level, NULL);
} }
static const struct file_operations fops = {
.open = open_debug_level,
.read = seq_read,
.llseek = seq_lseek,
.write = write_debug_level
};
int __init rtllib_init(void) int __init rtllib_init(void)
{ {
struct proc_dir_entry *e; struct proc_dir_entry *e;
...@@ -252,17 +247,12 @@ int __init rtllib_init(void) ...@@ -252,17 +247,12 @@ int __init rtllib_init(void)
" proc directory\n"); " proc directory\n");
return -EIO; return -EIO;
} }
e = create_proc_entry("debug_level", S_IFREG | S_IRUGO | S_IWUSR, e = proc_create("debug_level", S_IRUGO | S_IWUSR, rtllib_proc, &fops);
rtllib_proc);
if (!e) { if (!e) {
remove_proc_entry(DRV_NAME, init_net.proc_net); remove_proc_entry(DRV_NAME, init_net.proc_net);
rtllib_proc = NULL; rtllib_proc = NULL;
return -EIO; return -EIO;
} }
e->read_proc = show_debug_level;
e->write_proc = store_debug_level;
e->data = NULL;
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment