Changes in uspace/lib/c/generic/ddi.c [8cd680c:9359aae] in mainline
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
uspace/lib/c/generic/ddi.c
r8cd680c r9359aae 71 71 * @param flags Flags for the new address space area. 72 72 * @param virt Virtual address of the starting page. 73 * If set to AS_AREA_ANY ((void *) -1), a suitable value 74 * is found by the kernel, otherwise the kernel tries to 75 * obey the desired value. 76 * 77 * @return EOK on success. 78 * @return EPERM if the caller lacks the CAP_MEM_MANAGER capability. 73 * 74 * @return EOK on success 75 * @return EPERM if the caller lacks the CAP_MEM_MANAGER capability 76 * @return ENOENT if there is no task with specified ID 79 77 * @return ENOMEM if there was some problem in creating 80 78 * the address space area. … … 87 85 } 88 86 89 /** Unmap a piece of physical memory to task.90 *91 * Caller of this function must have the CAP_MEM_MANAGER capability.92 *93 * @param virt Virtual address from the phys-mapped region.94 *95 * @return EOK on success.96 * @return EPERM if the caller lacks the CAP_MEM_MANAGER capability.97 *98 */99 int physmem_unmap(void *virt)100 {101 return __SYSCALL1(SYS_PHYSMEM_UNMAP, (sysarg_t) virt);102 }103 104 /** Lock a piece physical memory for DMA transfers.105 *106 * The mapping of the specified virtual memory address107 * to physical memory address is locked in order to108 * make it safe for DMA transferts.109 *110 * Caller of this function must have the CAP_MEM_MANAGER capability.111 *112 * @param virt Virtual address of the memory to be locked.113 * @param size Number of bytes to lock.114 * @param map_flags Desired virtual memory area flags.115 * @param flags Flags for the physical memory address.116 * @param phys Locked physical memory address.117 *118 * @return EOK on success.119 * @return EPERM if the caller lacks the CAP_MEM_MANAGER capability.120 * @return ENOMEM if there was some problem in creating121 * the address space area.122 *123 */124 87 int dmamem_map(void *virt, size_t size, unsigned int map_flags, 125 88 unsigned int flags, uintptr_t *phys) … … 130 93 } 131 94 132 /** Map a piece of physical memory suitable for DMA transfers.133 *134 * Caller of this function must have the CAP_MEM_MANAGER capability.135 *136 * @param size Number of bytes to map.137 * @param constraint Bit mask defining the contraint on the physical138 * address to be mapped.139 * @param map_flags Desired virtual memory area flags.140 * @param flags Flags for the physical memory address.141 * @param virt Virtual address of the starting page.142 * If set to AS_AREA_ANY ((void *) -1), a suitable value143 * is found by the kernel, otherwise the kernel tries to144 * obey the desired value.145 *146 * @return EOK on success.147 * @return EPERM if the caller lacks the CAP_MEM_MANAGER capability.148 * @return ENOMEM if there was some problem in creating149 * the address space area.150 *151 */152 95 int dmamem_map_anonymous(size_t size, uintptr_t constraint, 153 96 unsigned int map_flags, unsigned int flags, uintptr_t *phys, void **virt) … … 194 137 195 138 return __SYSCALL1(SYS_IOSPACE_ENABLE, (sysarg_t) &arg); 196 }197 198 /** Disable I/O space range to task.199 *200 * Caller of this function must have the IO_MEM_MANAGER capability.201 *202 * @param id Task ID.203 * @param ioaddr Starting address of the I/O range.204 * @param size Size of the range.205 *206 * @return EOK on success207 * @return EPERM if the caller lacks the CAP_IO_MANAGER capability208 * @return ENOENT if there is no task with specified ID209 *210 */211 static int iospace_disable(task_id_t id, void *ioaddr, size_t size)212 {213 const ddi_ioarg_t arg = {214 .task_id = id,215 .ioaddr = ioaddr,216 .size = size217 };218 219 return __SYSCALL1(SYS_IOSPACE_DISABLE, (sysarg_t) &arg);220 139 } 221 140 … … 302 221 size_t pages = SIZE2PAGES(offset + size); 303 222 304 void *virt_page = AS_AREA_ANY;223 void *virt_page; 305 224 int rc = physmem_map(phys_frame, pages, 306 225 AS_AREA_READ | AS_AREA_WRITE, &virt_page); … … 312 231 } 313 232 314 /** Disable PIO for specified I/O range.315 *316 * @param virt I/O start address.317 * @param size Size of the I/O region.318 *319 * @return EOK on success.320 * @return Negative error code on failure.321 *322 */323 int pio_disable(void *virt, size_t size)324 {325 #ifdef IO_SPACE_BOUNDARY326 if (virt < IO_SPACE_BOUNDARY)327 return iospace_disable(task_get_id(), virt, size);328 #else329 (void) iospace_disable;330 #endif331 return physmem_unmap(virt);332 }333 334 233 void pio_write_8(ioport8_t *reg, uint8_t val) 335 234 { … … 371 270 } 372 271 272 /** Register IRQ notification. 273 * 274 * @param inr IRQ number. 275 * @param devno Device number of the device generating inr. 276 * @param method Use this method for notifying me. 277 * @param ucode Top-half pseudocode handler. 278 * 279 * @return Value returned by the kernel. 280 * 281 */ 282 int irq_register(int inr, int devno, int method, const irq_code_t *ucode) 283 { 284 return __SYSCALL4(SYS_IRQ_REGISTER, inr, devno, method, 285 (sysarg_t) ucode); 286 } 287 288 /** Unregister IRQ notification. 289 * 290 * @param inr IRQ number. 291 * @param devno Device number of the device generating inr. 292 * 293 * @return Value returned by the kernel. 294 * 295 */ 296 int irq_unregister(int inr, int devno) 297 { 298 return __SYSCALL2(SYS_IRQ_UNREGISTER, inr, devno); 299 } 300 373 301 /** @} 374 302 */
Note:
See TracChangeset
for help on using the changeset viewer.