NO

Author Topic: Binary search  (Read 5343 times)

Offline Vortex

  • Member
  • *
  • Posts: 839
    • http://www.vortex.masmcode.com
Binary search
« on: June 09, 2012, 11:02:56 AM »
Here is a simultation of GetProcAddress using binary search method to find the address of an exported function.

Code: [Select]
include     GetProcAddr.inc

_BinSearch  PROTO :DWORD,:DWORD,:DWORD,:DWORD

.code

GetProcAddr PROC USES esi hModule:DWORD,func:DWORD

LOCAL AddrOfFuncs:DWORD

    mov     esi,hModule
    mov     edx,esi
    add     edx,IMAGE_DOS_HEADER.e_lfanew[edx]
    mov     edx,IMAGE_NT_HEADERS.OptionalHeader.DataDirectory.VirtualAddress[edx]
    add     edx,esi

    mov     eax,IMAGE_EXPORT_DIRECTORY.AddressOfNames[edx]
    add     eax,esi
    mov     ecx,IMAGE_EXPORT_DIRECTORY.AddressOfFunctions[edx]
    add     ecx,esi

    mov     AddrOfFuncs,ecx

    invoke  _BinSearch,eax,\                                ; Address of the string array
            IMAGE_EXPORT_DIRECTORY.NumberOfNames[edx],\     ; Number of symbols
            func,\                                          ; Item to search for
            esi                                             ; hModule
           
    cmp     eax,-1
    je      finish

    mov     ecx,AddrOfFuncs
    lea     edx,[ecx+4*eax]
    mov     eax,DWORD PTR [edx]
    add     eax,esi

finish:

    ret

GetProcAddr ENDP

END
Code it... That's all...

Offline Vortex

  • Member
  • *
  • Posts: 839
    • http://www.vortex.masmcode.com
Re: Binary search
« Reply #1 on: December 26, 2020, 03:03:29 PM »
Here is the 64-bit version.
Code it... That's all...

Offline Vortex

  • Member
  • *
  • Posts: 839
    • http://www.vortex.masmcode.com
Re: Binary search
« Reply #2 on: September 03, 2023, 11:02:50 AM »
Replaced some local variables with volatile registers in the 64-bit version.
Code it... That's all...

Offline HellOfMice

  • Member
  • *
  • Posts: 66
  • Never be pleased, always improve
Re: Binary search
« Reply #3 on: September 23, 2023, 06:36:19 PM »
Very short!
Thank You Vortex
--------------------------------
Kenavo