Contributors: 10
	  
        
          | Author | 
          Tokens | 
          Token Proportion | 
          Commits | 
          Commit Proportion | 
        
	  
	  
        
        
          | FUJITA Tomonori | 
          124 | 
          64.92% | 
          3 | 
          21.43% | 
        
        
          | Joerg Roedel | 
          42 | 
          21.99% | 
          1 | 
          7.14% | 
        
        
          | Thomas Gleixner | 
          8 | 
          4.19% | 
          1 | 
          7.14% | 
        
        
          | Anton Blanchard | 
          4 | 
          2.09% | 
          1 | 
          7.14% | 
        
        
          | Linus Torvalds (pre-git) | 
          3 | 
          1.57% | 
          2 | 
          14.29% | 
        
        
          | Andy Shevchenko | 
          3 | 
          1.57% | 
          2 | 
          14.29% | 
        
        
          | Paul Gortmaker | 
          3 | 
          1.57% | 
          1 | 
          7.14% | 
        
        
          | Christoph Hellwig | 
          2 | 
          1.05% | 
          1 | 
          7.14% | 
        
        
          | Greg Kroah-Hartman | 
          1 | 
          0.52% | 
          1 | 
          7.14% | 
        
        
          | David Howells | 
          1 | 
          0.52% | 
          1 | 
          7.14% | 
        
	  
	  
        
          | Total | 
          191 | 
           | 
          14 | 
           | 
	    
	  
    
 
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef _LINUX_IOMMU_HELPER_H
#define _LINUX_IOMMU_HELPER_H
#include <linux/bug.h>
#include <linux/log2.h>
#include <linux/math.h>
#include <linux/types.h>
static inline unsigned long iommu_device_max_index(unsigned long size,
						   unsigned long offset,
						   u64 dma_mask)
{
	if (size + offset > dma_mask)
		return dma_mask - offset + 1;
	else
		return size;
}
static inline int iommu_is_span_boundary(unsigned int index, unsigned int nr,
		unsigned long shift, unsigned long boundary_size)
{
	BUG_ON(!is_power_of_2(boundary_size));
	shift = (shift + index) & (boundary_size - 1);
	return shift + nr > boundary_size;
}
extern unsigned long iommu_area_alloc(unsigned long *map, unsigned long size,
				      unsigned long start, unsigned int nr,
				      unsigned long shift,
				      unsigned long boundary_size,
				      unsigned long align_mask);
static inline unsigned long iommu_num_pages(unsigned long addr,
					    unsigned long len,
					    unsigned long io_page_size)
{
	unsigned long size = (addr & (io_page_size - 1)) + len;
	return DIV_ROUND_UP(size, io_page_size);
}
#endif