2
* Copyright (c) 2005 Jakub Jermar
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions
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.
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.
29
/** @addtogroup libcia64
35
#ifndef LIBC_ia64_FIBRIL_H_
36
#define LIBC_ia64_FIBRIL_H_
38
#include <sys/types.h>
40
#include <libarch/stack.h>
41
#include <libarch/types.h>
44
* context_save() and context_restore() are both leaf procedures.
45
* No need to allocate scratch area.
47
#define SP_DELTA (0 + ALIGN_UP(STACK_ITEM_SIZE, STACK_ALIGNMENT))
49
#define PFM_MASK (~0x3fffffffff)
51
#define PSTHREAD_INITIAL_STACK_PAGES_NO 2
52
/* Stack is divided into two equal parts (for memory stack and register stack). */
53
#define PSTHREAD_INITIAL_STACK_DIVISION 2
59
#define context_set(c, _pc, stack, size, tls) \
61
(c)->pc = (uint64_t) _pc; \
62
(c)->bsp = ((uint64_t) stack) + size / PSTHREAD_INITIAL_STACK_DIVISION; \
63
(c)->ar_pfs &= PFM_MASK; \
64
(c)->sp = ((uint64_t) stack) + ALIGN_UP((size / PSTHREAD_INITIAL_STACK_DIVISION), STACK_ALIGNMENT) - SP_DELTA; \
65
(c)->tp = (uint64_t) tls; \
70
* Only save registers that must be preserved across
73
typedef struct context {
76
* Application registers
79
uint64_t ar_unat_caller;
80
uint64_t ar_unat_callee;
82
uint64_t bsp; /* ar_bsp */
94
uint64_t sp; /* r12 */
95
uint64_t tp; /* r13 */
100
uint64_t pc; /* b0 */
108
* Predicate registers
112
__r128 f2 __attribute__ ((aligned(16)));