Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
a661187b
Commit
a661187b
authored
Jan 29, 2000
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Added our own user_regs_struct definition for better compatibility.
parent
6fb62f52
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
26 additions
and
14 deletions
+26
-14
context_i386.c
server/context_i386.c
+26
-14
No files found.
server/context_i386.c
View file @
a661187b
...
@@ -34,6 +34,18 @@
...
@@ -34,6 +34,18 @@
#ifdef linux
#ifdef linux
/* user_regs definitions from asm/user.h */
struct
kernel_user_regs_struct
{
long
ebx
,
ecx
,
edx
,
esi
,
edi
,
ebp
,
eax
;
unsigned
short
ds
,
__ds
,
es
,
__es
;
unsigned
short
fs
,
__fs
,
gs
,
__gs
;
long
orig_eax
,
eip
;
unsigned
short
cs
,
__cs
;
long
eflags
,
esp
;
unsigned
short
ss
,
__ss
;
};
/* debug register offset in struct user */
/* debug register offset in struct user */
#define DR_OFFSET(dr) ((int)((((struct user *)0)->u_debugreg) + (dr)))
#define DR_OFFSET(dr) ((int)((((struct user *)0)->u_debugreg) + (dr)))
...
@@ -56,7 +68,7 @@ static void get_thread_context( struct thread *thread, unsigned int flags, CONTE
...
@@ -56,7 +68,7 @@ static void get_thread_context( struct thread *thread, unsigned int flags, CONTE
int
pid
=
thread
->
unix_pid
;
int
pid
=
thread
->
unix_pid
;
if
(
flags
&
CONTEXT_FULL
)
if
(
flags
&
CONTEXT_FULL
)
{
{
struct
user_regs_struct
regs
;
struct
kernel_
user_regs_struct
regs
;
if
(
ptrace
(
PTRACE_GETREGS
,
pid
,
0
,
&
regs
)
==
-
1
)
goto
error
;
if
(
ptrace
(
PTRACE_GETREGS
,
pid
,
0
,
&
regs
)
==
-
1
)
goto
error
;
if
(
flags
&
CONTEXT_INTEGER
)
if
(
flags
&
CONTEXT_INTEGER
)
{
{
...
@@ -72,16 +84,16 @@ static void get_thread_context( struct thread *thread, unsigned int flags, CONTE
...
@@ -72,16 +84,16 @@ static void get_thread_context( struct thread *thread, unsigned int flags, CONTE
context
->
Ebp
=
regs
.
ebp
;
context
->
Ebp
=
regs
.
ebp
;
context
->
Esp
=
regs
.
esp
;
context
->
Esp
=
regs
.
esp
;
context
->
Eip
=
regs
.
eip
;
context
->
Eip
=
regs
.
eip
;
context
->
SegCs
=
regs
.
xcs
&
0xffff
;
context
->
SegCs
=
regs
.
cs
;
context
->
SegSs
=
regs
.
xss
&
0xffff
;
context
->
SegSs
=
regs
.
ss
;
context
->
EFlags
=
regs
.
eflags
;
context
->
EFlags
=
regs
.
eflags
;
}
}
if
(
flags
&
CONTEXT_SEGMENTS
)
if
(
flags
&
CONTEXT_SEGMENTS
)
{
{
context
->
SegDs
=
regs
.
xds
&
0xffff
;
context
->
SegDs
=
regs
.
ds
;
context
->
SegEs
=
regs
.
xes
&
0xffff
;
context
->
SegEs
=
regs
.
es
;
context
->
SegFs
=
regs
.
xfs
&
0xffff
;
context
->
SegFs
=
regs
.
fs
;
context
->
SegGs
=
regs
.
xgs
&
0xffff
;
context
->
SegGs
=
regs
.
gs
;
}
}
}
}
if
(
flags
&
CONTEXT_DEBUG_REGISTERS
)
if
(
flags
&
CONTEXT_DEBUG_REGISTERS
)
...
@@ -112,7 +124,7 @@ static void set_thread_context( struct thread *thread, unsigned int flags, CONTE
...
@@ -112,7 +124,7 @@ static void set_thread_context( struct thread *thread, unsigned int flags, CONTE
int
pid
=
thread
->
unix_pid
;
int
pid
=
thread
->
unix_pid
;
if
(
flags
&
CONTEXT_FULL
)
if
(
flags
&
CONTEXT_FULL
)
{
{
struct
user_regs_struct
regs
;
struct
kernel_
user_regs_struct
regs
;
if
((
flags
&
CONTEXT_FULL
)
!=
CONTEXT_FULL
)
/* need to preserve some registers */
if
((
flags
&
CONTEXT_FULL
)
!=
CONTEXT_FULL
)
/* need to preserve some registers */
{
{
if
(
ptrace
(
PTRACE_GETREGS
,
pid
,
0
,
&
regs
)
==
-
1
)
goto
error
;
if
(
ptrace
(
PTRACE_GETREGS
,
pid
,
0
,
&
regs
)
==
-
1
)
goto
error
;
...
@@ -131,16 +143,16 @@ static void set_thread_context( struct thread *thread, unsigned int flags, CONTE
...
@@ -131,16 +143,16 @@ static void set_thread_context( struct thread *thread, unsigned int flags, CONTE
regs
.
ebp
=
context
->
Ebp
;
regs
.
ebp
=
context
->
Ebp
;
regs
.
esp
=
context
->
Esp
;
regs
.
esp
=
context
->
Esp
;
regs
.
eip
=
context
->
Eip
;
regs
.
eip
=
context
->
Eip
;
regs
.
xcs
=
context
->
SegCs
;
regs
.
cs
=
context
->
SegCs
;
regs
.
xss
=
context
->
SegSs
;
regs
.
ss
=
context
->
SegSs
;
regs
.
eflags
=
context
->
EFlags
;
regs
.
eflags
=
context
->
EFlags
;
}
}
if
(
flags
&
CONTEXT_SEGMENTS
)
if
(
flags
&
CONTEXT_SEGMENTS
)
{
{
regs
.
x
ds
=
context
->
SegDs
;
regs
.
ds
=
context
->
SegDs
;
regs
.
x
es
=
context
->
SegEs
;
regs
.
es
=
context
->
SegEs
;
regs
.
x
fs
=
context
->
SegFs
;
regs
.
fs
=
context
->
SegFs
;
regs
.
x
gs
=
context
->
SegGs
;
regs
.
gs
=
context
->
SegGs
;
}
}
if
(
ptrace
(
PTRACE_SETREGS
,
pid
,
0
,
&
regs
)
==
-
1
)
goto
error
;
if
(
ptrace
(
PTRACE_SETREGS
,
pid
,
0
,
&
regs
)
==
-
1
)
goto
error
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment