diff options
author | Olof Johansson <[email protected]> | 2011-10-12 23:52:29 -0700 |
---|---|---|
committer | Olof Johansson <[email protected]> | 2012-02-06 18:24:58 -0800 |
commit | e2f91578b35347341482f6af9e4fcf3174531efd (patch) | |
tree | d6a739e65cfcebf70dea84527adcde2103f7ad8b /tools/perf/scripts/python/check-perf-trace.py | |
parent | 13ae3d5bdf737d6078a562154ff4fef0ba5d0de1 (diff) |
ARM: tegra: use APB DMA for accessing APB devices
Tegra2 hangs if APB registers are accessed from the cpu during an
apb dma operation. The workaround is to use apb dma to read/write the
registers instead.
There is a dependency loop between fuses, clocks, and APBDMA. If dma
is enabled, fuse reads must go through APBDMA to avoid corruption due
to a hw bug. APBDMA requires a clock to be enabled. Clocks must read
a fuse to determine allowable cpu frequencies.
Separate out the fuse DMA initialization, and allow the fuse read
and write functions to be called without using DMA before the DMA
initialization has been completed. Access to the fuses before APBDMA
is initialized won't hit the hardware bug because nothing else can be
using DMA.
Original fuse registar access code from Varun Wadekar
<[email protected]>, improved by Colin Cross <[email protected]>
and later moved to separate driver by Jon Mayo <[email protected]>.
Major refactoring/cleanup by Olof Johansson <[email protected]>.
Changes since v1:
* fix 'return false' on error condition
* dequeue dma ops in case of timeout
From: Jon Mayo <[email protected]>.
Signed-off-by: Jon Mayo <[email protected]>.
Signed-off-by: Olof Johansson <[email protected]>
Acked-by: Stephen Warren <[email protected]>
Diffstat (limited to 'tools/perf/scripts/python/check-perf-trace.py')
0 files changed, 0 insertions, 0 deletions