2019-05-29 22:12:41 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
2011-11-01 07:52:22 +08:00
|
|
|
/*
|
|
|
|
* DMA implementation for Hexagon
|
|
|
|
*
|
2013-04-09 07:30:12 +08:00
|
|
|
* Copyright (c) 2010-2012, The Linux Foundation. All rights reserved.
|
2011-11-01 07:52:22 +08:00
|
|
|
*/
|
|
|
|
|
2020-09-22 21:36:11 +08:00
|
|
|
#include <linux/dma-map-ops.h>
|
2018-10-31 06:09:49 +08:00
|
|
|
#include <linux/memblock.h>
|
2013-04-09 07:30:12 +08:00
|
|
|
#include <asm/page.h>
|
2011-11-01 07:52:22 +08:00
|
|
|
|
2019-11-08 01:03:11 +08:00
|
|
|
void arch_sync_dma_for_device(phys_addr_t paddr, size_t size,
|
|
|
|
enum dma_data_direction dir)
|
2011-11-01 07:52:22 +08:00
|
|
|
{
|
2018-08-20 19:54:29 +08:00
|
|
|
void *addr = phys_to_virt(paddr);
|
2011-11-01 07:52:22 +08:00
|
|
|
|
|
|
|
switch (dir) {
|
|
|
|
case DMA_TO_DEVICE:
|
|
|
|
hexagon_clean_dcache_range((unsigned long) addr,
|
|
|
|
(unsigned long) addr + size);
|
|
|
|
break;
|
|
|
|
case DMA_FROM_DEVICE:
|
|
|
|
hexagon_inv_dcache_range((unsigned long) addr,
|
|
|
|
(unsigned long) addr + size);
|
|
|
|
break;
|
|
|
|
case DMA_BIDIRECTIONAL:
|
|
|
|
flush_dcache_range((unsigned long) addr,
|
|
|
|
(unsigned long) addr + size);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
BUG();
|
|
|
|
}
|
|
|
|
}
|
2021-06-23 22:11:21 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Our max_low_pfn should have been backed off by 16MB in mm/init.c to create
|
|
|
|
* DMA coherent space. Use that for the pool.
|
|
|
|
*/
|
|
|
|
static int __init hexagon_dma_init(void)
|
|
|
|
{
|
|
|
|
return dma_init_global_coherent(PFN_PHYS(max_low_pfn),
|
|
|
|
hexagon_coherent_pool_size);
|
|
|
|
}
|
|
|
|
core_initcall(hexagon_dma_init);
|