L4Re Operating System Framework
Interface and Usage Documentation
Loading...
Searching...
No Matches
utcb.h
Go to the documentation of this file.
1
6/*
7 * (c) 2008-2009 Adam Lackorzynski <adam@os.inf.tu-dresden.de>,
8 * Alexander Warg <warg@os.inf.tu-dresden.de>
9 * economic rights: Technische Universität Dresden (Germany)
10 *
11 * License: see LICENSE.spdx (in this directory or the directories above)
12 */
13#ifndef __L4_SYS__INCLUDE__ARCH_ARM64__UTCB_H__
14#define __L4_SYS__INCLUDE__ARCH_ARM64__UTCB_H__
15
16#include <l4/sys/types.h>
17
27typedef struct l4_exc_regs_t
28{
29 l4_umword_t eret_work;
30 l4_umword_t r[31];
31 l4_umword_t reserved;
33
36 union { l4_umword_t ip; l4_umword_t pc; }; /* aliases for PC */
37 union { l4_umword_t flags; l4_umword_t pstate; }; /* aliases for PSTATE (PSR) */
41
48{
49 L4_UTCB_EXCEPTION_REGS_SIZE = sizeof(l4_exc_regs_t) / sizeof(l4_umword_t),
50 L4_UTCB_GENERIC_DATA_SIZE = 63,
51 L4_UTCB_GENERIC_BUFFERS_SIZE = 58,
52
53 L4_UTCB_MSG_REGS_OFFSET = 0,
54 L4_UTCB_BUF_REGS_OFFSET = 64 * sizeof(l4_umword_t),
55 L4_UTCB_THREAD_REGS_OFFSET = 123 * sizeof(l4_umword_t),
56
57 L4_UTCB_INHERIT_FPU = 1UL << 24,
58
59 L4_UTCB_OFFSET = 1024,
60};
61
62#include_next <l4/sys/utcb.h>
63
64/*
65 * ==================================================================
66 * Implementations.
67 */
68
69#ifdef __GNUC__
70L4_INLINE l4_utcb_t *l4_utcb_direct(void) L4_NOTHROW
71{
72 l4_utcb_t *utcb;
73 __asm__ ("mrs %0, TPIDRRO_EL0" : "=r" (utcb));
74 return utcb;
75}
76#endif
77
79{
80 return u->pc;
81}
82
87
89{
90 return u->err >> 26;
91}
92
94{
95 return ((u->err >> 26) & 0x30) == 0x20;
96}
97
99{
100 return (u->pfa & ~7UL) | ((u->err >> 5) & 2);
101}
102
104{
105 return (u->err >> 26) == 0x3e;
106}
107
108#endif /* ! __L4_SYS__INCLUDE__ARCH_ARM64__UTCB_H__ */
unsigned long l4_umword_t
Unsigned machine word.
Definition l4int.h:40
unsigned long l4_addr_t
Address type.
Definition l4int.h:34
struct l4_exc_regs_t l4_exc_regs_t
UTCB structure for exceptions.
L4_utcb_consts_arm64
UTCB constants for ARM64.
Definition utcb.h:48
struct l4_utcb_t l4_utcb_t
Opaque type for the UTCB.
Definition utcb.h:56
l4_addr_t l4_utcb_exc_pfa(l4_exc_regs_t const *u) L4_NOTHROW
Function to get the L4 style page fault address out of an exception.
Definition utcb.h:112
int l4_utcb_exc_is_ex_regs_exception(l4_exc_regs_t const *u) L4_NOTHROW
Check whether an exception IPC was triggered via l4_thread_ex_regs().
Definition utcb.h:117
int l4_utcb_exc_is_pf(l4_exc_regs_t const *u) L4_NOTHROW
Check whether an exception IPC is a page fault.
Definition utcb.h:107
l4_umword_t l4_utcb_exc_pc(l4_exc_regs_t const *u) L4_NOTHROW
Access function to get the program counter of the exception state.
Definition utcb.h:92
l4_umword_t l4_utcb_exc_typeval(l4_exc_regs_t const *u) L4_NOTHROW
Get the value out of an exception UTCB that describes the type of exception.
Definition utcb.h:102
void l4_utcb_exc_pc_set(l4_exc_regs_t *u, l4_addr_t pc) L4_NOTHROW
Set the program counter register in the exception state.
Definition utcb.h:97
#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
Common L4 ABI Data Types.
UTCB structure for exceptions.
Definition utcb.h:28
l4_umword_t r[13]
registers
Definition utcb.h:32
l4_umword_t sp
stack pointer
Definition utcb.h:33
l4_umword_t pfa
page fault address
Definition utcb.h:29
l4_umword_t ip
instruction pointer
Definition utcb.h:36
l4_umword_t flags
rflags
Definition utcb.h:37
l4_umword_t tpidrurw
Thread-ID register.
Definition utcb.h:39
l4_umword_t err
error code
Definition utcb.h:30
l4_umword_t tpidruro
Thread-ID register.
Definition utcb.h:38
l4_umword_t pc
pc
Definition utcb.h:36