diff options
| -rw-r--r-- | arch/m68k/include/asm/string.h | 4 | ||||
| -rw-r--r-- | arch/m68k/lib/string.c | 11 | ||||
| -rw-r--r-- | arch/m68knommu/kernel/vmlinux.lds.S | 6 | ||||
| -rw-r--r-- | arch/m68knommu/lib/Makefile | 2 | ||||
| -rw-r--r-- | arch/m68knommu/lib/memmove.c | 105 | ||||
| -rw-r--r-- | arch/m68knommu/platform/5249/intc2.c | 4 | ||||
| -rw-r--r-- | arch/m68knommu/platform/68328/entry.S | 1 | ||||
| -rw-r--r-- | arch/m68knommu/platform/68360/commproc.c | 2 | ||||
| -rw-r--r-- | arch/m68knommu/platform/68360/config.c | 2 | ||||
| -rw-r--r-- | arch/m68knommu/platform/68360/entry.S | 1 | ||||
| -rw-r--r-- | arch/m68knommu/platform/68360/ints.c | 4 | ||||
| -rw-r--r-- | arch/m68knommu/platform/coldfire/entry.S | 1 | ||||
| -rw-r--r-- | drivers/net/can/mscan/Kconfig | 2 | ||||
| -rw-r--r-- | drivers/tty/serial/68328serial.c | 29 | ||||
| -rw-r--r-- | drivers/watchdog/Kconfig | 6 | ||||
| -rw-r--r-- | drivers/watchdog/Makefile | 2 | ||||
| -rw-r--r-- | drivers/watchdog/m54xx_wdt.c (renamed from drivers/watchdog/m548x_wdt.c) | 50 | ||||
| -rw-r--r-- | lib/Kconfig.debug | 2 |
18 files changed, 165 insertions, 69 deletions
diff --git a/arch/m68k/include/asm/string.h b/arch/m68k/include/asm/string.h index 65b131282837..32198454da70 100644 --- a/arch/m68k/include/asm/string.h +++ b/arch/m68k/include/asm/string.h | |||
| @@ -99,14 +99,12 @@ static inline int strcmp(const char *cs, const char *ct) | |||
| 99 | : "+a" (cs), "+a" (ct), "=d" (res)); | 99 | : "+a" (cs), "+a" (ct), "=d" (res)); |
| 100 | return res; | 100 | return res; |
| 101 | } | 101 | } |
| 102 | #endif /* CONFIG_COLDFIRE */ | ||
| 102 | 103 | ||
| 103 | #define __HAVE_ARCH_MEMMOVE | 104 | #define __HAVE_ARCH_MEMMOVE |
| 104 | extern void *memmove(void *, const void *, __kernel_size_t); | 105 | extern void *memmove(void *, const void *, __kernel_size_t); |
| 105 | 106 | ||
| 106 | #define __HAVE_ARCH_MEMCMP | ||
| 107 | extern int memcmp(const void *, const void *, __kernel_size_t); | ||
| 108 | #define memcmp(d, s, n) __builtin_memcmp(d, s, n) | 107 | #define memcmp(d, s, n) __builtin_memcmp(d, s, n) |
| 109 | #endif /* CONFIG_COLDFIRE */ | ||
| 110 | 108 | ||
| 111 | #define __HAVE_ARCH_MEMSET | 109 | #define __HAVE_ARCH_MEMSET |
| 112 | extern void *memset(void *, int, __kernel_size_t); | 110 | extern void *memset(void *, int, __kernel_size_t); |
diff --git a/arch/m68k/lib/string.c b/arch/m68k/lib/string.c index 4253f870e54f..d399c5f25636 100644 --- a/arch/m68k/lib/string.c +++ b/arch/m68k/lib/string.c | |||
| @@ -243,14 +243,3 @@ void *memmove(void *dest, const void *src, size_t n) | |||
| 243 | return xdest; | 243 | return xdest; |
| 244 | } | 244 | } |
| 245 | EXPORT_SYMBOL(memmove); | 245 | EXPORT_SYMBOL(memmove); |
| 246 | |||
| 247 | int memcmp(const void *cs, const void *ct, size_t count) | ||
| 248 | { | ||
| 249 | const unsigned char *su1, *su2; | ||
| 250 | |||
| 251 | for (su1 = cs, su2 = ct; count > 0; ++su1, ++su2, count--) | ||
| 252 | if (*su1 != *su2) | ||
| 253 | return *su1 < *su2 ? -1 : +1; | ||
| 254 | return 0; | ||
| 255 | } | ||
| 256 | EXPORT_SYMBOL(memcmp); | ||
diff --git a/arch/m68knommu/kernel/vmlinux.lds.S b/arch/m68knommu/kernel/vmlinux.lds.S index ef332136f96d..47e15ebfd893 100644 --- a/arch/m68knommu/kernel/vmlinux.lds.S +++ b/arch/m68knommu/kernel/vmlinux.lds.S | |||
| @@ -141,6 +141,12 @@ SECTIONS { | |||
| 141 | *(__param) | 141 | *(__param) |
| 142 | __stop___param = .; | 142 | __stop___param = .; |
| 143 | 143 | ||
| 144 | /* Built-in module versions */ | ||
| 145 | . = ALIGN(4) ; | ||
| 146 | __start___modver = .; | ||
| 147 | *(__modver) | ||
| 148 | __stop___modver = .; | ||
| 149 | |||
| 144 | . = ALIGN(4) ; | 150 | . = ALIGN(4) ; |
| 145 | _etext = . ; | 151 | _etext = . ; |
| 146 | } > TEXT | 152 | } > TEXT |
diff --git a/arch/m68knommu/lib/Makefile b/arch/m68knommu/lib/Makefile index d94d709665aa..32d852e586d7 100644 --- a/arch/m68knommu/lib/Makefile +++ b/arch/m68knommu/lib/Makefile | |||
| @@ -4,4 +4,4 @@ | |||
| 4 | 4 | ||
| 5 | lib-y := ashldi3.o ashrdi3.o lshrdi3.o \ | 5 | lib-y := ashldi3.o ashrdi3.o lshrdi3.o \ |
| 6 | muldi3.o mulsi3.o divsi3.o udivsi3.o modsi3.o umodsi3.o \ | 6 | muldi3.o mulsi3.o divsi3.o udivsi3.o modsi3.o umodsi3.o \ |
| 7 | checksum.o memcpy.o memset.o delay.o | 7 | checksum.o memcpy.o memmove.o memset.o delay.o |
diff --git a/arch/m68knommu/lib/memmove.c b/arch/m68knommu/lib/memmove.c new file mode 100644 index 000000000000..b3dcfe9dab7e --- /dev/null +++ b/arch/m68knommu/lib/memmove.c | |||
| @@ -0,0 +1,105 @@ | |||
| 1 | /* | ||
| 2 | * This file is subject to the terms and conditions of the GNU General Public | ||
| 3 | * License. See the file COPYING in the main directory of this archive | ||
| 4 | * for more details. | ||
| 5 | */ | ||
| 6 | |||
| 7 | #define __IN_STRING_C | ||
| 8 | |||
| 9 | #include <linux/module.h> | ||
| 10 | #include <linux/string.h> | ||
| 11 | |||
| 12 | void *memmove(void *dest, const void *src, size_t n) | ||
| 13 | { | ||
| 14 | void *xdest = dest; | ||
| 15 | size_t temp; | ||
| 16 | |||
| 17 | if (!n) | ||
| 18 | return xdest; | ||
| 19 | |||
| 20 | if (dest < src) { | ||
| 21 | if ((long)dest & 1) { | ||
| 22 | char *cdest = dest; | ||
| 23 | const char *csrc = src; | ||
| 24 | *cdest++ = *csrc++; | ||
| 25 | dest = cdest; | ||
| 26 | src = csrc; | ||
| 27 | n--; | ||
| 28 | } | ||
| 29 | if (n > 2 && (long)dest & 2) { | ||
| 30 | short *sdest = dest; | ||
| 31 | const short *ssrc = src; | ||
| 32 | *sdest++ = *ssrc++; | ||
| 33 | dest = sdest; | ||
| 34 | src = ssrc; | ||
| 35 | n -= 2; | ||
| 36 | } | ||
| 37 | temp = n >> 2; | ||
| 38 | if (temp) { | ||
| 39 | long *ldest = dest; | ||
| 40 | const long *lsrc = src; | ||
| 41 | temp--; | ||
| 42 | do | ||
| 43 | *ldest++ = *lsrc++; | ||
| 44 | while (temp--); | ||
| 45 | dest = ldest; | ||
| 46 | src = lsrc; | ||
| 47 | } | ||
| 48 | if (n & 2) { | ||
| 49 | short *sdest = dest; | ||
| 50 | const short *ssrc = src; | ||
| 51 | *sdest++ = *ssrc++; | ||
| 52 | dest = sdest; | ||
| 53 | src = ssrc; | ||
| 54 | } | ||
| 55 | if (n & 1) { | ||
| 56 | char *cdest = dest; | ||
| 57 | const char *csrc = src; | ||
| 58 | *cdest = *csrc; | ||
| 59 | } | ||
| 60 | } else { | ||
| 61 | dest = (char *)dest + n; | ||
| 62 | src = (const char *)src + n; | ||
| 63 | if ((long)dest & 1) { | ||
| 64 | char *cdest = dest; | ||
| 65 | const char *csrc = src; | ||
| 66 | *--cdest = *--csrc; | ||
| 67 | dest = cdest; | ||
| 68 | src = csrc; | ||
| 69 | n--; | ||
| 70 | } | ||
| 71 | if (n > 2 && (long)dest & 2) { | ||
| 72 | short *sdest = dest; | ||
| 73 | const short *ssrc = src; | ||
| 74 | *--sdest = *--ssrc; | ||
| 75 | dest = sdest; | ||
| 76 | src = ssrc; | ||
| 77 | n -= 2; | ||
| 78 | } | ||
| 79 | temp = n >> 2; | ||
| 80 | if (temp) { | ||
| 81 | long *ldest = dest; | ||
| 82 | const long *lsrc = src; | ||
| 83 | temp--; | ||
| 84 | do | ||
| 85 | *--ldest = *--lsrc; | ||
| 86 | while (temp--); | ||
| 87 | dest = ldest; | ||
| 88 | src = lsrc; | ||
| 89 | } | ||
| 90 | if (n & 2) { | ||
| 91 | short *sdest = dest; | ||
| 92 | const short *ssrc = src; | ||
| 93 | *--sdest = *--ssrc; | ||
| 94 | dest = sdest; | ||
| 95 | src = ssrc; | ||
| 96 | } | ||
| 97 | if (n & 1) { | ||
| 98 | char *cdest = dest; | ||
| 99 | const char *csrc = src; | ||
| 100 | *--cdest = *--csrc; | ||
| 101 | } | ||
| 102 | } | ||
| 103 | return xdest; | ||
| 104 | } | ||
| 105 | EXPORT_SYMBOL(memmove); | ||
diff --git a/arch/m68knommu/platform/5249/intc2.c b/arch/m68knommu/platform/5249/intc2.c index d09d9da04537..c5151f846591 100644 --- a/arch/m68knommu/platform/5249/intc2.c +++ b/arch/m68knommu/platform/5249/intc2.c | |||
| @@ -50,8 +50,10 @@ static int __init mcf_intc2_init(void) | |||
| 50 | int irq; | 50 | int irq; |
| 51 | 51 | ||
| 52 | /* GPIO interrupt sources */ | 52 | /* GPIO interrupt sources */ |
| 53 | for (irq = MCFINTC2_GPIOIRQ0; (irq <= MCFINTC2_GPIOIRQ7); irq++) | 53 | for (irq = MCFINTC2_GPIOIRQ0; (irq <= MCFINTC2_GPIOIRQ7); irq++) { |
| 54 | irq_desc[irq].chip = &intc2_irq_gpio_chip; | 54 | irq_desc[irq].chip = &intc2_irq_gpio_chip; |
| 55 | set_irq_handler(irq, handle_edge_irq); | ||
| 56 | } | ||
| 55 | 57 | ||
| 56 | return 0; | 58 | return 0; |
| 57 | } | 59 | } |
diff --git a/arch/m68knommu/platform/68328/entry.S b/arch/m68knommu/platform/68328/entry.S index 240a7a6e25c8..676960cf022a 100644 --- a/arch/m68knommu/platform/68328/entry.S +++ b/arch/m68knommu/platform/68328/entry.S | |||
| @@ -108,7 +108,6 @@ Luser_return: | |||
| 108 | movel %d1,%a2 | 108 | movel %d1,%a2 |
| 109 | 1: | 109 | 1: |
| 110 | move %a2@(TI_FLAGS),%d1 /* thread_info->flags */ | 110 | move %a2@(TI_FLAGS),%d1 /* thread_info->flags */ |
| 111 | andl #_TIF_WORK_MASK,%d1 | ||
| 112 | jne Lwork_to_do | 111 | jne Lwork_to_do |
| 113 | RESTORE_ALL | 112 | RESTORE_ALL |
| 114 | 113 | ||
diff --git a/arch/m68knommu/platform/68360/commproc.c b/arch/m68knommu/platform/68360/commproc.c index f27e688c404e..8e4e10cc0080 100644 --- a/arch/m68knommu/platform/68360/commproc.c +++ b/arch/m68knommu/platform/68360/commproc.c | |||
| @@ -210,7 +210,7 @@ void | |||
| 210 | cpm_install_handler(int vec, void (*handler)(), void *dev_id) | 210 | cpm_install_handler(int vec, void (*handler)(), void *dev_id) |
| 211 | { | 211 | { |
| 212 | 212 | ||
| 213 | request_irq(vec, handler, IRQ_FLG_LOCK, "timer", dev_id); | 213 | request_irq(vec, handler, 0, "timer", dev_id); |
| 214 | 214 | ||
| 215 | /* if (cpm_vecs[vec].handler != 0) */ | 215 | /* if (cpm_vecs[vec].handler != 0) */ |
| 216 | /* printk(KERN_INFO "CPM interrupt %x replacing %x\n", */ | 216 | /* printk(KERN_INFO "CPM interrupt %x replacing %x\n", */ |
diff --git a/arch/m68knommu/platform/68360/config.c b/arch/m68knommu/platform/68360/config.c index ac629fa30099..9dd5bca38749 100644 --- a/arch/m68knommu/platform/68360/config.c +++ b/arch/m68knommu/platform/68360/config.c | |||
| @@ -75,7 +75,7 @@ void hw_timer_init(void) | |||
| 75 | /* Set compare register 32Khz / 32 / 10 = 100 */ | 75 | /* Set compare register 32Khz / 32 / 10 = 100 */ |
| 76 | TCMP = 10; | 76 | TCMP = 10; |
| 77 | 77 | ||
| 78 | request_irq(IRQ_MACHSPEC | 1, timer_routine, IRQ_FLG_LOCK, "timer", NULL); | 78 | request_irq(IRQ_MACHSPEC | 1, timer_routine, 0, "timer", NULL); |
| 79 | #endif | 79 | #endif |
| 80 | 80 | ||
| 81 | /* General purpose quicc timers: MC68360UM p7-20 */ | 81 | /* General purpose quicc timers: MC68360UM p7-20 */ |
diff --git a/arch/m68knommu/platform/68360/entry.S b/arch/m68knommu/platform/68360/entry.S index 8a28788c0eea..46c1b18c9dcb 100644 --- a/arch/m68knommu/platform/68360/entry.S +++ b/arch/m68knommu/platform/68360/entry.S | |||
| @@ -104,7 +104,6 @@ Luser_return: | |||
| 104 | movel %d1,%a2 | 104 | movel %d1,%a2 |
| 105 | 1: | 105 | 1: |
| 106 | move %a2@(TI_FLAGS),%d1 /* thread_info->flags */ | 106 | move %a2@(TI_FLAGS),%d1 /* thread_info->flags */ |
| 107 | andl #_TIF_WORK_MASK,%d1 | ||
| 108 | jne Lwork_to_do | 107 | jne Lwork_to_do |
| 109 | RESTORE_ALL | 108 | RESTORE_ALL |
| 110 | 109 | ||
diff --git a/arch/m68knommu/platform/68360/ints.c b/arch/m68knommu/platform/68360/ints.c index ad96ab1051f0..a29041c1a8a0 100644 --- a/arch/m68knommu/platform/68360/ints.c +++ b/arch/m68knommu/platform/68360/ints.c | |||
| @@ -132,8 +132,8 @@ void init_IRQ(void) | |||
| 132 | pquicc->intr_cimr = 0x00000000; | 132 | pquicc->intr_cimr = 0x00000000; |
| 133 | 133 | ||
| 134 | for (i = 0; (i < NR_IRQS); i++) { | 134 | for (i = 0; (i < NR_IRQS); i++) { |
| 135 | set_irq_chip(irq, &intc_irq_chip); | 135 | set_irq_chip(i, &intc_irq_chip); |
| 136 | set_irq_handler(irq, handle_level_irq); | 136 | set_irq_handler(i, handle_level_irq); |
| 137 | } | 137 | } |
| 138 | } | 138 | } |
| 139 | 139 | ||
diff --git a/arch/m68knommu/platform/coldfire/entry.S b/arch/m68knommu/platform/coldfire/entry.S index 4ddfc3da70d8..5837cf080b6d 100644 --- a/arch/m68knommu/platform/coldfire/entry.S +++ b/arch/m68knommu/platform/coldfire/entry.S | |||
| @@ -138,7 +138,6 @@ Luser_return: | |||
| 138 | andl #-THREAD_SIZE,%d1 /* at base of kernel stack */ | 138 | andl #-THREAD_SIZE,%d1 /* at base of kernel stack */ |
| 139 | movel %d1,%a0 | 139 | movel %d1,%a0 |
| 140 | movel %a0@(TI_FLAGS),%d1 /* get thread_info->flags */ | 140 | movel %a0@(TI_FLAGS),%d1 /* get thread_info->flags */ |
| 141 | andl #0xefff,%d1 | ||
| 142 | jne Lwork_to_do /* still work to do */ | 141 | jne Lwork_to_do /* still work to do */ |
| 143 | 142 | ||
| 144 | Lreturn: | 143 | Lreturn: |
diff --git a/drivers/net/can/mscan/Kconfig b/drivers/net/can/mscan/Kconfig index 27d1d398e25e..d38706958af6 100644 --- a/drivers/net/can/mscan/Kconfig +++ b/drivers/net/can/mscan/Kconfig | |||
| @@ -1,5 +1,5 @@ | |||
| 1 | config CAN_MSCAN | 1 | config CAN_MSCAN |
| 2 | depends on CAN_DEV && (PPC || M68K || M68KNOMMU) | 2 | depends on CAN_DEV && (PPC || M68K) |
| 3 | tristate "Support for Freescale MSCAN based chips" | 3 | tristate "Support for Freescale MSCAN based chips" |
| 4 | ---help--- | 4 | ---help--- |
| 5 | The Motorola Scalable Controller Area Network (MSCAN) definition | 5 | The Motorola Scalable Controller Area Network (MSCAN) definition |
diff --git a/drivers/tty/serial/68328serial.c b/drivers/tty/serial/68328serial.c index be0ebce36e54..de0160e3f8c4 100644 --- a/drivers/tty/serial/68328serial.c +++ b/drivers/tty/serial/68328serial.c | |||
| @@ -262,7 +262,7 @@ static void status_handle(struct m68k_serial *info, unsigned short status) | |||
| 262 | 262 | ||
| 263 | static void receive_chars(struct m68k_serial *info, unsigned short rx) | 263 | static void receive_chars(struct m68k_serial *info, unsigned short rx) |
| 264 | { | 264 | { |
| 265 | struct tty_struct *tty = info->port.tty; | 265 | struct tty_struct *tty = info->tty; |
| 266 | m68328_uart *uart = &uart_addr[info->line]; | 266 | m68328_uart *uart = &uart_addr[info->line]; |
| 267 | unsigned char ch, flag; | 267 | unsigned char ch, flag; |
| 268 | 268 | ||
| @@ -329,7 +329,7 @@ static void transmit_chars(struct m68k_serial *info) | |||
| 329 | goto clear_and_return; | 329 | goto clear_and_return; |
| 330 | } | 330 | } |
| 331 | 331 | ||
| 332 | if((info->xmit_cnt <= 0) || info->port.tty->stopped) { | 332 | if((info->xmit_cnt <= 0) || info->tty->stopped) { |
| 333 | /* That's peculiar... TX ints off */ | 333 | /* That's peculiar... TX ints off */ |
| 334 | uart->ustcnt &= ~USTCNT_TX_INTR_MASK; | 334 | uart->ustcnt &= ~USTCNT_TX_INTR_MASK; |
| 335 | goto clear_and_return; | 335 | goto clear_and_return; |
| @@ -383,7 +383,7 @@ static void do_softint(struct work_struct *work) | |||
| 383 | struct m68k_serial *info = container_of(work, struct m68k_serial, tqueue); | 383 | struct m68k_serial *info = container_of(work, struct m68k_serial, tqueue); |
| 384 | struct tty_struct *tty; | 384 | struct tty_struct *tty; |
| 385 | 385 | ||
| 386 | tty = info->port.tty; | 386 | tty = info->tty; |
| 387 | if (!tty) | 387 | if (!tty) |
| 388 | return; | 388 | return; |
| 389 | #if 0 | 389 | #if 0 |
| @@ -407,7 +407,7 @@ static void do_serial_hangup(struct work_struct *work) | |||
| 407 | struct m68k_serial *info = container_of(work, struct m68k_serial, tqueue_hangup); | 407 | struct m68k_serial *info = container_of(work, struct m68k_serial, tqueue_hangup); |
| 408 | struct tty_struct *tty; | 408 | struct tty_struct *tty; |
| 409 | 409 | ||
| 410 | tty = info->port.tty; | 410 | tty = info->tty; |
| 411 | if (!tty) | 411 | if (!tty) |
| 412 | return; | 412 | return; |
| 413 | 413 | ||
| @@ -451,8 +451,8 @@ static int startup(struct m68k_serial * info) | |||
| 451 | uart->ustcnt = USTCNT_UEN | USTCNT_RXEN | USTCNT_RX_INTR_MASK; | 451 | uart->ustcnt = USTCNT_UEN | USTCNT_RXEN | USTCNT_RX_INTR_MASK; |
| 452 | #endif | 452 | #endif |
| 453 | 453 | ||
| 454 | if (info->port.tty) | 454 | if (info->tty) |
| 455 | clear_bit(TTY_IO_ERROR, &info->port.tty->flags); | 455 | clear_bit(TTY_IO_ERROR, &info->tty->flags); |
| 456 | info->xmit_cnt = info->xmit_head = info->xmit_tail = 0; | 456 | info->xmit_cnt = info->xmit_head = info->xmit_tail = 0; |
| 457 | 457 | ||
| 458 | /* | 458 | /* |
| @@ -486,8 +486,8 @@ static void shutdown(struct m68k_serial * info) | |||
| 486 | info->xmit_buf = 0; | 486 | info->xmit_buf = 0; |
| 487 | } | 487 | } |
| 488 | 488 | ||
| 489 | if (info->port.tty) | 489 | if (info->tty) |
| 490 | set_bit(TTY_IO_ERROR, &info->port.tty->flags); | 490 | set_bit(TTY_IO_ERROR, &info->tty->flags); |
| 491 | 491 | ||
| 492 | info->flags &= ~S_INITIALIZED; | 492 | info->flags &= ~S_INITIALIZED; |
| 493 | local_irq_restore(flags); | 493 | local_irq_restore(flags); |
| @@ -553,9 +553,9 @@ static void change_speed(struct m68k_serial *info) | |||
| 553 | unsigned cflag; | 553 | unsigned cflag; |
| 554 | int i; | 554 | int i; |
| 555 | 555 | ||
| 556 | if (!info->port.tty || !info->port.tty->termios) | 556 | if (!info->tty || !info->tty->termios) |
| 557 | return; | 557 | return; |
| 558 | cflag = info->port.tty->termios->c_cflag; | 558 | cflag = info->tty->termios->c_cflag; |
| 559 | if (!(port = info->port)) | 559 | if (!(port = info->port)) |
| 560 | return; | 560 | return; |
| 561 | 561 | ||
| @@ -970,7 +970,6 @@ static void send_break(struct m68k_serial * info, unsigned int duration) | |||
| 970 | static int rs_ioctl(struct tty_struct *tty, struct file * file, | 970 | static int rs_ioctl(struct tty_struct *tty, struct file * file, |
| 971 | unsigned int cmd, unsigned long arg) | 971 | unsigned int cmd, unsigned long arg) |
| 972 | { | 972 | { |
| 973 | int error; | ||
| 974 | struct m68k_serial * info = (struct m68k_serial *)tty->driver_data; | 973 | struct m68k_serial * info = (struct m68k_serial *)tty->driver_data; |
| 975 | int retval; | 974 | int retval; |
| 976 | 975 | ||
| @@ -1104,7 +1103,7 @@ static void rs_close(struct tty_struct *tty, struct file * filp) | |||
| 1104 | tty_ldisc_flush(tty); | 1103 | tty_ldisc_flush(tty); |
| 1105 | tty->closing = 0; | 1104 | tty->closing = 0; |
| 1106 | info->event = 0; | 1105 | info->event = 0; |
| 1107 | info->port.tty = NULL; | 1106 | info->tty = NULL; |
| 1108 | #warning "This is not and has never been valid so fix it" | 1107 | #warning "This is not and has never been valid so fix it" |
| 1109 | #if 0 | 1108 | #if 0 |
| 1110 | if (tty->ldisc.num != ldiscs[N_TTY].num) { | 1109 | if (tty->ldisc.num != ldiscs[N_TTY].num) { |
| @@ -1142,7 +1141,7 @@ void rs_hangup(struct tty_struct *tty) | |||
| 1142 | info->event = 0; | 1141 | info->event = 0; |
| 1143 | info->count = 0; | 1142 | info->count = 0; |
| 1144 | info->flags &= ~S_NORMAL_ACTIVE; | 1143 | info->flags &= ~S_NORMAL_ACTIVE; |
| 1145 | info->port.tty = NULL; | 1144 | info->tty = NULL; |
| 1146 | wake_up_interruptible(&info->open_wait); | 1145 | wake_up_interruptible(&info->open_wait); |
| 1147 | } | 1146 | } |
| 1148 | 1147 | ||
| @@ -1261,7 +1260,7 @@ int rs_open(struct tty_struct *tty, struct file * filp) | |||
| 1261 | 1260 | ||
| 1262 | info->count++; | 1261 | info->count++; |
| 1263 | tty->driver_data = info; | 1262 | tty->driver_data = info; |
| 1264 | info->port.tty = tty; | 1263 | info->tty = tty; |
| 1265 | 1264 | ||
| 1266 | /* | 1265 | /* |
| 1267 | * Start up serial port | 1266 | * Start up serial port |
| @@ -1338,7 +1337,7 @@ rs68328_init(void) | |||
| 1338 | info = &m68k_soft[i]; | 1337 | info = &m68k_soft[i]; |
| 1339 | info->magic = SERIAL_MAGIC; | 1338 | info->magic = SERIAL_MAGIC; |
| 1340 | info->port = (int) &uart_addr[i]; | 1339 | info->port = (int) &uart_addr[i]; |
| 1341 | info->port.tty = NULL; | 1340 | info->tty = NULL; |
| 1342 | info->irq = uart_irqs[i]; | 1341 | info->irq = uart_irqs[i]; |
| 1343 | info->custom_divisor = 16; | 1342 | info->custom_divisor = 16; |
| 1344 | info->close_delay = 50; | 1343 | info->close_delay = 50; |
diff --git a/drivers/watchdog/Kconfig b/drivers/watchdog/Kconfig index 2e2400e7322e..31649b7b672f 100644 --- a/drivers/watchdog/Kconfig +++ b/drivers/watchdog/Kconfig | |||
| @@ -862,12 +862,12 @@ config SBC_EPX_C3_WATCHDOG | |||
| 862 | 862 | ||
| 863 | # M68K Architecture | 863 | # M68K Architecture |
| 864 | 864 | ||
| 865 | config M548x_WATCHDOG | 865 | config M54xx_WATCHDOG |
| 866 | tristate "MCF548x watchdog support" | 866 | tristate "MCF54xx watchdog support" |
| 867 | depends on M548x | 867 | depends on M548x |
| 868 | help | 868 | help |
| 869 | To compile this driver as a module, choose M here: the | 869 | To compile this driver as a module, choose M here: the |
| 870 | module will be called m548x_wdt. | 870 | module will be called m54xx_wdt. |
| 871 | 871 | ||
| 872 | # MIPS Architecture | 872 | # MIPS Architecture |
| 873 | 873 | ||
diff --git a/drivers/watchdog/Makefile b/drivers/watchdog/Makefile index dd776651917c..20e44c4782b3 100644 --- a/drivers/watchdog/Makefile +++ b/drivers/watchdog/Makefile | |||
| @@ -106,7 +106,7 @@ obj-$(CONFIG_SBC_EPX_C3_WATCHDOG) += sbc_epx_c3.o | |||
| 106 | # M32R Architecture | 106 | # M32R Architecture |
| 107 | 107 | ||
| 108 | # M68K Architecture | 108 | # M68K Architecture |
| 109 | obj-$(CONFIG_M548x_WATCHDOG) += m548x_wdt.o | 109 | obj-$(CONFIG_M54xx_WATCHDOG) += m54xx_wdt.o |
| 110 | 110 | ||
| 111 | # MIPS Architecture | 111 | # MIPS Architecture |
| 112 | obj-$(CONFIG_ATH79_WDT) += ath79_wdt.o | 112 | obj-$(CONFIG_ATH79_WDT) += ath79_wdt.o |
diff --git a/drivers/watchdog/m548x_wdt.c b/drivers/watchdog/m54xx_wdt.c index cabbcfe1c847..4d43286074aa 100644 --- a/drivers/watchdog/m548x_wdt.c +++ b/drivers/watchdog/m54xx_wdt.c | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | /* | 1 | /* |
| 2 | * drivers/watchdog/m548x_wdt.c | 2 | * drivers/watchdog/m54xx_wdt.c |
| 3 | * | 3 | * |
| 4 | * Watchdog driver for ColdFire MCF548x processors | 4 | * Watchdog driver for ColdFire MCF547x & MCF548x processors |
| 5 | * Copyright 2010 (c) Philippe De Muyter <phdm@macqel.be> | 5 | * Copyright 2010 (c) Philippe De Muyter <phdm@macqel.be> |
| 6 | * | 6 | * |
| 7 | * Adapted from the IXP4xx watchdog driver, which carries these notices: | 7 | * Adapted from the IXP4xx watchdog driver, which carries these notices: |
| @@ -29,8 +29,8 @@ | |||
| 29 | #include <linux/uaccess.h> | 29 | #include <linux/uaccess.h> |
| 30 | 30 | ||
| 31 | #include <asm/coldfire.h> | 31 | #include <asm/coldfire.h> |
| 32 | #include <asm/m548xsim.h> | 32 | #include <asm/m54xxsim.h> |
| 33 | #include <asm/m548xgpt.h> | 33 | #include <asm/m54xxgpt.h> |
| 34 | 34 | ||
| 35 | static int nowayout = WATCHDOG_NOWAYOUT; | 35 | static int nowayout = WATCHDOG_NOWAYOUT; |
| 36 | static unsigned int heartbeat = 30; /* (secs) Default is 0.5 minute */ | 36 | static unsigned int heartbeat = 30; /* (secs) Default is 0.5 minute */ |
| @@ -76,7 +76,7 @@ static void wdt_keepalive(void) | |||
| 76 | __raw_writel(gms0, MCF_MBAR + MCF_GPT_GMS0); | 76 | __raw_writel(gms0, MCF_MBAR + MCF_GPT_GMS0); |
| 77 | } | 77 | } |
| 78 | 78 | ||
| 79 | static int m548x_wdt_open(struct inode *inode, struct file *file) | 79 | static int m54xx_wdt_open(struct inode *inode, struct file *file) |
| 80 | { | 80 | { |
| 81 | if (test_and_set_bit(WDT_IN_USE, &wdt_status)) | 81 | if (test_and_set_bit(WDT_IN_USE, &wdt_status)) |
| 82 | return -EBUSY; | 82 | return -EBUSY; |
| @@ -86,7 +86,7 @@ static int m548x_wdt_open(struct inode *inode, struct file *file) | |||
| 86 | return nonseekable_open(inode, file); | 86 | return nonseekable_open(inode, file); |
| 87 | } | 87 | } |
| 88 | 88 | ||
| 89 | static ssize_t m548x_wdt_write(struct file *file, const char *data, | 89 | static ssize_t m54xx_wdt_write(struct file *file, const char *data, |
| 90 | size_t len, loff_t *ppos) | 90 | size_t len, loff_t *ppos) |
| 91 | { | 91 | { |
| 92 | if (len) { | 92 | if (len) { |
| @@ -112,10 +112,10 @@ static ssize_t m548x_wdt_write(struct file *file, const char *data, | |||
| 112 | static const struct watchdog_info ident = { | 112 | static const struct watchdog_info ident = { |
| 113 | .options = WDIOF_MAGICCLOSE | WDIOF_SETTIMEOUT | | 113 | .options = WDIOF_MAGICCLOSE | WDIOF_SETTIMEOUT | |
| 114 | WDIOF_KEEPALIVEPING, | 114 | WDIOF_KEEPALIVEPING, |
| 115 | .identity = "Coldfire M548x Watchdog", | 115 | .identity = "Coldfire M54xx Watchdog", |
| 116 | }; | 116 | }; |
| 117 | 117 | ||
| 118 | static long m548x_wdt_ioctl(struct file *file, unsigned int cmd, | 118 | static long m54xx_wdt_ioctl(struct file *file, unsigned int cmd, |
| 119 | unsigned long arg) | 119 | unsigned long arg) |
| 120 | { | 120 | { |
| 121 | int ret = -ENOTTY; | 121 | int ret = -ENOTTY; |
| @@ -161,7 +161,7 @@ static long m548x_wdt_ioctl(struct file *file, unsigned int cmd, | |||
| 161 | return ret; | 161 | return ret; |
| 162 | } | 162 | } |
| 163 | 163 | ||
| 164 | static int m548x_wdt_release(struct inode *inode, struct file *file) | 164 | static int m54xx_wdt_release(struct inode *inode, struct file *file) |
| 165 | { | 165 | { |
| 166 | if (test_bit(WDT_OK_TO_CLOSE, &wdt_status)) | 166 | if (test_bit(WDT_OK_TO_CLOSE, &wdt_status)) |
| 167 | wdt_disable(); | 167 | wdt_disable(); |
| @@ -177,45 +177,45 @@ static int m548x_wdt_release(struct inode *inode, struct file *file) | |||
| 177 | } | 177 | } |
| 178 | 178 | ||
| 179 | 179 | ||
| 180 | static const struct file_operations m548x_wdt_fops = { | 180 | static const struct file_operations m54xx_wdt_fops = { |
| 181 | .owner = THIS_MODULE, | 181 | .owner = THIS_MODULE, |
| 182 | .llseek = no_llseek, | 182 | .llseek = no_llseek, |
| 183 | .write = m548x_wdt_write, | 183 | .write = m54xx_wdt_write, |
| 184 | .unlocked_ioctl = m548x_wdt_ioctl, | 184 | .unlocked_ioctl = m54xx_wdt_ioctl, |
| 185 | .open = m548x_wdt_open, | 185 | .open = m54xx_wdt_open, |
| 186 | .release = m548x_wdt_release, | 186 | .release = m54xx_wdt_release, |
| 187 | }; | 187 | }; |
| 188 | 188 | ||
| 189 | static struct miscdevice m548x_wdt_miscdev = { | 189 | static struct miscdevice m54xx_wdt_miscdev = { |
| 190 | .minor = WATCHDOG_MINOR, | 190 | .minor = WATCHDOG_MINOR, |
| 191 | .name = "watchdog", | 191 | .name = "watchdog", |
| 192 | .fops = &m548x_wdt_fops, | 192 | .fops = &m54xx_wdt_fops, |
| 193 | }; | 193 | }; |
| 194 | 194 | ||
| 195 | static int __init m548x_wdt_init(void) | 195 | static int __init m54xx_wdt_init(void) |
| 196 | { | 196 | { |
| 197 | if (!request_mem_region(MCF_MBAR + MCF_GPT_GCIR0, 4, | 197 | if (!request_mem_region(MCF_MBAR + MCF_GPT_GCIR0, 4, |
| 198 | "Coldfire M548x Watchdog")) { | 198 | "Coldfire M54xx Watchdog")) { |
| 199 | printk(KERN_WARNING | 199 | printk(KERN_WARNING |
| 200 | "Coldfire M548x Watchdog : I/O region busy\n"); | 200 | "Coldfire M54xx Watchdog : I/O region busy\n"); |
| 201 | return -EBUSY; | 201 | return -EBUSY; |
| 202 | } | 202 | } |
| 203 | printk(KERN_INFO "ColdFire watchdog driver is loaded.\n"); | 203 | printk(KERN_INFO "ColdFire watchdog driver is loaded.\n"); |
| 204 | 204 | ||
| 205 | return misc_register(&m548x_wdt_miscdev); | 205 | return misc_register(&m54xx_wdt_miscdev); |
| 206 | } | 206 | } |
| 207 | 207 | ||
| 208 | static void __exit m548x_wdt_exit(void) | 208 | static void __exit m54xx_wdt_exit(void) |
| 209 | { | 209 | { |
| 210 | misc_deregister(&m548x_wdt_miscdev); | 210 | misc_deregister(&m54xx_wdt_miscdev); |
| 211 | release_mem_region(MCF_MBAR + MCF_GPT_GCIR0, 4); | 211 | release_mem_region(MCF_MBAR + MCF_GPT_GCIR0, 4); |
| 212 | } | 212 | } |
| 213 | 213 | ||
| 214 | module_init(m548x_wdt_init); | 214 | module_init(m54xx_wdt_init); |
| 215 | module_exit(m548x_wdt_exit); | 215 | module_exit(m54xx_wdt_exit); |
| 216 | 216 | ||
| 217 | MODULE_AUTHOR("Philippe De Muyter <phdm@macqel.be>"); | 217 | MODULE_AUTHOR("Philippe De Muyter <phdm@macqel.be>"); |
| 218 | MODULE_DESCRIPTION("Coldfire M548x Watchdog"); | 218 | MODULE_DESCRIPTION("Coldfire M54xx Watchdog"); |
| 219 | 219 | ||
| 220 | module_param(heartbeat, int, 0); | 220 | module_param(heartbeat, int, 0); |
| 221 | MODULE_PARM_DESC(heartbeat, "Watchdog heartbeat in seconds (default 30s)"); | 221 | MODULE_PARM_DESC(heartbeat, "Watchdog heartbeat in seconds (default 30s)"); |
diff --git a/lib/Kconfig.debug b/lib/Kconfig.debug index 3967c2356e37..2b97418c67e2 100644 --- a/lib/Kconfig.debug +++ b/lib/Kconfig.debug | |||
| @@ -805,7 +805,7 @@ config ARCH_WANT_FRAME_POINTERS | |||
| 805 | config FRAME_POINTER | 805 | config FRAME_POINTER |
| 806 | bool "Compile the kernel with frame pointers" | 806 | bool "Compile the kernel with frame pointers" |
| 807 | depends on DEBUG_KERNEL && \ | 807 | depends on DEBUG_KERNEL && \ |
| 808 | (CRIS || M68K || M68KNOMMU || FRV || UML || \ | 808 | (CRIS || M68K || FRV || UML || \ |
| 809 | AVR32 || SUPERH || BLACKFIN || MN10300) || \ | 809 | AVR32 || SUPERH || BLACKFIN || MN10300) || \ |
| 810 | ARCH_WANT_FRAME_POINTERS | 810 | ARCH_WANT_FRAME_POINTERS |
| 811 | default y if (DEBUG_INFO && UML) || ARCH_WANT_FRAME_POINTERS | 811 | default y if (DEBUG_INFO && UML) || ARCH_WANT_FRAME_POINTERS |
