blob: cb9a9248c8c0c52656b8976293d0689349fee8c0 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Thomas Gleixner1e19b162008-10-06 14:15:24 +02002#ifndef _LINUX_IOMMU_HELPER_H
3#define _LINUX_IOMMU_HELPER_H
4
Anton Blancharde269b082010-08-09 17:20:23 -07005#include <linux/kernel.h>
6
FUJITA Tomonorieecfffc2008-09-12 19:42:33 +09007static inline unsigned long iommu_device_max_index(unsigned long size,
8 unsigned long offset,
9 u64 dma_mask)
10{
11 if (size + offset > dma_mask)
12 return dma_mask - offset + 1;
13 else
14 return size;
15}
16
FUJITA Tomonori37158632008-03-04 14:29:27 -080017extern int iommu_is_span_boundary(unsigned int index, unsigned int nr,
18 unsigned long shift,
19 unsigned long boundary_size);
FUJITA Tomonori0291df82008-02-04 22:28:07 -080020extern unsigned long iommu_area_alloc(unsigned long *map, unsigned long size,
21 unsigned long start, unsigned int nr,
22 unsigned long shift,
23 unsigned long boundary_size,
24 unsigned long align_mask);
Thomas Gleixner1e19b162008-10-06 14:15:24 +020025
Anton Blancharde269b082010-08-09 17:20:23 -070026static inline unsigned long iommu_num_pages(unsigned long addr,
27 unsigned long len,
28 unsigned long io_page_size)
29{
30 unsigned long size = (addr & (io_page_size - 1)) + len;
31
32 return DIV_ROUND_UP(size, io_page_size);
33}
Joerg Roedel56d93662008-10-15 22:02:10 -070034
Thomas Gleixner1e19b162008-10-06 14:15:24 +020035#endif