Skip to content

Conversation

@dblnz
Copy link
Contributor

@dblnz dblnz commented Jul 24, 2025

This PR address part of hyperlight-dev/hyperlight#684 and closes #120 that concerns the hyperlight-wasm related work to enable the wasm modules/components native debugging running in hyperlight-wasm guest.

What this includes:

@dblnz dblnz self-assigned this Jul 24, 2025
@dblnz dblnz added the kind/enhancement New feature or request label Jul 24, 2025
Copy link
Member

@syntactically syntactically left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks great! If I understand it correctly, the actual "registering loaded code with GDB" is taken care of by the upstream wasmtime code that handles the GDB jit interface, which automatically works for us since when gdb loads the debug information for the sandbox binary, it gets the jit interface symbols from wasmtime?

One minor note that is not really completely related to this PR---this changeset made me notice that we still have a .vscode in this directory, which we removed from hyperlight core in hyperlight-dev/hyperlight#66. Do we want to remove that here as well, and make sure that any/all relevant settings are documented?

#[cfg(feature = "gdb")]
{
config.debug_info(true);
config.cranelift_opt_level(OptLevel::None);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we want this to be unconditional? Sometimes it's quite useful to be able to debug the optimized code.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This was is still in dev, I'll remove it

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It turns out that this is needed. I wasn't able to debug wasm modules without this option

@dblnz
Copy link
Contributor Author

dblnz commented Jul 24, 2025

This looks great! If I understand it correctly, the actual "registering loaded code with GDB" is taken care of by the upstream wasmtime code that handles the GDB jit interface, which automatically works for us since when gdb loads the debug information for the sandbox binary, it gets the jit interface symbols from wasmtime?

One minor note that is not really completely related to this PR---this changeset made me notice that we still have a .vscode in this directory, which we removed from hyperlight core in hyperlight-dev/hyperlight#66. Do we want to remove that here as well, and make sure that any/all relevant settings are documented?

Thanks for taking a look at this. You are correct, the GDB jit interface is handled by the changes in wasmtime that enable it for no_std environments also.

I'll remove the .vscode, I don't have a strong preference.

@ludfjig
Copy link
Contributor

ludfjig commented Jul 25, 2025

I'm a fan of keeping the .vscode for what it's worth. We brought it back in hl-core as well.

@simongdavies
Copy link
Contributor

I'm a fan of keeping the .vscode for what it's worth. We brought it back in hl-core as well.

Agreed, I don't think this impacts folks who don't care and helps those who do?

@syntactically
Copy link
Member

Is the only thing blocking this waiting for a new wasmtime release that includes the debug features?

/// This feature is only available when the `gdb` feature is enabled.
/// If the `gdb` feature is not enabled, this method will have no effect.
pub fn with_debugging_enabled(mut self, port: u16) -> Self {
#[cfg(feature = "gdb")]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could this be put on the function to follow the pattern for things like with_crashdump_enabled?

@simongdavies
Copy link
Contributor

@dblnz #167 introduces wasmtime 36 so this should be unblocked now?

@dblnz dblnz marked this pull request as ready for review September 3, 2025 10:48
@dblnz dblnz force-pushed the wasm-debug branch 2 times, most recently from f66659c to b5e07d0 Compare September 4, 2025 10:55
@dblnz dblnz force-pushed the wasm-debug branch 2 times, most recently from 2c1be3a to 966c54b Compare September 29, 2025 15:21
@dblnz
Copy link
Contributor Author

dblnz commented Oct 6, 2025

I have discovered that the changes pending review do not allow wasm guests to be debugged any more. When placing a breakpoint in a wasm module, the host responds with an error because it cannot find a correct guest memory are at the corresponding address.

I have debugged this issue to find out the root cause, and the problem is the fact that mapping the wasm module into the host memory breaks this support.

I have taken some time to investigate hyperlight-dev/hyperlight#747, and it I will come up with a fix for both as they have a common root cause.

@dblnz dblnz force-pushed the wasm-debug branch 4 times, most recently from 349f9a8 to 9c0777d Compare October 22, 2025 09:18
@dblnz dblnz changed the title [WIP] Enable native debugging for wasm modules/components Enable native debugging for wasm modules/components Oct 22, 2025
dblnz added 4 commits October 23, 2025 18:39
- The toolchain paths and flags are not correctly propagated on
  windows. When gdb feature is enabled, wasmtime-internal-jit-debug
  crate tries to compile C files using cc which is not correctly set
  on Windows

Signed-off-by: Doru Blânzeanu <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

kind/enhancement New feature or request

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Add flag to hyperlight-wasm-aot to include debug symbols

5 participants