ARM: clps711x: Fix lowlevel debug-macro
authorAlexander Shiyan <shc_work@mail.ru>
Tue, 21 Aug 2012 16:59:34 +0000 (20:59 +0400)
committerArnd Bergmann <arnd@arndb.de>
Fri, 28 Sep 2012 19:14:07 +0000 (21:14 +0200)
CTS signal can not be used for the port and tied to any logic state.
In this case we have an infinite loop waiting for the signal. For fix
this problem, checking CTS removed, waiting for the signal "busy" was
postponed after the byte write to the port.

Signed-off-by: Alexander Shiyan <shc_work@mail.ru>
arch/arm/mach-clps711x/include/mach/debug-macro.S

index 118b3d9305730c2d213e15bd9fc1a10e773735b2..cb3684f8dae01ec887083388220f0e0a7696ca27 100644 (file)
                .endm
 
                .macro  waituart,rd,rx
-1001:          ldr     \rd, [\rx, #0x0140]     @ SYSFLGx
-               tst     \rd, #1 << 11           @ UBUSYx
-               bne     1001b
                .endm
 
                .macro  busyuart,rd,rx
-               tst     \rx, #0x1000            @ UART2 does not have CTS here
-               bne     1002f
 1001:          ldr     \rd, [\rx, #0x0140]     @ SYSFLGx
-               tst     \rd, #1 << 8            @ CTS
+               tst     \rd, #1 << 11           @ UBUSYx
                bne     1001b
-1002:
                .endm