Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

379 lines
12 KiB

title "Dynamic Linkages to RPCRT4.DLL"
;++
;
; Copyright (c) 1989 Microsoft Corporation
;
; Module Name:
;
; rpccall.asm
;
; Abstract:
;
; This module implements functions that dynamically link to
; RPCRT4.DLL.
;
; Author:
;
; Murthy Srinivas 7-Nov-1995
;
; Environment:
;
; Any mode.
;
; Revision History:
;
; Notes:
;
; This module is dependent on the internal structure of the
; COleStaticMutexSem object (g_Rpcrt4Sem). It invokes the
; COleCommonMutexSem::Request method, as well as invokes
; COleStaticMutexSem::ReleaseFn. Any changes to this object
; may impact this code -- BEWARE!
;
;--
.386p
.xlist
include callconv.inc
.list
extrn _GetLastError@0:proc
extrn _GetProcAddress@8:proc
extrn _LoadLibraryA@4:proc
extrn _FreeLibrary@4:proc
extrn ?Request@COleStaticMutexSem@@QAEXXZ:proc ; COleStaticMutexSem::Request
extrn ?g_Rpcrt4Sem@@3VCOleStaticMutexSem@@A:DWORD ; COleStaticMutexSem g_Rpcrt4Sem
extrn ?ReleaseFn@COleStaticMutexSem@@QAEXXZ:proc ; COleStaticMutexSem::ReleaseFn
_BSS SEGMENT DWORD PUBLIC 'BSS'
_BSS ENDS
CONST SEGMENT DWORD PUBLIC 'CONST'
CONST ENDS
_TEXT SEGMENT DWORD PUBLIC 'CODE'
ASSUME DS:FLAT, ES:NOTHING, SS:NOTHING, FS:NOTHING, GS:NOTHING
_TEXT ENDS
_DATA SEGMENT DWORD PUBLIC 'DATA'
ASSUME DS:FLAT, ES:NOTHING, SS:NOTHING, FS:NOTHING, GS:NOTHING
_DATA ENDS
EPBlock STRUC
EPAddr DD ?
Nameptr DD ?
ErrRtn DD ?
EPBlock ENDS
;
; Macro to define an RPC entry point that is to be dynamically
; linked-to
;
RPC_ENTRY macro EntryPoint,N
_DATA SEGMENT
EntryPoint&Block EPBlock {LoadAndGo,EntryPoint&Name,EntryPoint&Err}
_DATA ENDS
CONST SEGMENT
EntryPoint&Name DB '&EntryPoint',0
CONST ENDS
_TEXT SEGMENT
align dword ;;
ifb <N>
PUBLICP <_&EntryPoint>
stdProc <_&EntryPoint>,0,<> ;;
else
PUBLICP <_&EntryPoint>,N
stdProc <_&EntryPoint>,N,<> ;;
endif
lea eax,EntryPoint&Block ;; ptr to block for EP
jmp DWORD PTR [eax].EPBlock.EPAddr ;; first time will jump to
;; LoadAndGo. Subsequently
;; will jump to EP in RPCRT4
EntryPoint&Err: ;;
stdRET <_&EntryPoint> ;;
stdENDP <_&EntryPoint> ;;
_TEXT ENDS
endm
RPC_VAR_ENTRY macro EntryPoint
_DATA SEGMENT
EntryPoint&Block EPBlock {LoadAndGo,EntryPoint&Name,EntryPoint&Err}
_DATA ENDS
CONST SEGMENT
EntryPoint&Name DB '&EntryPoint',0
CONST ENDS
_TEXT SEGMENT
align dword ;;
public _&EntryPoint ;;
_&EntryPoint proc ;;
lea eax,EntryPoint&Block ;; ptr to block for EP
jmp DWORD PTR [eax].EPBlock.EPAddr ;; first time will jump to
;; LoadAndGo. Subsequently
;; will jump to EP in RPCRT4
EntryPoint&Err: ;;
ret ;;
_&EntryPoint endp ;;
_TEXT ENDS
endm
page
subttl "Load RPCRT4 Entry Point And Jump"
;++
;
; VOID
; LoadAndGo ()
;
; Routine Description:
;
; This function dynamically loads and saves the entry point address
; from RPCRT4.DLL and then jumps to the routine.
;
; Arguments:
;
; AX - ptr to EPBlock structure
;
; Return Value:
;
; Whatever the designated routine returns.
;
;--
_BSS SEGMENT
hLibrary DD 1
_BSS ENDS
_DATA SEGMENT
LoadOrGet DD LoadLib
_DATA ENDS
CONST SEGMENT
RPCRT4 DB 'RPCRT4.DLL',0
CONST ENDS
_TEXT SEGMENT
LoadAndGo:
push ebx ; save ebx, ecx, edx
push ecx ;
push edx ;
push eax ; save EPBlock address
mov ecx, OFFSET FLAT:?g_Rpcrt4Sem@@3VCOleStaticMutexSem@@A ; g_Rpcrt4Sem
call ?Request@COleStaticMutexSem@@QAEXXZ ; COleStaticMutexSem::Request
jmp DWORD PTR LoadOrGet ; LoadLib or GetProc
LoadLib:
lea eax,RPCRT4 ; load rpcrt4.dll
push eax
call _LoadLibraryA@4
or eax,eax ; successful?
jnz LoadLibOK ;
mov ecx, OFFSET FLAT:?g_Rpcrt4Sem@@3VCOleStaticMutexSem@@A ; g_Rpcrt4Sem
call ?ReleaseFn@COleStaticMutexSem@@QAEXXZ ; COleStaticMutexSem::ReleaseFn
jmp GotError ;
LoadLibOK:
mov hLibrary,eax ; save its module handle
lea eax,GetProc ; next time we won't LoadLib
mov LoadOrGet,eax ;
GetProc:
mov ecx, OFFSET FLAT:?g_Rpcrt4Sem@@3VCOleStaticMutexSem@@A ; g_Rpcrt4Sem
call ?ReleaseFn@COleStaticMutexSem@@QAEXXZ ; COleStaticMutexSem::ReleaseFn
pop eax ; restore EPBlock address
push eax ; save EPBlock address
push [eax].EPBlock.NamePtr ; routine name
push hLibrary ;
call _GetProcAddress@8 ; load routine address
or eax,eax ; successful?
jz GotError ;
pop ebx ; restore EPBlock Address
mov [ebx].EPBlock.EPAddr,eax ; save routine address in designated location
pop edx ; restore EDX, ECX, EBX
pop ecx ;
pop ebx ;
jmp eax ; and jump to the routine in rpcrt4.dll
GotError:
call _GetLastError@0 ; for debugging only
pop eax ; restore EPBlock address
pop edx ;
pop ecx ;
pop ebx ;
push [eax].EPBlock.ErrRtn ; set up error return
mov eax,8 ; error return ERROR_NOT_ENOUGH_MEMORY
ret ;
_TEXT ENDS
_TEXT SEGMENT
align dword
PUBLICP _FreeRPCRT4 ;
stdProc _FreeRPCRT4,0,<> ;
mov ecx, OFFSET FLAT:?g_Rpcrt4Sem@@3VCOleStaticMutexSem@@A ; g_Rpcrt4Sem
call ?Request@COleStaticMutexSem@@QAEXXZ ; COleStaticMutexSem::Request
push hLibrary ; FreeLibrary
call _FreeLibrary@4 ;
lea eax,GotError ; Always return error
mov LoadOrGet,eax ;
mov ecx, OFFSET FLAT:?g_Rpcrt4Sem@@3VCOleStaticMutexSem@@A ; g_Rpcrt4Sem
call ?ReleaseFn@COleStaticMutexSem@@QAEXXZ ; COleStaticMutexSem::ReleaseFn
stdRET _FreeRPCRT4 ;
stdENDP _FreeRPCRT4 ;
_TEXT ENDS
;
; Intercepted Entry points
;
RPC_ENTRY CStdStubBuffer_AddRef,1
RPC_ENTRY CStdStubBuffer_Connect,2
RPC_ENTRY CStdStubBuffer_CountRefs,1
RPC_ENTRY CStdStubBuffer_DebugServerQueryInterface,2
RPC_ENTRY CStdStubBuffer_DebugServerRelease,2
RPC_ENTRY CStdStubBuffer_Disconnect,1
RPC_ENTRY CStdStubBuffer_Invoke,3
RPC_ENTRY CStdStubBuffer_IsIIDSupported,2
RPC_ENTRY CStdStubBuffer_QueryInterface,3
RPC_ENTRY IUnknown_AddRef_Proxy,1
RPC_ENTRY IUnknown_QueryInterface_Proxy,3
RPC_ENTRY IUnknown_Release_Proxy,1
RPC_ENTRY I_RpcAllocate,1
RPC_ENTRY I_RpcBindingInqTransportType,2
RPC_ENTRY I_RpcBindingSetAsync,3
RPC_ENTRY I_RpcFree,1
RPC_ENTRY I_RpcFreeBuffer,1
RPC_ENTRY I_RpcGetBuffer,1
RPC_ENTRY I_RpcGetThreadWindowHandle,1
RPC_ENTRY I_RpcSendReceive,1
RPC_ENTRY I_RpcServerRegisterForwardFunction,1
RPC_ENTRY I_RpcServerStartListening,1
RPC_ENTRY I_RpcServerStopListening,0
RPC_ENTRY I_RpcServerUnregisterEndpointW,2
RPC_ENTRY I_RpcSetThreadParams,3
RPC_ENTRY I_RpcSsDontSerializeContext
RPC_ENTRY I_RpcWindowProc,4
RPC_ENTRY NdrAllocate,2
RPC_ENTRY NDRCContextBinding,1
RPC_ENTRY NDRSContextUnmarshall,2
RPC_ENTRY NdrClearOutParameters,3
RPC_ENTRY NdrCStdStubBuffer_Release,2
RPC_VAR_ENTRY NdrClientCall2
RPC_ENTRY NdrClientContextMarshall,3
RPC_ENTRY NdrClientContextUnmarshall,3
RPC_ENTRY NdrClientInitializeNew,4
RPC_ENTRY NdrComplexArrayBufferSize,3
RPC_ENTRY NdrComplexArrayFree,3
RPC_ENTRY NdrComplexArrayMarshall,3
RPC_ENTRY NdrComplexArrayUnmarshall,4
RPC_ENTRY NdrConformantStringBufferSize,3
RPC_ENTRY NdrConformantStringMarshall,3
RPC_ENTRY NdrConformantStringUnmarshall,4
RPC_ENTRY NdrConformantStructBufferSize,3
RPC_ENTRY NdrConformantStructMarshall,3
RPC_ENTRY NdrConformantStructUnmarshall,4
RPC_ENTRY NdrConformantVaryingArrayBufferSize,3
RPC_ENTRY NdrConformantVaryingArrayMarshall,3
RPC_ENTRY NdrConvert,2
RPC_ENTRY NdrConvert2,3
RPC_ENTRY NdrCStdStubBuffer2_Release,2
RPC_ENTRY NdrDllCanUnloadNow,1
RPC_ENTRY NdrDllGetClassObject,6
RPC_ENTRY NdrDllRegisterProxy,3
RPC_ENTRY NdrDllUnregisterProxy,3
RPC_ENTRY NdrFreeBuffer,1
RPC_ENTRY NdrFullPointerXlatFree,1
RPC_ENTRY NdrFullPointerXlatInit,2
RPC_ENTRY NdrGetBuffer,3
RPC_ENTRY NdrMapCommAndFaultStatus,4
RPC_ENTRY NdrOleAllocate,1
RPC_ENTRY NdrOleFree,1
RPC_ENTRY NdrPointerBufferSize,3
RPC_ENTRY NdrPointerFree,3
RPC_ENTRY NdrPointerMarshall,3
RPC_ENTRY NdrPointerUnmarshall,4
RPC_ENTRY NdrProxyErrorHandler,1
RPC_ENTRY NdrProxyFreeBuffer,2
RPC_ENTRY NdrProxyGetBuffer,2
RPC_ENTRY NdrProxyInitialize,5
RPC_ENTRY NdrProxySendReceive,2
RPC_ENTRY NdrSendReceive,2
RPC_ENTRY NdrServerCall2,1
RPC_ENTRY NdrServerContextMarshall,3
RPC_ENTRY NdrServerContextUnmarshall,1
RPC_ENTRY NdrServerInitializeNew,3
RPC_ENTRY NdrSimpleStructBufferSize,3
RPC_ENTRY NdrSimpleStructMarshall,3
RPC_ENTRY NdrSimpleStructUnmarshall,4
RPC_ENTRY NdrStubCall2,4
RPC_ENTRY NdrStubGetBuffer,3
RPC_ENTRY NdrStubInitialize,4
RPC_ENTRY RpcBindingCopy,2
RPC_ENTRY RpcBindingFree,1
RPC_ENTRY RpcBindingFromStringBindingA,2
RPC_ENTRY RpcBindingFromStringBindingW,2
RPC_ENTRY RpcBindingInqAuthClientA,6
RPC_ENTRY RpcBindingInqAuthClientW,6
RPC_ENTRY RpcBindingInqAuthInfoExW,8
RPC_ENTRY RpcBindingInqAuthInfoW,6
RPC_ENTRY RpcBindingInqObject,2
RPC_ENTRY RpcBindingReset,1
RPC_ENTRY RpcBindingSetAuthInfoA,6
RPC_ENTRY RpcBindingSetAuthInfoExW,7
RPC_ENTRY RpcBindingSetAuthInfoW,6
RPC_ENTRY RpcBindingSetObject,2
RPC_ENTRY RpcBindingToStringBindingW,2
RPC_ENTRY RpcBindingVectorFree,1
RPC_ENTRY RpcImpersonateClient,1
RPC_ENTRY RpcMgmtInqComTimeout,2
RPC_ENTRY RpcMgmtIsServerListening,1
RPC_ENTRY RpcMgmtStopServerListening,1
RPC_ENTRY RpcMgmtWaitServerListen
RPC_ENTRY RpcNetworkIsProtseqValidW,1
RPC_ENTRY RpcRaiseException,1
RPC_ENTRY RpcRevertToSelf
RPC_ENTRY RpcServerInqBindings,1
RPC_ENTRY RpcServerInqDefaultPrincNameA,2
RPC_ENTRY RpcServerInqDefaultPrincNameW,2
RPC_ENTRY RpcServerListen,3
RPC_ENTRY RpcServerRegisterAuthInfoW,4
RPC_ENTRY RpcServerRegisterAuthInfoA,4
RPC_ENTRY RpcServerRegisterIf,3
RPC_ENTRY RpcServerRegisterIfEx,6
RPC_ENTRY RpcServerUnregisterIf,3
RPC_ENTRY RpcServerUseProtseqEpW,4
RPC_ENTRY RpcServerUseProtseqW,3
RPC_ENTRY RpcSmDestroyClientContext,1
RPC_ENTRY RpcStringBindingComposeW,6
RPC_ENTRY RpcStringBindingParseW,6
RPC_ENTRY RpcStringFreeW,1
RPC_ENTRY RpcStringFreeA,1
RPC_ENTRY TowerExplode,6
RPC_ENTRY UuidCreate,1
RPC_ENTRY MesHandleFree,1
RPC_ENTRY MesEncodeFixedBufferHandleCreate,4
RPC_ENTRY MesBufferHandleReset,6
RPC_ENTRY MesDecodeBufferHandleCreate,3
RPC_ENTRY NdrMesTypeAlignSize,4
RPC_ENTRY NdrMesTypeEncode,4
RPC_ENTRY NdrMesTypeDecode,4
end