diff options
author | Haren Myneni <haren@us.ibm.com> | 2012-07-11 01:18:44 -0400 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2012-07-11 04:22:32 -0400 |
commit | e1612de9e4cdf375c3cf1c72434ab8abdcb3927e (patch) | |
tree | d2bf73a13ea6e92c9c79d4300294584ef82767c2 /drivers/char | |
parent | 475d0094293b51353e342d1198377967dbc48169 (diff) |
powerpc: Disable /dev/port interface on systems without an ISA bridge
Some power systems do not have legacy ISA devices. So, /dev/port is not
a valid interface on these systems. User level tools such as kbdrate is
trying to access the device using this interface which is causing the
system crash.
This patch will fix this issue by not creating this interface on these
powerpc systems.
Signed-off-by: Haren Myneni <haren@us.ibm.com>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'drivers/char')
-rw-r--r-- | drivers/char/mem.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/drivers/char/mem.c b/drivers/char/mem.c index 67c3371723cc..e5eedfa24c91 100644 --- a/drivers/char/mem.c +++ b/drivers/char/mem.c | |||
@@ -27,14 +27,16 @@ | |||
27 | #include <linux/splice.h> | 27 | #include <linux/splice.h> |
28 | #include <linux/pfn.h> | 28 | #include <linux/pfn.h> |
29 | #include <linux/export.h> | 29 | #include <linux/export.h> |
30 | #include <linux/io.h> | ||
30 | 31 | ||
31 | #include <asm/uaccess.h> | 32 | #include <asm/uaccess.h> |
32 | #include <asm/io.h> | ||
33 | 33 | ||
34 | #ifdef CONFIG_IA64 | 34 | #ifdef CONFIG_IA64 |
35 | # include <linux/efi.h> | 35 | # include <linux/efi.h> |
36 | #endif | 36 | #endif |
37 | 37 | ||
38 | #define DEVPORT_MINOR 4 | ||
39 | |||
38 | static inline unsigned long size_inside_page(unsigned long start, | 40 | static inline unsigned long size_inside_page(unsigned long start, |
39 | unsigned long size) | 41 | unsigned long size) |
40 | { | 42 | { |
@@ -894,6 +896,13 @@ static int __init chr_dev_init(void) | |||
894 | for (minor = 1; minor < ARRAY_SIZE(devlist); minor++) { | 896 | for (minor = 1; minor < ARRAY_SIZE(devlist); minor++) { |
895 | if (!devlist[minor].name) | 897 | if (!devlist[minor].name) |
896 | continue; | 898 | continue; |
899 | |||
900 | /* | ||
901 | * Create /dev/port? | ||
902 | */ | ||
903 | if ((minor == DEVPORT_MINOR) && !arch_has_dev_port()) | ||
904 | continue; | ||
905 | |||
897 | device_create(mem_class, NULL, MKDEV(MEM_MAJOR, minor), | 906 | device_create(mem_class, NULL, MKDEV(MEM_MAJOR, minor), |
898 | NULL, devlist[minor].name); | 907 | NULL, devlist[minor].name); |
899 | } | 908 | } |