diff options
Diffstat (limited to 'drivers/char/nsc_gpio.c')
-rw-r--r-- | drivers/char/nsc_gpio.c | 45 |
1 files changed, 25 insertions, 20 deletions
diff --git a/drivers/char/nsc_gpio.c b/drivers/char/nsc_gpio.c index 929d68486c1a..d0b5d65a73fb 100644 --- a/drivers/char/nsc_gpio.c +++ b/drivers/char/nsc_gpio.c | |||
@@ -14,22 +14,27 @@ | |||
14 | #include <linux/kernel.h> | 14 | #include <linux/kernel.h> |
15 | #include <linux/init.h> | 15 | #include <linux/init.h> |
16 | #include <linux/nsc_gpio.h> | 16 | #include <linux/nsc_gpio.h> |
17 | #include <linux/platform_device.h> | ||
17 | #include <asm/uaccess.h> | 18 | #include <asm/uaccess.h> |
18 | #include <asm/io.h> | 19 | #include <asm/io.h> |
19 | 20 | ||
20 | #define NAME "nsc_gpio" | 21 | #define NAME "nsc_gpio" |
21 | 22 | ||
22 | void nsc_gpio_dump(unsigned index, u32 config) | 23 | void nsc_gpio_dump(struct nsc_gpio_ops *amp, unsigned index) |
23 | { | 24 | { |
24 | printk(KERN_INFO NAME ": GPIO-%02u: 0x%08lx %s %s %s %s %s %s %s\n", | 25 | /* retrieve current config w/o changing it */ |
25 | index, (unsigned long)config, | 26 | u32 config = amp->gpio_config(index, ~0, 0); |
26 | (config & 1) ? "OE" : "TS", /* output-enabled/tristate */ | 27 | |
27 | (config & 2) ? "PP" : "OD", /* push pull / open drain */ | 28 | /* user requested via 'v' command, so its INFO */ |
28 | (config & 4) ? "PUE" : "PUD", /* pull up enabled/disabled */ | 29 | dev_info(amp->dev, "io%02u: 0x%04x %s %s %s %s %s %s %s\n", |
29 | (config & 8) ? "LOCKED" : "", /* locked / unlocked */ | 30 | index, config, |
30 | (config & 16) ? "LEVEL" : "EDGE",/* level/edge input */ | 31 | (config & 1) ? "OE" : "TS", /* output-enabled/tristate */ |
31 | (config & 32) ? "HI" : "LO", /* trigger on rise/fall edge */ | 32 | (config & 2) ? "PP" : "OD", /* push pull / open drain */ |
32 | (config & 64) ? "DEBOUNCE" : ""); /* debounce */ | 33 | (config & 4) ? "PUE" : "PUD", /* pull up enabled/disabled */ |
34 | (config & 8) ? "LOCKED" : "", /* locked / unlocked */ | ||
35 | (config & 16) ? "LEVEL" : "EDGE",/* level/edge input */ | ||
36 | (config & 32) ? "HI" : "LO", /* trigger on rise/fall edge */ | ||
37 | (config & 64) ? "DEBOUNCE" : ""); /* debounce */ | ||
33 | } | 38 | } |
34 | 39 | ||
35 | ssize_t nsc_gpio_write(struct file *file, const char __user *data, | 40 | ssize_t nsc_gpio_write(struct file *file, const char __user *data, |
@@ -37,6 +42,7 @@ ssize_t nsc_gpio_write(struct file *file, const char __user *data, | |||
37 | { | 42 | { |
38 | unsigned m = iminor(file->f_dentry->d_inode); | 43 | unsigned m = iminor(file->f_dentry->d_inode); |
39 | struct nsc_gpio_ops *amp = file->private_data; | 44 | struct nsc_gpio_ops *amp = file->private_data; |
45 | struct device *dev = amp->dev; | ||
40 | size_t i; | 46 | size_t i; |
41 | int err = 0; | 47 | int err = 0; |
42 | 48 | ||
@@ -52,42 +58,41 @@ ssize_t nsc_gpio_write(struct file *file, const char __user *data, | |||
52 | amp->gpio_set(m, 1); | 58 | amp->gpio_set(m, 1); |
53 | break; | 59 | break; |
54 | case 'O': | 60 | case 'O': |
55 | printk(KERN_INFO NAME ": GPIO%d output enabled\n", m); | 61 | dev_dbg(dev, "GPIO%d output enabled\n", m); |
56 | amp->gpio_config(m, ~1, 1); | 62 | amp->gpio_config(m, ~1, 1); |
57 | break; | 63 | break; |
58 | case 'o': | 64 | case 'o': |
59 | printk(KERN_INFO NAME ": GPIO%d output disabled\n", m); | 65 | dev_dbg(dev, "GPIO%d output disabled\n", m); |
60 | amp->gpio_config(m, ~1, 0); | 66 | amp->gpio_config(m, ~1, 0); |
61 | break; | 67 | break; |
62 | case 'T': | 68 | case 'T': |
63 | printk(KERN_INFO NAME ": GPIO%d output is push pull\n", | 69 | dev_dbg(dev, "GPIO%d output is push pull\n", |
64 | m); | 70 | m); |
65 | amp->gpio_config(m, ~2, 2); | 71 | amp->gpio_config(m, ~2, 2); |
66 | break; | 72 | break; |
67 | case 't': | 73 | case 't': |
68 | printk(KERN_INFO NAME ": GPIO%d output is open drain\n", | 74 | dev_dbg(dev, "GPIO%d output is open drain\n", |
69 | m); | 75 | m); |
70 | amp->gpio_config(m, ~2, 0); | 76 | amp->gpio_config(m, ~2, 0); |
71 | break; | 77 | break; |
72 | case 'P': | 78 | case 'P': |
73 | printk(KERN_INFO NAME ": GPIO%d pull up enabled\n", m); | 79 | dev_dbg(dev, "GPIO%d pull up enabled\n", m); |
74 | amp->gpio_config(m, ~4, 4); | 80 | amp->gpio_config(m, ~4, 4); |
75 | break; | 81 | break; |
76 | case 'p': | 82 | case 'p': |
77 | printk(KERN_INFO NAME ": GPIO%d pull up disabled\n", m); | 83 | dev_dbg(dev, "GPIO%d pull up disabled\n", m); |
78 | amp->gpio_config(m, ~4, 0); | 84 | amp->gpio_config(m, ~4, 0); |
79 | break; | 85 | break; |
80 | case 'v': | 86 | case 'v': |
81 | /* View Current pin settings */ | 87 | /* View Current pin settings */ |
82 | amp->gpio_dump(m); | 88 | amp->gpio_dump(amp, m); |
83 | break; | 89 | break; |
84 | case '\n': | 90 | case '\n': |
85 | /* end of settings string, do nothing */ | 91 | /* end of settings string, do nothing */ |
86 | break; | 92 | break; |
87 | default: | 93 | default: |
88 | printk(KERN_ERR NAME | 94 | dev_err(dev, "io%2d bad setting: chr<0x%2x>\n", |
89 | ": GPIO-%2d bad setting: chr<0x%2x>\n", m, | 95 | m, (int)c); |
90 | (int)c); | ||
91 | err++; | 96 | err++; |
92 | } | 97 | } |
93 | } | 98 | } |