iommu/exynos: update to use iommu big-endian
Add initial support for big endian by always writing the pte in le32. Note, revisit if hardware capable of doing big endian fetches. Signed-off-by: Ben Dooks <ben.dooks@codethink.co.uk> Acked-by: Marek Szyprowski <m.szyprowski@samsung.com> Signed-off-by: Joerg Roedel <jroedel@suse.de>
This commit is contained in:
parent
96f6655700
commit
6ae5343c26
|
@ -54,6 +54,10 @@ typedef u32 sysmmu_pte_t;
|
||||||
#define lv2ent_small(pent) ((*(pent) & 2) == 2)
|
#define lv2ent_small(pent) ((*(pent) & 2) == 2)
|
||||||
#define lv2ent_large(pent) ((*(pent) & 3) == 1)
|
#define lv2ent_large(pent) ((*(pent) & 3) == 1)
|
||||||
|
|
||||||
|
#ifdef CONFIG_BIG_ENDIAN
|
||||||
|
#warning "revisit driver if we can enable big-endian ptes"
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* v1.x - v3.x SYSMMU supports 32bit physical and 32bit virtual address spaces
|
* v1.x - v3.x SYSMMU supports 32bit physical and 32bit virtual address spaces
|
||||||
* v5.0 introduced support for 36bit physical address space by shifting
|
* v5.0 introduced support for 36bit physical address space by shifting
|
||||||
|
@ -710,7 +714,7 @@ static inline void update_pte(sysmmu_pte_t *ent, sysmmu_pte_t val)
|
||||||
{
|
{
|
||||||
dma_sync_single_for_cpu(dma_dev, virt_to_phys(ent), sizeof(*ent),
|
dma_sync_single_for_cpu(dma_dev, virt_to_phys(ent), sizeof(*ent),
|
||||||
DMA_TO_DEVICE);
|
DMA_TO_DEVICE);
|
||||||
*ent = val;
|
*ent = cpu_to_le32(val);
|
||||||
dma_sync_single_for_device(dma_dev, virt_to_phys(ent), sizeof(*ent),
|
dma_sync_single_for_device(dma_dev, virt_to_phys(ent), sizeof(*ent),
|
||||||
DMA_TO_DEVICE);
|
DMA_TO_DEVICE);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue