aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/tty
diff options
context:
space:
mode:
authorStephen Boyd <sboyd@codeaurora.org>2011-10-25 19:19:43 -0700
committerGreg Kroah-Hartman <gregkh@suse.de>2011-11-26 09:09:57 -0800
commit5e3092bd68b8ed5d17ece466ba98e02f4ad035ec (patch)
tree29a21428fe7c154ec006576b6a95eab85ce15f36 /drivers/tty
parent6e6d3ebc5179779d72837ff38749843506fd6f7f (diff)
downloadkernel_samsung_smdk4412-5e3092bd68b8ed5d17ece466ba98e02f4ad035ec.zip
kernel_samsung_smdk4412-5e3092bd68b8ed5d17ece466ba98e02f4ad035ec.tar.gz
kernel_samsung_smdk4412-5e3092bd68b8ed5d17ece466ba98e02f4ad035ec.tar.bz2
tty: hvc_dcc: Fix duplicate character inputs
commit c2a3e84f950e7ddba1f3914b005861d46ae60359 upstream. Reading from the DCC grabs a character from the buffer and clears the status bit. Since this is a context-changing operation, instructions following the character read that rely on the status bit being accurate need to be synchronized with an ISB. In this case, the status bit check needs to execute after the character read otherwise we run the risk of reading the character and checking the status bit before the read can clear the status bit in the first place. When this happens, the user will see the same character they typed twice, instead of once. Add an ISB after the read and the write, so that the status check is synchronized with the read/write operations. Signed-off-by: Stephen Boyd <sboyd@codeaurora.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/tty')
-rw-r--r--drivers/tty/hvc/hvc_dcc.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/tty/hvc/hvc_dcc.c b/drivers/tty/hvc/hvc_dcc.c
index 435f6fa..44fbeba 100644
--- a/drivers/tty/hvc/hvc_dcc.c
+++ b/drivers/tty/hvc/hvc_dcc.c
@@ -46,6 +46,7 @@ static inline char __dcc_getchar(void)
asm volatile("mrc p14, 0, %0, c0, c5, 0 @ read comms data reg"
: "=r" (__c));
+ isb();
return __c;
}
@@ -55,6 +56,7 @@ static inline void __dcc_putchar(char c)
asm volatile("mcr p14, 0, %0, c0, c5, 0 @ write a char"
: /* no output register */
: "r" (c));
+ isb();
}
static int hvc_dcc_put_chars(uint32_t vt, const char *buf, int count)