L4Re Operating System Framework
Interface and Usage Documentation
Loading...
Searching...
No Matches
rm.h
Go to the documentation of this file.
1
5/*
6 * (c) 2008-2009 Adam Lackorzynski <adam@os.inf.tu-dresden.de>,
7 * Alexander Warg <warg@os.inf.tu-dresden.de>
8 * economic rights: Technische Universität Dresden (Germany)
9 *
10 * License: see LICENSE.spdx (in this directory or the directories above)
11 */
12#pragma once
13
19
20#include <l4/re/env.h>
21#include <l4/re/c/dataspace.h>
22#include <l4/sys/compiler.h>
23
25
31 L4RE_RM_F_R = L4RE_DS_F_R,
32 L4RE_RM_F_W = L4RE_DS_F_W,
33 L4RE_RM_F_X = L4RE_DS_F_X,
34 L4RE_RM_F_RX = L4RE_DS_F_RX,
35 L4RE_RM_F_RW = L4RE_DS_F_RW,
36 L4RE_RM_F_RWX = L4RE_DS_F_RWX,
37
42
44
47
49
52
55
58
60 L4RE_RM_F_IN_AREA = 0x040000,
64};
65
66typedef l4_uint32_t l4re_rm_flags_t;
67typedef l4_uint64_t l4re_rm_offset_t;
68
78l4re_rm_reserve_area(l4_addr_t *start, unsigned long size,
79 l4re_rm_flags_t flags, unsigned char align) L4_NOTHROW;
80
91
143l4re_rm_attach(void **start, unsigned long size, l4re_rm_flags_t flags,
144 l4re_ds_t mem, l4re_rm_offset_t offs,
145 unsigned char align) L4_NOTHROW;
146
201l4re_rm_attach_w_info(void **start, unsigned long size, l4re_rm_flags_t flags,
202 l4re_ds_t mem, l4re_rm_offset_t offs,
203 unsigned char align,
204 char const *name,
205 l4re_ds_offset_t backing_offset) L4_NOTHROW;
206
207
226l4re_rm_detach(void *addr) L4_NOTHROW;
227
248l4re_rm_detach_ds(void *addr, l4re_ds_t *ds) L4_NOTHROW;
249
263
279l4re_rm_detach_ds_unmap(void *addr, l4re_ds_t *ds,
281
282
290l4re_rm_find(l4_addr_t *addr, unsigned long *size,
291 l4re_rm_offset_t *offset,
292 l4re_rm_flags_t *flags, l4re_ds_t *m) L4_NOTHROW;
293
303 char *name, unsigned int len,
304 l4re_rm_offset_t *backing_offset) L4_NOTHROW;
305
306
313L4_CV L4_INLINE void
315
316
317/*
318 * Variants of functions that also take a capability of the region map
319 * service.
320 */
321
322
327L4_CV int
328l4re_rm_reserve_area_srv(l4_cap_idx_t rm, l4_addr_t *start, unsigned long size,
329 l4re_rm_flags_t flags, unsigned char align) L4_NOTHROW;
330
335L4_CV int
337
342L4_CV int
343l4re_rm_attach_srv(l4_cap_idx_t rm, void **start, unsigned long size,
344 l4re_rm_flags_t flags, l4re_ds_t mem,
345 l4re_rm_offset_t offs,
346 unsigned char align) L4_NOTHROW;
347
352L4_CV int
353l4re_rm_attach_w_info_srv(l4_cap_idx_t rm, void **start, unsigned long size,
354 l4re_rm_flags_t flags, l4re_ds_t mem,
355 l4re_rm_offset_t offs,
356 unsigned char align,
357 char const *name,
358 l4re_ds_offset_t backing_offset) L4_NOTHROW;
359
360
365L4_CV int
368
369
374L4_CV int
376 unsigned long *size, l4re_rm_offset_t *offset,
377 l4re_rm_flags_t *flags, l4re_ds_t *m) L4_NOTHROW;
378
379
384L4_CV int
386 char *name, unsigned int len,
387 l4re_rm_offset_t *backing_offset) L4_NOTHROW;
388
393L4_CV void
395
396
397/********** Implementations ***************************/
398
400l4re_rm_reserve_area(l4_addr_t *start, unsigned long size,
401 l4re_rm_flags_t flags, unsigned char align) L4_NOTHROW
402{
403 return l4re_rm_reserve_area_srv(l4re_global_env->rm, start, size,
404 flags, align);
405}
406
409{
410 return l4re_rm_free_area_srv(l4re_global_env->rm, addr);
411}
412
414l4re_rm_attach(void **start, unsigned long size, l4re_rm_flags_t flags,
415 l4re_ds_t mem, l4re_rm_offset_t offs,
416 unsigned char align) L4_NOTHROW
417{
418 return l4re_rm_attach_srv(l4re_global_env->rm, start, size,
419 flags, mem, offs, align);
420}
421
423l4re_rm_attach_w_info(void **start, unsigned long size, l4re_rm_flags_t flags,
424 l4re_ds_t mem, l4re_rm_offset_t offs,
425 unsigned char align,
426 char const *name,
427 l4re_ds_offset_t backing_offset) L4_NOTHROW
428{
429 return l4re_rm_attach_w_info_srv(l4re_global_env->rm, start, size,
430 flags, mem, offs, align,
431 name, backing_offset);
432}
433
434
437{
438 return l4re_rm_detach_srv(l4re_global_env->rm,
439 (l4_addr_t)addr, 0, L4_BASE_TASK_CAP);
440}
441
444{
445 return l4re_rm_detach_srv(l4re_global_env->rm, addr, 0, task);
446}
447
450{
451 return l4re_rm_detach_srv(l4re_global_env->rm, (l4_addr_t)addr,
452 ds, L4_BASE_TASK_CAP);
453}
454
457{
458 return l4re_rm_detach_srv(l4re_global_env->rm, (l4_addr_t)addr,
459 ds, task);
460}
461
463l4re_rm_find(l4_addr_t *addr, unsigned long *size,
464 l4re_rm_offset_t *offset,
465 l4re_rm_flags_t *flags, l4re_ds_t *m) L4_NOTHROW
466{
467 return l4re_rm_find_srv(l4re_global_env->rm, addr, size, offset, flags, m);
468}
469
470L4_CV L4_INLINE void
472{
473 l4re_rm_show_lists_srv(l4re_global_env->rm);
474}
475
476
477
479l4re_rm_get_info(l4_addr_t addr, char *name, unsigned int len,
480 l4re_rm_offset_t *backing_offset) L4_NOTHROW
481{
482 return l4re_rm_get_info_srv(l4re_global_env->rm, addr, name, len,
483 backing_offset);
484}
485
L4 compiler related defines.
Data space C interface.
Environment interface.
L4_BEGIN_DECLS typedef l4_cap_idx_t l4re_ds_t
Dataspace type.
Definition dataspace.h:29
@ L4RE_DS_F_BUFFERABLE
request bufferable (write buffered) mappings
Definition dataspace.h:60
@ L4RE_DS_F_NORMAL
request normal memory mapping
Definition dataspace.h:58
@ L4RE_DS_F_CACHING_MASK
mask for caching flags
Definition dataspace.h:62
@ L4RE_DS_F_UNCACHEABLE
request uncacheable memory mappings
Definition dataspace.h:61
int l4re_rm_attach_w_info_srv(l4_cap_idx_t rm, void **start, unsigned long size, l4re_rm_flags_t flags, l4re_ds_t mem, l4re_rm_offset_t offs, unsigned char align, char const *name, l4re_ds_offset_t backing_offset) L4_NOTHROW
int l4re_rm_attach(void **start, unsigned long size, l4re_rm_flags_t flags, l4re_ds_t mem, l4re_rm_offset_t offs, unsigned char align) L4_NOTHROW
Attach a data space to a region.
Definition rm.h:414
int l4re_rm_detach(void *addr) L4_NOTHROW
Detach and unmap a region from the address space in the current task.
Definition rm.h:436
void l4re_rm_show_lists_srv(l4_cap_idx_t rm) L4_NOTHROW
Dump region map internal data structures.
int l4re_rm_attach_srv(l4_cap_idx_t rm, void **start, unsigned long size, l4re_rm_flags_t flags, l4re_ds_t mem, l4re_rm_offset_t offs, unsigned char align) L4_NOTHROW
int l4re_rm_reserve_area_srv(l4_cap_idx_t rm, l4_addr_t *start, unsigned long size, l4re_rm_flags_t flags, unsigned char align) L4_NOTHROW
void l4re_rm_show_lists(void) L4_NOTHROW
Dump region map internal data structures.
Definition rm.h:471
int l4re_rm_find(l4_addr_t *addr, unsigned long *size, l4re_rm_offset_t *offset, l4re_rm_flags_t *flags, l4re_ds_t *m) L4_NOTHROW
Find a region given an address and size.
Definition rm.h:463
int l4re_rm_get_info(l4_addr_t addr, char *name, unsigned int len, l4re_rm_offset_t *backing_offset) L4_NOTHROW
Return auxiliary information of a region.
Definition rm.h:479
int l4re_rm_detach_ds(void *addr, l4re_ds_t *ds) L4_NOTHROW
Detach and unmap a region and return affected dataspace in the current task.
Definition rm.h:449
int l4re_rm_detach_srv(l4_cap_idx_t rm, l4_addr_t addr, l4re_ds_t *ds, l4_cap_idx_t task) L4_NOTHROW
int l4re_rm_detach_unmap(l4_addr_t addr, l4_cap_idx_t task) L4_NOTHROW
Detach and unmap in specified task.
Definition rm.h:443
l4re_rm_flags_values
Flags for region operations.
Definition rm.h:30
int l4re_rm_attach_w_info(void **start, unsigned long size, l4re_rm_flags_t flags, l4re_ds_t mem, l4re_rm_offset_t offs, unsigned char align, char const *name, l4re_ds_offset_t backing_offset) L4_NOTHROW
Attach a data space to a region.
Definition rm.h:423
int l4re_rm_find_srv(l4_cap_idx_t rm, l4_addr_t *addr, unsigned long *size, l4re_rm_offset_t *offset, l4re_rm_flags_t *flags, l4re_ds_t *m) L4_NOTHROW
int l4re_rm_free_area_srv(l4_cap_idx_t rm, l4_addr_t addr) L4_NOTHROW
int l4re_rm_reserve_area(l4_addr_t *start, unsigned long size, l4re_rm_flags_t flags, unsigned char align) L4_NOTHROW
Reserve the given area in the region map.
Definition rm.h:400
int l4re_rm_detach_ds_unmap(void *addr, l4re_ds_t *ds, l4_cap_idx_t task) L4_NOTHROW
Detach and unmap in specified task.
Definition rm.h:456
int l4re_rm_free_area(l4_addr_t addr) L4_NOTHROW
Free an area from the region map.
Definition rm.h:408
int l4re_rm_get_info_srv(l4_cap_idx_t rm, l4_addr_t addr, char *name, unsigned int len, l4re_rm_offset_t *backing_offset) L4_NOTHROW
@ L4RE_RM_F_CACHE_BUFFERED
Cache bits for buffered (write combining) memory.
Definition rm.h:54
@ L4RE_RM_REGION_FLAGS
Mask of all region flags.
Definition rm.h:48
@ L4RE_RM_F_CACHE_UNCACHED
Cache bits for uncached memory.
Definition rm.h:57
@ L4RE_RM_CACHING_SHIFT
Start of region mapper cache bits.
Definition rm.h:43
@ L4RE_RM_F_NO_EAGER_MAP
Prevent eager mapping of the attached data space.
Definition rm.h:62
@ L4RE_RM_F_SEARCH_ADDR
Search for a suitable address range.
Definition rm.h:59
@ L4RE_RM_F_DETACH_FREE
Free the portion of the data space after detach.
Definition rm.h:39
@ L4RE_RM_F_KERNEL
Kernel-provided memory (KUMEM).
Definition rm.h:38
@ L4RE_RM_F_PAGER
Region has a pager.
Definition rm.h:40
@ L4RE_RM_F_R
Region is read-only.
Definition rm.h:31
@ L4RE_RM_F_IN_AREA
Search only in area, or map into area.
Definition rm.h:60
@ L4RE_RM_F_CACHE_NORMAL
Cache bits for normal cacheable memory.
Definition rm.h:51
@ L4RE_RM_F_ATTACH_FLAGS
Mask of all attach flags.
Definition rm.h:63
@ L4RE_RM_F_RESERVED
Region is reserved (blocked).
Definition rm.h:41
@ L4RE_RM_F_EAGER_MAP
Eagerly map the attached data space in.
Definition rm.h:61
@ L4RE_RM_F_CACHING
Mask of all region manager cache bits.
Definition rm.h:46
unsigned long l4_addr_t
Address type.
Definition l4int.h:34
unsigned int l4_uint32_t
Unsigned 32bit value.
Definition l4int.h:29
unsigned long long l4_uint64_t
Unsigned 64bit value.
Definition l4int.h:31
unsigned long l4_cap_idx_t
Capability selector type.
Definition types.h:357
@ L4_BASE_TASK_CAP
Capability selector for the current task.
Definition consts.h:346
#define L4_CV
Define calling convention.
Definition linkage.h:33
#define L4_NOTHROW
Mark a function declaration and definition as never throwing an exception.
Definition compiler.h:167
#define L4_INLINE
L4 Inline function attribute.
Definition compiler.h:51
#define L4_BEGIN_DECLS
Start section with C types and functions.
Definition compiler.h:171
#define L4_END_DECLS
End section with C types and functions.
Definition compiler.h:172