Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8074675
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 5, 20262026-06-05T14:43:59+00:00 2026-06-05T14:43:59+00:00

I try to analyze a dll file with my poor assembly skills, so forgive

  • 0

I try to analyze a dll file with my poor assembly skills, so forgive me if I couldn’t achieve something very trivial. My problem is that, while debugging the application, I find the code I’m looking for only in debug session, after I stop the debugger, the address is gone. The dll doesn’t look to be obfuscated, as many of the code is readable. Take a look at the screenshot. The code I’m looking for is located at address 07D1EBBF in debug376 section. BTW, where did I get this debug376 section?

So my question is, How can I find this function while not debugging?
Thanks

UPDATE

Ok, as I said, as soon as I stop the debugger, the code is vanished. I can’t even find it via sequence of bytes (but I can in debug mode). When I start the debugger, the code is not disassembled imediately, I should add a hardware breakpoint at that place and only when the breakpoint will be hit, IDA will show disassembled code. take a look at this screenshot
You see the line of code I’m interested in, which is not visible if the program is not running in debug mode. I’m not sure, but I think it’s something like unpacking the code at runtime, which is not visible at design time.

Anyway, any help would be appreciated. I want to know why that code is hidden, until breakpoint hit (it’s shown as “db 8Bh” etc) and how to find that address without debugging if possible. BTW, could this be a code from a different module (dll)?

Thanks

UPDATE 2

I found out that debug376 is a segment created at runtime. So simple question: how can I find out where this segment came from 🙂

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-05T14:44:01+00:00Added an answer on June 5, 2026 at 2:44 pm

    So you see the code in the Debugger Window once your program is running and as you seem not to find the verry same opcodes in the raw Hex-Dump once it’s not running any more?

    What might help you is taking a Memory Snapshot. Pause the program’s execution near the instructions you’re interested in to make sure they are there, then choose “Take memory snapshot” from the “Debugger” Menu. IDA will then ask you wether to copy only the Data found at the segments that are defined as “loder segments” (those the PE loader creates from the predefined table) or “all segments” that seem to currently belong to the debugged program (including such that might have been created by an unpacking routine, decryptor, whatever). Go for “All segments” and you should be fine seeing memory contents including your debug segments (a segment
    created or recognized while debugging) in IDA when not debugging the application.

    You can view the list of segements at any time by pressing Shift+F7 or by clicking “Segments” from View > Open subviews.

    Keep in mind that the programm your trying to analyze might choose to create the segment some other place the next time it is loaded to make it harder to understand for you what’s going on.

    UPDATE to match your second Question

    When a program is unpacking data from somewhere, it will have to copy stuff somewhere. Windows is a virtual machine that nowadays get’s real nasty at you when trying to execute or write code at locations that you’re not allowed to. So any program, as long as we’re under windows will somehow

    1. Register a Bunch of new memory or overwrite memory it already owns. This is usually done by calling something like malloc or so [Your code looks as if it could have been a verry pointer-intensive language… VB perhaps or something object oriented] it mostly boils down to a call to VirtualAlloc or VirtualAllocEx from Windows’s kernel32.dll, see http://msdn.microsoft.com/en-us/library/windows/desktop/aa366887(v=vs.85).aspx for more detail on it’s calling convention.
    2. Perhaps set up Windows Exception handling on that and mark the memory range als executable if it wasn’t already when calling VirtualAlloc. This would be done by calling VirtualProtect, again from kernel32.dll. See http://msdn.microsoft.com/en-us/library/windows/desktop/aa366898(v=vs.85).aspx and http://msdn.microsoft.com/en-us/library/windows/desktop/aa366786(v=vs.85).aspx for more info on that.

    So now, you should take a step trough the programm, starting at its default Entrypoint (OEP) and look for calls tho one of those functions, possibly with the memory protection set to PAGE_EXECUTE or a descendant. After that will possibly come some sort of loop decrypting the memory contents, copying them to their new location. You might want to just step over it, depending on what your interest in the program is by justr placing the cursor after the loop (thick blue line in IDA usually) and clicking “Run to Cursor” from the menu that appears upon right clicking the assembler code.

    If that fails, just try placing a Hardware Breakpoint on kernel32.dll’s VirtualAlloc and see if you get anything interestin when stepping into the return statement so you end up wherever the execution chain will take you after the Alloc or Protect call.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I'm trying to analyze audio using AudioRecord in a class. My problem is that
I'm using WINDBG to analyze a dump file for a program that exhibits a
Using FxCop when I try to analyze projects that rely on Patterns and Practices,
I am trying to analyze what problem i might be having with unsafe threading
I'm working on an assignment where we're supposed to crypt-analyze a PDF that had
I'm trying to analyze Java source files with Clojure but I couldn't find a
I'm making a little tool to analyze code dependencies recursively. I found a problem:
I has a question about XCODE analyze command. When a function has @try @catch,
Can anyone recommend a tool (ideally FOSS) that can analyse an .NET assembly and
I ran 'analyze in xcode on a current iOS project to try to track

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.