⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 context.s

📁 eCos1.31版
💻 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 + -