.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 | |