| [79522a7] | 1 | /* | 
|---|
| [df4ed85] | 2 | * Copyright (c) 2006 Jakub Jermar | 
|---|
| [79522a7] | 3 | * All rights reserved. | 
|---|
|  | 4 | * | 
|---|
|  | 5 | * Redistribution and use in source and binary forms, with or without | 
|---|
|  | 6 | * modification, are permitted provided that the following conditions | 
|---|
|  | 7 | * are met: | 
|---|
|  | 8 | * | 
|---|
|  | 9 | * - Redistributions of source code must retain the above copyright | 
|---|
|  | 10 | *   notice, this list of conditions and the following disclaimer. | 
|---|
|  | 11 | * - Redistributions in binary form must reproduce the above copyright | 
|---|
|  | 12 | *   notice, this list of conditions and the following disclaimer in the | 
|---|
|  | 13 | *   documentation and/or other materials provided with the distribution. | 
|---|
|  | 14 | * - The name of the author may not be used to endorse or promote products | 
|---|
|  | 15 | *   derived from this software without specific prior written permission. | 
|---|
|  | 16 | * | 
|---|
|  | 17 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR | 
|---|
|  | 18 | * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | 
|---|
|  | 19 | * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. | 
|---|
|  | 20 | * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, | 
|---|
|  | 21 | * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | 
|---|
|  | 22 | * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 
|---|
|  | 23 | * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 
|---|
|  | 24 | * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 
|---|
|  | 25 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | 
|---|
|  | 26 | * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 
|---|
| [b2951e2] | 27 | */ | 
|---|
|  | 28 |  | 
|---|
| [a46da63] | 29 | /** @addtogroup libc | 
|---|
| [b2951e2] | 30 | * @{ | 
|---|
|  | 31 | */ | 
|---|
|  | 32 | /** @file | 
|---|
| [e1ab30f8] | 33 | */ | 
|---|
| [79522a7] | 34 |  | 
|---|
| [5a4c754] | 35 | #include <as.h> | 
|---|
| [79522a7] | 36 | #include <libc.h> | 
|---|
| [b93d637] | 37 | #include <errno.h> | 
|---|
| [79522a7] | 38 | #include <unistd.h> | 
|---|
| [bf9afa07] | 39 | #include <align.h> | 
|---|
| [5d4e90f0] | 40 | #include <sys/types.h> | 
|---|
| [f8ddd17] | 41 | #include <bitops.h> | 
|---|
| [db24058] | 42 | #include <malloc.h> | 
|---|
| [0b37882] | 43 | #include "private/libc.h" | 
|---|
| [79522a7] | 44 |  | 
|---|
| [d3b8c1f] | 45 | /** Create address space area. | 
|---|
| [585819d] | 46 | * | 
|---|
| [fbcdeb8] | 47 | * @param base  Starting virtual address of the area. | 
|---|
| [faba839] | 48 | *              If set to AS_AREA_ANY ((void *) -1), | 
|---|
|  | 49 | *              the kernel finds a mappable area. | 
|---|
| [fbcdeb8] | 50 | * @param size  Size of the area. | 
|---|
|  | 51 | * @param flags Flags describing type of the area. | 
|---|
| [585819d] | 52 | * | 
|---|
| [fbcdeb8] | 53 | * @return Starting virtual address of the created area on success. | 
|---|
| [faba839] | 54 | * @return AS_MAP_FAILED ((void *) -1) otherwise. | 
|---|
| [db24058] | 55 | * | 
|---|
| [585819d] | 56 | */ | 
|---|
| [fbcdeb8] | 57 | void *as_area_create(void *base, size_t size, unsigned int flags) | 
|---|
| [79522a7] | 58 | { | 
|---|
| [fbcdeb8] | 59 | return (void *) __SYSCALL4(SYS_AS_AREA_CREATE, (sysarg_t) base, | 
|---|
|  | 60 | (sysarg_t) size, (sysarg_t) flags, (sysarg_t) __entry); | 
|---|
| [79522a7] | 61 | } | 
|---|
| [7ad3c2f] | 62 |  | 
|---|
| [d3b8c1f] | 63 | /** Resize address space area. | 
|---|
| [585819d] | 64 | * | 
|---|
| [f8ddd17] | 65 | * @param address Virtual address pointing into already existing address space | 
|---|
| [db24058] | 66 | *                area. | 
|---|
|  | 67 | * @param size    New requested size of the area. | 
|---|
|  | 68 | * @param flags   Currently unused. | 
|---|
|  | 69 | * | 
|---|
|  | 70 | * @return zero on success or a code from @ref errno.h on failure. | 
|---|
| [585819d] | 71 | * | 
|---|
| [46ec2c06] | 72 | */ | 
|---|
| [56273bb] | 73 | int as_area_resize(void *address, size_t size, unsigned int flags) | 
|---|
| [46ec2c06] | 74 | { | 
|---|
| [db24058] | 75 | return __SYSCALL3(SYS_AS_AREA_RESIZE, (sysarg_t) address, | 
|---|
| [2057572] | 76 | (sysarg_t) size, (sysarg_t) flags); | 
|---|
| [46ec2c06] | 77 | } | 
|---|
|  | 78 |  | 
|---|
|  | 79 | /** Destroy address space area. | 
|---|
|  | 80 | * | 
|---|
| [f8ddd17] | 81 | * @param address Virtual address pointing into the address space area being | 
|---|
| [db24058] | 82 | *                destroyed. | 
|---|
|  | 83 | * | 
|---|
|  | 84 | * @return zero on success or a code from @ref errno.h on failure. | 
|---|
| [46ec2c06] | 85 | * | 
|---|
| [585819d] | 86 | */ | 
|---|
| [46ec2c06] | 87 | int as_area_destroy(void *address) | 
|---|
| [585819d] | 88 | { | 
|---|
| [db24058] | 89 | return __SYSCALL1(SYS_AS_AREA_DESTROY, (sysarg_t) address); | 
|---|
| [585819d] | 90 | } | 
|---|
| [7ad3c2f] | 91 |  | 
|---|
| [c98e6ee] | 92 | /** Change address-space area flags. | 
|---|
|  | 93 | * | 
|---|
|  | 94 | * @param address Virtual address pointing into the address space area being | 
|---|
| [db24058] | 95 | *                modified. | 
|---|
|  | 96 | * @param flags   New flags describing type of the area. | 
|---|
|  | 97 | * | 
|---|
|  | 98 | * @return zero on success or a code from @ref errno.h on failure. | 
|---|
| [c98e6ee] | 99 | * | 
|---|
|  | 100 | */ | 
|---|
| [56273bb] | 101 | int as_area_change_flags(void *address, unsigned int flags) | 
|---|
| [c98e6ee] | 102 | { | 
|---|
|  | 103 | return __SYSCALL2(SYS_AS_AREA_CHANGE_FLAGS, (sysarg_t) address, | 
|---|
|  | 104 | (sysarg_t) flags); | 
|---|
|  | 105 | } | 
|---|
|  | 106 |  | 
|---|
| [b93d637] | 107 | /** Find mapping to physical address. | 
|---|
|  | 108 | * | 
|---|
| [c6ae4c2] | 109 | * @param      virt Virtual address to find mapping for. | 
|---|
|  | 110 | * @param[out] phys Physical adress. | 
|---|
|  | 111 | * | 
|---|
|  | 112 | * @return EOK on no error. | 
|---|
|  | 113 | * @retval ENOENT if no mapping was found. | 
|---|
|  | 114 | * | 
|---|
| [b93d637] | 115 | */ | 
|---|
| [c6ae4c2] | 116 | int as_get_physical_mapping(const void *virt, uintptr_t *phys) | 
|---|
| [b93d637] | 117 | { | 
|---|
| [c6ae4c2] | 118 | return (int) __SYSCALL2(SYS_PAGE_FIND_MAPPING, (sysarg_t) virt, | 
|---|
|  | 119 | (sysarg_t) phys); | 
|---|
| [b93d637] | 120 | } | 
|---|
|  | 121 |  | 
|---|
| [a46da63] | 122 | /** @} | 
|---|
| [b2951e2] | 123 | */ | 
|---|