Committer: Michael Beasley <mike@snafu.setup>
[mikesnafu-overlay.git] / drivers / pci / iova.h
blob228f6c94b69c327543d118c5868ddce07a2f9a43
1 /*
2 * Copyright (c) 2006, Intel Corporation.
4 * This file is released under the GPLv2.
6 * Copyright (C) 2006-2008 Intel Corporation
7 * Author: Anil S Keshavamurthy <anil.s.keshavamurthy@intel.com>
9 */
11 #ifndef _IOVA_H_
12 #define _IOVA_H_
14 #include <linux/types.h>
15 #include <linux/kernel.h>
16 #include <linux/rbtree.h>
17 #include <linux/dma-mapping.h>
19 /* IO virtual address start page frame number */
20 #define IOVA_START_PFN (1)
22 /* iova structure */
23 struct iova {
24 struct rb_node node;
25 unsigned long pfn_hi; /* IOMMU dish out addr hi */
26 unsigned long pfn_lo; /* IOMMU dish out addr lo */
29 /* holds all the iova translations for a domain */
30 struct iova_domain {
31 spinlock_t iova_alloc_lock;/* Lock to protect iova allocation */
32 spinlock_t iova_rbtree_lock; /* Lock to protect update of rbtree */
33 struct rb_root rbroot; /* iova domain rbtree root */
34 struct rb_node *cached32_node; /* Save last alloced node */
35 unsigned long dma_32bit_pfn;
38 struct iova *alloc_iova_mem(void);
39 void free_iova_mem(struct iova *iova);
40 void free_iova(struct iova_domain *iovad, unsigned long pfn);
41 void __free_iova(struct iova_domain *iovad, struct iova *iova);
42 struct iova *alloc_iova(struct iova_domain *iovad, unsigned long size,
43 unsigned long limit_pfn,
44 bool size_aligned);
45 struct iova *reserve_iova(struct iova_domain *iovad, unsigned long pfn_lo,
46 unsigned long pfn_hi);
47 void copy_reserved_iova(struct iova_domain *from, struct iova_domain *to);
48 void init_iova_domain(struct iova_domain *iovad, unsigned long pfn_32bit);
49 struct iova *find_iova(struct iova_domain *iovad, unsigned long pfn);
50 void put_iova_domain(struct iova_domain *iovad);
52 #endif