ARM: msm: Fix uncompess.h tx underrun check
authorStephen Boyd <sboyd@codeaurora.org>
Thu, 11 Apr 2013 01:00:11 +0000 (18:00 -0700)
committerDavid Brown <davidb@codeaurora.org>
Thu, 11 Apr 2013 16:40:35 +0000 (09:40 -0700)
commit73a8c28f167c9e7bc42eafc0bcbd298031709430
tree5b6a152c302c531d57a54cdb66405865c529b0ca
parent4080d2d11a2d572228c2b8d02406e997b87ba6a5
ARM: msm: Fix uncompess.h tx underrun check

Bit 3 of the SR register is set if there is a tx underrun. If
this bit isn't set, we should loop on the tx ready bit until we
can transmit again. Otherwise we should skip the loop and
transmit immediately. The code is doing the opposite though,
checking for an underrun and then looping on the tx ready bit
causing us to never loop on the tx read bit when the tx buffer
may not be ready.

This doesn't seem to affect my 8960 device too often, but in some
cases I see a lost character or two from the decompressor prints.
This also matches what we do in the assembly in debug-macro.S.

Signed-off-by: Stephen Boyd <sboyd@codeaurora.org>
Signed-off-by: David Brown <davidb@codeaurora.org>
arch/arm/mach-msm/include/mach/uncompress.h