1 /* $OpenBSD: highmem.h,v 1.3 2020/06/14 15:20:07 jsg Exp $ */ 2 /* 3 * Copyright (c) 2013, 2014, 2015 Mark Kettenis 4 * 5 * Permission to use, copy, modify, and distribute this software for any 6 * purpose with or without fee is hereby granted, provided that the above 7 * copyright notice and this permission notice appear in all copies. 8 * 9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 16 */ 17 18 #ifndef _LINUX_HIGHMEM_H 19 #define _LINUX_HIGHMEM_H 20 21 #include <sys/param.h> 22 #include <uvm/uvm_extern.h> 23 #include <linux/uaccess.h> 24 25 void *kmap(struct vm_page *); 26 void kunmap_va(void *addr); 27 28 #define kmap_to_page(ptr) (ptr) 29 30 #if defined(__i386__) || defined(__amd64__) 31 32 static inline void * 33 kmap_atomic(struct vm_page *pg) 34 { 35 vaddr_t va; 36 37 #if defined (__HAVE_PMAP_DIRECT) 38 va = pmap_map_direct(pg); 39 #else 40 extern vaddr_t pmap_tmpmap_pa(paddr_t); 41 va = pmap_tmpmap_pa(VM_PAGE_TO_PHYS(pg)); 42 #endif 43 return (void *)va; 44 } 45 46 static inline void 47 kunmap_atomic(void *addr) 48 { 49 #if defined (__HAVE_PMAP_DIRECT) 50 pmap_unmap_direct((vaddr_t)addr); 51 #else 52 extern void pmap_tmpunmap_pa(void); 53 pmap_tmpunmap_pa(); 54 #endif 55 } 56 57 #endif /* defined(__i386__) || defined(__amd64__) */ 58 59 #endif 60