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

📄 loadhelp.asm

📁 开放源码的编译器open watcom 1.6.0版的源代码
💻 ASM
字号:
;*****************************************************************************
;*
;*                            Open Watcom Project
;*
;*    Portions Copyright (c) 1983-2002 Sybase, Inc. All Rights Reserved.
;*
;*  ========================================================================
;*
;*    This file contains Original Code and/or Modifications of Original
;*    Code as defined in and that are subject to the Sybase Open Watcom
;*    Public License version 1.0 (the 'License'). You may not use this file
;*    except in compliance with the License. BY USING THIS FILE YOU AGREE TO
;*    ALL TERMS AND CONDITIONS OF THE LICENSE. A copy of the License is
;*    provided with the Original Code and Modifications, and is also
;*    available at www.sybase.com/developer/opensource.
;*
;*    The Original Code and all software distributed under the License are
;*    distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
;*    EXPRESS OR IMPLIED, AND SYBASE AND ALL CONTRIBUTORS HEREBY DISCLAIM
;*    ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF
;*    MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR
;*    NON-INFRINGEMENT. Please see the License for the specific language
;*    governing rights and limitations under the License.
;*
;*  ========================================================================
;*
;* Description:  Small function to load the helped DLL into the debuggee.
;*               See pgmexec.c for details.
;*
;*****************************************************************************


.386p

extrn           DosLoadModule : near

public          LoadHelperDLL_
public          EndLoadHelperDLL_

_TEXT segment byte public 'CODE' use32

assume cs:_TEXT

; Why use the indirect call? A direct call to DosLoadModule would be a near
; call and relative to caller's address. When this code is copied to the
; debuggee's address space, it wouldn't work. We get around that easily by
; getting DosLoadModule's absolute address and calling that. Note that the
; address is guaranteed to be same in both (all) processes due to the way
; DLLs are implemented on OS/2.
LoadHelperDLL_  proc    near
        mov     eax, offset DosLoadModule      ; get DosLoadModule address
        call    eax                            ; load WDSPLICE.DLL
        int     3                              ; breakpoint to get control back
EndLoadHelperDLL_ label byte
LoadHelperDLL_  endp

_TEXT           ends

                end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -