pl011: reset the fifo when enabled or disabled
authorRob Herring <rob.herring@linaro.org>
Tue, 18 Mar 2014 18:18:39 +0000 (13:18 -0500)
committerPeter Maydell <peter.maydell@linaro.org>
Tue, 18 Mar 2014 19:36:49 +0000 (19:36 +0000)
commit22709e90a270a36418f1b1d5d3277016eec1edc2
treecf4830c3153c5aa96d855f37be70ea7709f805c5
parentbd16430777cc3d25930e479fdbe290d92cec0888
pl011: reset the fifo when enabled or disabled

Intermittent issues have been seen where no serial input occurs. It
appears the pl011 gets in a state where the rx interrupt never fires
because the rx interrupt only asserts when crossing the fifo trigger
level. The fifo state appears to get out of sync when the pl011 is
re-configured. This combined with the rx timeout interrupt not being
modeled results in no more rx interrupts.

Disabling the fifo is the recommended way to clear the tx fifo in the
TRM (section 3.3.8). The behavior in this case for the rx fifo is
undefined in the TRM, but having fifo contents to be maintained during
configuration changes is not likely expected behavior. Reseting the
fifo state when the fifo size is changed is the simplest solution.

Signed-off-by: Rob Herring <rob.herring@linaro.org>
Reviewed-by: Peter Maydell <peter.maydell@linaro.org>
Message-id: 1395166721-15716-2-git-send-email-robherring2@gmail.com
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
hw/char/pl011.c