📄 context.s
字号:
##=============================================================================#### context.S#### i386 context switch code####=============================================================================#####COPYRIGHTBEGIN##### # ------------------------------------------- # The contents of this file are subject to the Red Hat eCos Public License # Version 1.1 (the "License"); you may not use this file except in # compliance with the License. You may obtain a copy of the License at # http://www.redhat.com/ # # Software distributed under the License is distributed on an "AS IS" # basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the # License for the specific language governing rights and limitations under # the License. # # The Original Code is eCos - Embedded Configurable Operating System, # released September 30, 1998. # # The Initial Developer of the Original Code is Red Hat. # Portions created by Red Hat are # Copyright (C) 1998, 1999, 2000 Red Hat, Inc. # All Rights Reserved. # ------------------------------------------- # #####COPYRIGHTEND######=============================================================================#######DESCRIPTIONBEGIN######## Author(s): jskov## Contributors:jskov, pjo, nickg## Date: 1999-01-20## Purpose: i386 context switch code## Description: This file contains implementations of the thread context ## switch routines. It also contains the longjmp() and setjmp()## routines.## Based on PowerPC context.S, using data from SYSV ABI4, i386 ## supplement (page 37-38)## http://www.sco.com/products/layered/develop/devspecs/abi386-4.pdf########DESCRIPTIONEND########=============================================================================#include <pkgconf/hal.h>#include "cyg/hal/i386.inc"#------------------------------------------------------------------------------# function declaration macro#define FUNC_START(name) \ .globl name; \name: #------------------------------------------------------------------------------# hal_thread_switch_context# Switch thread contexts# : 0(%esp) : return address# : 4(%esp) : address of sp of next thread to execute# : 8(%esp) : address of sp save location of current thread## %eax, %ecx, and %edx are ours to abuse. FUNC_START(hal_thread_switch_context) movl 4(%esp),%eax # next context ptr movl 8(%esp),%edx # this context ptr # Make room on the stack for the context movl %esp,%ecx # keep original SP sub $i386reg_context_size,%esp # Save next context ptr in this context. Necessary because # hal_thread_load_context expects to find the ptr on the stack, # not in a register as on PPC. movl %eax,i386reg_next_context(%esp) # Save registers movl %ecx,i386reg_esp(%esp) # original esp movl %ebp,i386reg_ebp(%esp) movl %ebx,i386reg_ebx(%esp) movl %esi,i386reg_esi(%esp) movl %edi,i386reg_edi(%esp) # Store the context ptr movl %esp,(%edx) # Now fall through to hal_thread_load_context #------------------------------------------------------------------------------# hal_thread_load_context# Load thread context# : 4(%esp) = i386reg_next_context(%esp) = address of sp of thread to execute# Note that this function is also the second half of hal_thread_switch_context# and is simply dropped into from it.## %eax, %ecx, and %edx are ours to abuse. FUNC_START(hal_thread_load_context)#ifdef CYGHWR_HAL_I386_FPU movl %cr0, %eax orl $0x8, %eax movl %eax, %cr0#endif movl i386reg_next_context(%esp),%eax # get new context ptr movl (%eax),%eax # Restore registers movl i386reg_ebp(%eax),%ebp movl i386reg_ebx(%eax),%ebx movl i386reg_esi(%eax),%esi movl i386reg_edi(%eax),%edi movl i386reg_esp(%eax),%esp ret#------------------------------------------------------------------------------# HAL longjmp, setjmp implementations# hal_setjmp saves only to callee save registers ebp, ebx, esi, edi and# and esp+pc into buffer supplied in 4(esp)# Note: These definitions are repeated in hal_arch.h. If changes are required# remember to update both sets.#define CYGARC_JMP_BUF_SP 0#define CYGARC_JMP_BUF_EBP 1#define CYGARC_JMP_BUF_EBX 2#define CYGARC_JMP_BUF_ESI 3#define CYGARC_JMP_BUF_EDI 4#define CYGARC_JMP_BUF_PC 5#define CYGARC_JMP_BUF_SIZE 6FUNC_START(hal_setjmp) # Get jmpbuf pointer movl 4(%esp),%eax # Save regular registers movl %ebp,CYGARC_JMP_BUF_EBP*4(%eax) movl %ebx,CYGARC_JMP_BUF_EBX*4(%eax) movl %esi,CYGARC_JMP_BUF_ESI*4(%eax) movl %edi,CYGARC_JMP_BUF_EDI*4(%eax) # Stack and PC movl %esp,CYGARC_JMP_BUF_SP*4(%eax) movl 0(%esp),%ebx movl %ebx,CYGARC_JMP_BUF_PC*4(%eax) # Return 0 xor %eax,%eax ret # hal_longjmp loads state from 4(esp) and returns to PC stored in stateFUNC_START(hal_longjmp) # Get return value movl 8(%esp),%eax # Get jmpbuf pointer movl 4(%esp),%ecx # Restore regular registers movl CYGARC_JMP_BUF_EBP*4(%ecx),%ebp movl CYGARC_JMP_BUF_EBX*4(%ecx),%ebx movl CYGARC_JMP_BUF_ESI*4(%ecx),%esi movl CYGARC_JMP_BUF_EDI*4(%ecx),%edi # Restore stack pointer movl CYGARC_JMP_BUF_SP*4(%ecx),%esp # Put return address on stack movl CYGARC_JMP_BUF_PC*4(%ecx),%edx movl %edx,0(%esp) ret#-----------------------------------------------------------------------------# End of context.S
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -