0.7.6.12:
[sbcl.git] / src / runtime / alpha-linux-os.c
1 /*
2  * This is the Compaq/Digital Alpha Linux incarnation of
3  * arch-dependent OS-dependent routines. See also "linux-os.c".  */
4
5 /*
6  * This software is part of the SBCL system. See the README file for
7  * more information.
8  *
9  * This software is derived from the CMU CL system, which was
10  * written at Carnegie Mellon University and released into the
11  * public domain. The software is in the public domain and is
12  * provided with absolutely no warranty. See the COPYING and CREDITS
13  * files for more information.
14  */
15
16 /* These header files were lifted wholesale from linux-os.c, some may
17  * be redundant. -- Dan Barlow ca. 2001-05-01 */
18 #include <stdio.h>
19 #include <sys/param.h>
20 #include <sys/file.h>
21 #include "./signal.h"
22 #include "os.h"
23 #include "arch.h"
24 #include "globals.h"
25 #include "interrupt.h"
26 #include "interr.h"
27 #include "lispregs.h"
28 #include "sbcl.h"
29 #include <sys/socket.h>
30 #include <sys/utsname.h>
31
32 #include <sys/types.h>
33 #include <signal.h>
34 #include <sys/time.h>
35 #include <sys/stat.h>
36 #include <unistd.h>
37 #include <asm/fpu.h>
38
39 #include "validate.h"
40 size_t os_vm_page_size;
41
42
43 os_context_register_t   *
44 os_context_register_addr(os_context_t *context, int offset)
45 {
46     return &context->uc_mcontext.sc_regs[offset];
47 }
48
49 os_context_register_t *
50 os_context_float_register_addr(os_context_t *context, int offset)
51 {
52     return &context->uc_mcontext.sc_fpregs[offset];
53 }
54
55 os_context_register_t *
56 os_context_pc_addr(os_context_t *context)
57 {
58     return &((context->uc_mcontext).sc_pc);
59 }
60
61 sigset_t *
62 os_context_sigmask_addr(os_context_t *context)
63 {
64     return &context->uc_sigmask;
65 }
66
67 unsigned long
68 os_context_fp_control(os_context_t *context)
69 {
70     return ieee_fpcr_to_swcr((context->uc_mcontext).sc_fpcr);
71 }
72
73 void
74 os_restore_fp_control(os_context_t *context)
75 {
76     /* FIXME (in two parts):
77        Firstly, what happens in alpha linux inside the signal handler?
78        Does the floating point control state get cleared as in other
79        Linuxes?
80     
81        Secondly, how do we put it back if so? It will probably involve
82        something to do with
83     
84        context->uc_mcontext.sc_fpcr
85
86        (maybe a simple assembly statement will be enough)
87     */ 
88 }
89
90 void os_flush_icache(os_vm_address_t address, os_vm_size_t length)
91 {
92     asm volatile ("imb" : : : "memory" );
93 }