summaryrefslogtreecommitdiffstats
path: root/tools/perf/arch/common.c
diff options
context:
space:
mode:
authorVignesh R <vigneshr@ti.com>2017-04-11 17:22:25 +0530
committerMark Brown <broonie@kernel.org>2017-04-21 18:03:53 +0100
commitc687c46e9e4527c4b4d82bc3cca58c1b08bcfb83 (patch)
tree1e7db7fdf3adb9e07d1e528c277c84fe54f41c51 /tools/perf/arch/common.c
parent2bca34455b257d75080d87e800ae14afe49001bf (diff)
downloadlinux-c687c46e9e4527c4b4d82bc3cca58c1b08bcfb83.tar.bz2
spi: spi-ti-qspi: Use bounce buffer if read buffer is not DMA'ble
Flash filesystems like JFFS2, UBIFS and MTD block layer can provide vmalloc'd or kmap'd buffers that cannot be mapped using dma_map_sg() and can potentially be in memory region above 32bit addressable region(ie buffers belonging to memory region backed by LPAE) of DMA, implement spi_flash_can_dma() interface to inform SPI core not to map such buffers. When buffers are not mapped for DMA, then use a pre allocated bounce buffer(64K = typical flash erase sector size) to read from flash and then do a copy to actual destination buffer. This is approach is much faster than using memcpy using CPU and also reduces CPU load. With this patch, UBIFS read speed is ~18MB/s and CPU utilization <20% on DRA74 Rev H EVM. Performance degradation is negligible when compared with non bounce buffer case while using UBIFS. Signed-off-by: Vignesh R <vigneshr@ti.com> Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'tools/perf/arch/common.c')
0 files changed, 0 insertions, 0 deletions