L4Re Operating System Framework
Interface and Usage Documentation
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
__l4_fpage.h
1
6/*
7 * (c) 2008-2009 Adam Lackorzynski <adam@os.inf.tu-dresden.de>,
8 * Alexander Warg <warg@os.inf.tu-dresden.de>,
9 * Björn Döbel <doebel@os.inf.tu-dresden.de>,
10 * Torsten Frenzel <frenzel@os.inf.tu-dresden.de>
11 * economic rights: Technische Universität Dresden (Germany)
12 *
13 * License: see LICENSE.spdx (in this directory or the directories above)
14 */
15#pragma once
16
17#include <l4/sys/compiler.h>
18
71
80
84enum
85{
93};
94
103
104
127
226
239
252
279
280
302
303
307enum
308{
313
317
318
319
335l4_fpage(l4_addr_t address, unsigned int order, unsigned char rights) L4_NOTHROW;
336
350
359
360
372l4_iofpage(unsigned long port, unsigned int order) L4_NOTHROW;
373
374
388l4_obj_fpage(l4_cap_idx_t obj, unsigned int order, unsigned char rights) L4_NOTHROW;
389
399L4_INLINE int
401
402
450l4_map_control(l4_umword_t spot, unsigned char cache, unsigned grant) L4_NOTHROW;
451
466l4_map_obj_control(l4_umword_t spot, unsigned grant) L4_NOTHROW;
467
476L4_INLINE unsigned
478
487L4_INLINE unsigned
489
500L4_INLINE unsigned
502
513L4_INLINE unsigned long
515
531
547
561L4_INLINE unsigned long
563
574l4_fpage_set_rights(l4_fpage_t src, unsigned char new_rights) L4_NOTHROW;
575
587L4_INLINE int
588l4_fpage_contains(l4_fpage_t fpage, l4_addr_t addr, unsigned order) L4_NOTHROW;
589
606L4_INLINE unsigned char
607l4_fpage_max_order(unsigned char order, l4_addr_t addr,
608 l4_addr_t min_addr, l4_addr_t max_addr,
609 l4_addr_t hotspot L4_DEFAULT_PARAM(0));
610
611/*************************************************************************
612 * Implementations
613 *************************************************************************/
614
615L4_INLINE unsigned
620
621L4_INLINE unsigned
623{
624 return (f.raw & L4_FPAGE_TYPE_MASK) >> L4_FPAGE_TYPE_SHIFT;
625}
626
627L4_INLINE unsigned
629{
630 return (f.raw & L4_FPAGE_SIZE_MASK) >> L4_FPAGE_SIZE_SHIFT;
631}
632
633L4_INLINE unsigned long
635{
636 return (f.raw & L4_FPAGE_ADDR_MASK) >> L4_FPAGE_ADDR_SHIFT;
637}
638
639L4_INLINE unsigned long
641{
642 return (f.raw & L4_FPAGE_ADDR_MASK) >> L4_FPAGE_ADDR_SHIFT;
643}
644
647{
648 return f.raw & L4_FPAGE_ADDR_MASK;
649}
650
653{
654 return f.raw & L4_FPAGE_ADDR_MASK;
655}
656
659__l4_fpage_generic(unsigned long address, unsigned int type,
660 unsigned int order, unsigned char rights) L4_NOTHROW;
661
663__l4_fpage_generic(unsigned long address, unsigned int type,
664 unsigned int order, unsigned char rights) L4_NOTHROW
665{
666 l4_fpage_t t;
668 | ((type << L4_FPAGE_TYPE_SHIFT) & L4_FPAGE_TYPE_MASK)
669 | ((order << L4_FPAGE_SIZE_SHIFT) & L4_FPAGE_SIZE_MASK)
670 | ((address ) & L4_FPAGE_ADDR_MASK);
671 return t;
672}
673
675l4_fpage_set_rights(l4_fpage_t src, unsigned char new_rights) L4_NOTHROW
676{
677 l4_fpage_t f;
678 f.raw = ((L4_FPAGE_TYPE_MASK | L4_FPAGE_SIZE_MASK | L4_FPAGE_ADDR_MASK) & src.raw)
679 | ((new_rights << L4_FPAGE_RIGHTS_SHIFT) & L4_FPAGE_RIGHTS_MASK);
680 return f;
681}
682
684l4_fpage(l4_addr_t address, unsigned int order, unsigned char rights) L4_NOTHROW
685{
686 return __l4_fpage_generic(address, L4_FPAGE_MEMORY, order, rights);
687}
688
690l4_iofpage(unsigned long port, unsigned int order) L4_NOTHROW
691{
692 return __l4_fpage_generic(port << L4_FPAGE_ADDR_SHIFT, L4_FPAGE_IO, order, L4_FPAGE_RW);
693}
694
696l4_obj_fpage(l4_cap_idx_t obj, unsigned int order, unsigned char rights) L4_NOTHROW
697{
698 static_assert((unsigned long)L4_CAP_SHIFT >= L4_FPAGE_ADDR_SHIFT,
699 "Capability index does not fit into fpage.");
700 return __l4_fpage_generic(obj, L4_FPAGE_OBJ, order, rights);
701}
702
705{
706 return __l4_fpage_generic(0, L4_FPAGE_SPECIAL, L4_WHOLE_ADDRESS_SPACE, 0);
707}
708
711{
712 return __l4_fpage_generic(0, L4_FPAGE_SPECIAL, 0, 0);
713}
714
715
716L4_INLINE int
721
723l4_map_control(l4_umword_t snd_base, unsigned char cache, unsigned grant) L4_NOTHROW
724{
725 return (snd_base & L4_FPAGE_CONTROL_MASK)
726 | ((l4_umword_t)cache << 4) | L4_ITEM_MAP | grant;
727}
728
731{
732 return l4_map_control(snd_base, 0, grant);
733}
734
735L4_INLINE int
736l4_fpage_contains(l4_fpage_t fpage, l4_addr_t addr, unsigned log2size) L4_NOTHROW
737{
738 l4_addr_t fa = l4_fpage_memaddr(fpage);
739 return (fa <= addr)
740 && (fa + (1UL << l4_fpage_size(fpage)) >= addr + (1UL << log2size));
741}
742
743L4_INLINE unsigned char
744l4_fpage_max_order(unsigned char order, l4_addr_t addr,
745 l4_addr_t min_addr, l4_addr_t max_addr,
746 l4_addr_t hotspot)
747{
748 while (order < 30 /* limit to 1GB flexpages */)
749 {
750 l4_addr_t mask;
751 l4_addr_t base = l4_trunc_size(addr, order + 1);
752 if (base < min_addr)
753 return order;
754
755 if (base + (1UL << (order + 1)) - 1 > max_addr - 1)
756 return order;
757
758 mask = ~(~0UL << (order + 1));
759 if (hotspot == ~0UL || ((addr ^ hotspot) & mask))
760 break;
761
762 ++order;
763 }
764
765 return order;
766}
L4 compiler related defines.
unsigned long l4_umword_t
Unsigned machine word.
Definition l4int.h:40
unsigned long l4_addr_t
Address type.
Definition l4int.h:34
#define L4_MWORD_BITS
Size of machine words in bits.
Definition l4int.h:22
unsigned long l4_cap_idx_t
Capability selector type.
Definition types.h:335
@ L4_CAP_SHIFT
Capability index shift.
Definition consts.h:146
unsigned long l4_fpage_page(l4_fpage_t f) L4_NOTHROW
Return the page part from a flexpage.
Definition __l4_fpage.h:634
int l4_fpage_contains(l4_fpage_t fpage, l4_addr_t addr, unsigned order) L4_NOTHROW
Test whether a given range is completely within an fpage.
Definition __l4_fpage.h:736
l4_fpage_t l4_obj_fpage(l4_cap_idx_t obj, unsigned int order, unsigned char rights) L4_NOTHROW
Create a kernel-object flexpage.
Definition __l4_fpage.h:696
l4_fpage_t l4_fpage_all(void) L4_NOTHROW
Get a flexpage, describing all address spaces at once.
Definition __l4_fpage.h:704
l4_fpage_t l4_fpage_set_rights(l4_fpage_t src, unsigned char new_rights) L4_NOTHROW
Set new right in a flexpage.
Definition __l4_fpage.h:675
L4_fpage_rights
Memory and IO port flexpage rights.
Definition __l4_fpage.h:119
L4_fpage_control
Flexpage map control flags.
Definition __l4_fpage.h:244
unsigned l4_fpage_type(l4_fpage_t f) L4_NOTHROW
Return type from a flexpage.
Definition __l4_fpage.h:622
unsigned long l4_fpage_ioport(l4_fpage_t f) L4_NOTHROW
Return the IO port number from the IO flexpage.
Definition __l4_fpage.h:640
l4_addr_t l4_fpage_memaddr(l4_fpage_t f) L4_NOTHROW
Return the memory address from the memory flexpage.
Definition __l4_fpage.h:646
l4_fpage_t l4_fpage(l4_addr_t address, unsigned int order, unsigned char rights) L4_NOTHROW
Create a memory flexpage.
Definition __l4_fpage.h:684
unsigned l4_fpage_size(l4_fpage_t f) L4_NOTHROW
Return size (log2) from a flexpage.
Definition __l4_fpage.h:628
unsigned char l4_fpage_max_order(unsigned char order, l4_addr_t addr, l4_addr_t min_addr, l4_addr_t max_addr, l4_addr_t hotspot=0)
Determine maximum flexpage size of a region.
Definition __l4_fpage.h:744
unsigned l4_fpage_rights(l4_fpage_t f) L4_NOTHROW
Return rights from a flexpage.
Definition __l4_fpage.h:616
l4_fpage_t l4_iofpage(unsigned long port, unsigned int order) L4_NOTHROW
Create an IO-port flexpage.
Definition __l4_fpage.h:690
int l4_is_fpage_writable(l4_fpage_t fp) L4_NOTHROW
Test if the flexpage is writable.
Definition __l4_fpage.h:717
L4_fpage_type
Flexpage type.
Definition __l4_fpage.h:231
l4_fpage_t l4_fpage_invalid(void) L4_NOTHROW
Get an invalid flexpage.
Definition __l4_fpage.h:710
l4_cap_idx_t l4_fpage_obj(l4_fpage_t f) L4_NOTHROW
Return the capability index from the object flexpage.
Definition __l4_fpage.h:652
L4_cap_fpage_rights
Object flexpage rights.
Definition __l4_fpage.h:149
L4_fpage_consts
L4 flexpage structure.
Definition __l4_fpage.h:49
@ L4_WHOLE_IOADDRESS_SPACE
Whole I/O address space size.
Definition __l4_fpage.h:312
@ L4_IOPORT_MAX
Maximum I/O port address plus 1.
Definition __l4_fpage.h:315
@ L4_WHOLE_ADDRESS_SPACE
Whole address space size.
Definition __l4_fpage.h:92
@ L4_FPAGE_X
Executable flexpage.
Definition __l4_fpage.h:120
@ L4_FPAGE_RWX
Read-write-execute flexpage.
Definition __l4_fpage.h:125
@ L4_FPAGE_RX
Read-execute flexpage.
Definition __l4_fpage.h:124
@ L4_FPAGE_RO
Read-only flexpage
Definition __l4_fpage.h:122
@ L4_FPAGE_RW
Read-write flexpage.
Definition __l4_fpage.h:123
@ L4_FPAGE_W
Writable flexpage.
Definition __l4_fpage.h:121
@ L4_FPAGE_CONTROL_MASK
Mask for truncating the lower bits of the send base or the index of the control word.
Definition __l4_fpage.h:250
@ L4_FPAGE_CONTROL_OFFSET_SHIFT
Number of bits an index must be shifted or an address must be aligned to in the control word.
Definition __l4_fpage.h:247
@ L4_FPAGE_MEMORY
Flexpage for memory spaces.
Definition __l4_fpage.h:235
@ L4_FPAGE_IO
Flexpage for I/O port spaces.
Definition __l4_fpage.h:236
@ L4_FPAGE_OBJ
Flexpage for object spaces.
Definition __l4_fpage.h:237
@ L4_FPAGE_SPECIAL
Special flexpage, either l4_fpage_invalid() or l4_fpage_all(); only supported by selected interfaces.
Definition __l4_fpage.h:232
@ L4_CAP_FPAGE_RO
Read right for capability flexpages.
Definition __l4_fpage.h:176
@ L4_CAP_FPAGE_R
Read right for capability flexpages.
Definition __l4_fpage.h:175
@ L4_CAP_FPAGE_RW
Read and interface specific 'W' right for capability flexpages.
Definition __l4_fpage.h:192
@ L4_CAP_FPAGE_W
Interface specific 'W' right for capability flexpages.
Definition __l4_fpage.h:157
@ L4_CAP_FPAGE_RS
Read and interface specific 'S' right for capability flexpages.
Definition __l4_fpage.h:199
@ L4_CAP_FPAGE_RWSD
Full rights for capability flexpages.
Definition __l4_fpage.h:212
@ L4_CAP_FPAGE_RSD
Read, 'S', and delete right for capability flexpages.
Definition __l4_fpage.h:224
@ L4_CAP_FPAGE_RWS
Read, interface specific 'W', and 'S' rights for capability flexpages.
Definition __l4_fpage.h:206
@ L4_CAP_FPAGE_D
Delete right for capability flexpages.
Definition __l4_fpage.h:185
@ L4_CAP_FPAGE_S
Interface specific 'S' right for capability flexpages.
Definition __l4_fpage.h:169
@ L4_CAP_FPAGE_RWD
Read, write, and delete right for capability flexpages.
Definition __l4_fpage.h:218
@ L4_FPAGE_ADDR_SHIFT
Page address shift.
Definition __l4_fpage.h:53
@ L4_FPAGE_TYPE_SHIFT
Flexpage type shift (memory, IO port, obj...)
Definition __l4_fpage.h:51
@ L4_FPAGE_RIGHTS_MASK
Mask to get the flexpage rights.
Definition __l4_fpage.h:61
@ L4_FPAGE_TYPE_BITS
Flexpage type size (memory, IO port, obj...)
Definition __l4_fpage.h:56
@ L4_FPAGE_RIGHTS_BITS
Access permissions size.
Definition __l4_fpage.h:55
@ L4_FPAGE_RIGHTS_ALL
Specify as flexpage rights during grant.
Definition __l4_fpage.h:69
@ L4_FPAGE_ADDR_BITS
Page address size.
Definition __l4_fpage.h:58
@ L4_FPAGE_SIZE_BITS
Flexpage size size (log2-based)
Definition __l4_fpage.h:57
@ L4_FPAGE_RIGHTS_SHIFT
Access permissions shift.
Definition __l4_fpage.h:50
@ L4_FPAGE_SIZE_SHIFT
Flexpage size shift (log2-based)
Definition __l4_fpage.h:52
l4_addr_t l4_trunc_size(l4_addr_t address, unsigned char bits) L4_NOTHROW
Round an address down to the next lower flexpage with size bits.
Definition consts.h:463
l4_umword_t l4_map_control(l4_umword_t spot, unsigned char cache, unsigned grant) L4_NOTHROW
Create the first word for a map item that is a send item for the memory space.
Definition __l4_fpage.h:723
l4_fpage_cacheability_opt_t
Cacheability options for memory send items.
Definition __l4_fpage.h:285
l4_umword_t l4_map_obj_control(l4_umword_t spot, unsigned grant) L4_NOTHROW
Create the first word for a map item that is a send item for the object space.
Definition __l4_fpage.h:730
L4_obj_fpage_ctl
Attributes and additional permissions for object send items.
Definition __l4_fpage.h:263
@ L4_FPAGE_CACHEABLE
Cacheability option to enable caches for the mapping.
Definition __l4_fpage.h:292
@ L4_FPAGE_CACHE_OPT
Enable the cacheability option in a memory send item.
Definition __l4_fpage.h:288
@ L4_FPAGE_UNCACHEABLE
Cacheability option to disable caching for the mapping.
Definition __l4_fpage.h:300
@ L4_FPAGE_BUFFERABLE
Cacheability option to enable buffered writes for the mapping.
Definition __l4_fpage.h:296
@ L4_ITEM_MAP
Identify a message item as map item.
Definition consts.h:218
@ L4_FPAGE_C_NO_REF_CNT
Don't increase the reference counter.
Definition __l4_fpage.h:265
@ L4_FPAGE_C_OBJ_RIGHT1
Object-type specific right.
Definition __l4_fpage.h:267
@ L4_FPAGE_C_IPCGATE_SVR
The receiver may invoke IPC-gate-specific functions on the capability, e.g.
Definition __l4_fpage.h:277
@ L4_FPAGE_C_OBJ_RIGHT2
Object-type specific right.
Definition __l4_fpage.h:268
@ L4_FPAGE_C_OBJ_RIGHT3
Object-type specific right.
Definition __l4_fpage.h:269
@ L4_FPAGE_C_OBJ_RIGHTS
All Object-type specific right bits.
Definition __l4_fpage.h:270
@ L4_FPAGE_C_REF_CNT
Mapping is reference-counted (default).
Definition __l4_fpage.h:264
#define L4_NOTHROW
Mark a function declaration and definition as never throwing an exception.
Definition compiler.h:159
#define L4_INLINE
L4 Inline function attribute.
Definition compiler.h:51
Send-flexpage types.
Definition __l4_fpage.h:99
l4_fpage_t fpage
Source flexpage descriptor.
Definition __l4_fpage.h:101
l4_umword_t snd_base
Offset in receive window (send base)
Definition __l4_fpage.h:100
L4 flexpage type.
Definition __l4_fpage.h:76
l4_umword_t raw
Raw value.
Definition __l4_fpage.h:78
l4_umword_t fpage
Raw value.
Definition __l4_fpage.h:77