projects
/
sbcl.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
0.7.6.3:
[sbcl.git]
/
src
/
runtime
/
x86-linux-os.c
diff --git
a/src/runtime/x86-linux-os.c
b/src/runtime/x86-linux-os.c
index
ba3b0e8
..
e5c3895
100644
(file)
--- a/
src/runtime/x86-linux-os.c
+++ b/
src/runtime/x86-linux-os.c
@@
-47,7
+47,7
@@
size_t os_vm_page_size;
* gregs[], but it's conditional on __USE_GNU and not defined, so
* we need to do this nasty absolute index magic number thing
* instead. */
* gregs[], but it's conditional on __USE_GNU and not defined, so
* we need to do this nasty absolute index magic number thing
* instead. */
-register_t *
+os_context_register_t *
os_context_register_addr(os_context_t *context, int offset)
{
switch(offset) {
os_context_register_addr(os_context_t *context, int offset)
{
switch(offset) {
@@
-63,15
+63,30
@@
os_context_register_addr(os_context_t *context, int offset)
}
return &context->uc_mcontext.gregs[offset];
}
}
return &context->uc_mcontext.gregs[offset];
}
-register_t *
+
+os_context_register_t *
os_context_pc_addr(os_context_t *context)
{
os_context_pc_addr(os_context_t *context)
{
- return &context->uc_mcontext.gregs[14];
+ return &context->uc_mcontext.gregs[14]; /* REG_EIP */
}
}
-register_t *
+
+os_context_register_t *
os_context_sp_addr(os_context_t *context)
os_context_sp_addr(os_context_t *context)
+{
+ return &context->uc_mcontext.gregs[17]; /* REG_UESP */
+}
+
+os_context_register_t *
+os_context_fp_addr(os_context_t *context)
{
{
- return &context->uc_mcontext.gregs[17];
+ return &context->uc_mcontext.gregs[6]; /* REG_EBP */
+}
+
+unsigned long
+os_context_fp_control(os_context_t *context)
+{
+ return ((((context->uc_mcontext.fpregs->cw) & 0xffff) ^ 0x3f) |
+ (((context->uc_mcontext.fpregs->sw) & 0xffff) << 16));
}
sigset_t *
}
sigset_t *
@@
-81,6
+96,12
@@
os_context_sigmask_addr(os_context_t *context)
}
void
}
void
+os_restore_fp_control(os_context_t *context)
+{
+ asm ("fldcw %0" : : "m" (context->uc_mcontext.fpregs->cw));
+}
+
+void
os_flush_icache(os_vm_address_t address, os_vm_size_t length)
{
}
os_flush_icache(os_vm_address_t address, os_vm_size_t length)
{
}