aboutsummaryrefslogtreecommitdiff
path: root/src/libthread/FreeBSD-386-asm.s
blob: f9a80255992c290f6ce270eb1278124b484646d0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
.globl _tas
_tas:
	movl $0xCAFEBABE, %eax
	movl 4(%esp), %ecx
	xchgl %eax, 0(%ecx)
	ret

.globl setmcontext
setmcontext:
	movl 4(%esp), %edx
	movl	8(%edx), %fs
	movl	12(%edx), %es
	movl	16(%edx), %ds
	movl	76(%edx), %ss
	movl	20(%edx), %edi
	movl	24(%edx), %esi
	movl	28(%edx), %ebp
	movl	%esp, %ecx		 
	movl	72(%edx), %esp		 
	pushl	60(%edx)	/* eip */	 
	pushl	44(%edx)	/* ecx */	 
	pushl	48(%edx)	/* eax */	 
	movl	36(%edx), %ebx		 
	movl	40(%edx), %edx
	movl	12(%ecx), %eax		 
	popl	%eax			 
	popl	%ecx
	ret

.globl getmcontext
getmcontext:
	pushl	%edx
	movl	8(%esp), %edx
	movl	%fs, 8(%edx)
	movl	%es, 12(%edx)
	movl	%ds, 16(%edx)
	movl	%ss, 76(%edx)
	movl	%edi, 20(%edx)
	movl	%esi, 24(%edx)
	movl	%ebp, 28(%edx)
	movl	%ebx, 36(%edx)
	movl	$1, 48(%edx)
	popl	%eax
	movl	%eax, 40(%edx)		 
	movl	%ecx, 44(%edx)
	movl	(%esp), %eax	/* eip */		 
	movl	%eax, 60(%edx)		 
	movl	%esp, %eax		 
	addl	$4, %eax	/* setmcontext will re-push the eip */	 
	movl	%eax, 72(%edx)
	movl	40(%edx), %edx		 
	xorl	%eax, %eax		 
	ret