VSX CompatibleOXP Native: Planned

// Description

CDT GDB debug adapter extension for Visual Studio Code

// Readme

Open VSX

#CDT GDB Debug Adapter Extension for Visual Studio Code

This is a Visual Studio Code extension that supports debugging using GDB and the MI protocol. It is built by the experts that provide the GDB support in the Eclipse C/C++ IDE (CDT).

This extension provides a number of features that integrate into the Visual Studio Code debug environment. This includes launch types, support for the standard debug views as well as a custom viewer for memory browsing.

##Prerequisites

External tools are expected to be present on your system depending on the intended use case.

  • Local GDB Debug: A GDB installation is required on your system.
  • Remote GDB Debug: A GDB installation is required on your system. In addition to that you must have either access to a running GDB server instance (attach use case), or a suitable GDB server variant must be installed to launch and connect to your debug target.

##Launch Configurations

The Visual Studio Debug Extension for GDB contributes two debugger types:

  • gdb: Support for Local GDB Debug. Launch or attach to an already running application locally on your host machine using GDB.
  • gdbtarget: Support for Remote GDB Debug. Launch or attach to an already running remote GDB server using GDB.

Both come as launch and attach request types, each with a sophisticated set of configuration settings.

###gdb Debugger Type

Launch and attach configuration settings that can be used with the gdb debugger type for local GDB debug.

SettinglaunchattachTypeDescription
gdbxxstringPath to GDB. This can be an absolute path or the name of an executable on your PATH environment variable.Default: gdb
cwdxxstringCurrent working directory for launching GDB.Default: Directory of the debugged program.
environmentxxobjectEnvironment variables to use when launching GDB, defined as a key-value pairs. Use null value to remove variable.Example:"environment": { "VARNAME": "value", "PATH": "/new/item:${env:PATH}", "REMOVEME": null}
programxxstringPath to the program to be debugged. For launch requests, this program is also launched.Default: ${workspaceFolder}/${command:askProgramPath}, which allows to interactively enter the full program path.
argumentsxstringArguments for the program.
processIdxstringProcess ID to attach to.
gdbAsyncxxbooleanUse mi-async mode for communication with GDB. Always true if gdbNonStop is true.Default: true
gdbNonStopxxbooleanUse non-stop mode for controlling multiple threads. Default: false
verbosexxbooleanProduce verbose log output.
logFilexxstringAbsolute path to the file to log interaction with GDB.
openGdbConsolexxboolean(UNIX-only) Open a GDB console in your IDE while debugging.
preConnectCommandsxxstring[]List of GDB commands sent before attaching to inferior.
initCommandsxxstring[]List of GDB commands sent after attaching to inferior before running/continuing.
updateThreadInfoxxstringControls when thread information is retrieved from GDB. See updateThreadInfo setting section for details.Supported values: missing, when-requested, neverDefault: missing

updateThreadInfo Setting

The updateThreadInfo setting controls when thread information is retrieved from GDB. This setting can be used with both gdb and gdbtarget debugger types.

Supported values:

###gdbtarget Debugger Type

Launch and attach configuration settings that can be used with the gdbtarget debugger type for remote GDB debug connections.

SettinglaunchattachTypeDescription
gdbxxstringPath to GDB. This can be an absolute path or the name of an executable on your PATH environment variable.Default: gdb
cwdxxstringCurrent working directory for launching GDB.Default: Directory of the debugged program.
environmentxxobjectEnvironment variables to use when launching GDB, defined as a key-value pairs. Use null value to remove variable.Example:"environment": { "VARNAME": "value", "PATH": "/new/item:${env:PATH}", "REMOVEME": null}
programxxstringPath to the program to be debugged. For launch requests, this program is also launched.Default: ${workspaceFolder}/${command:askProgramPath}, which allows to interactively enter the full program path.Note: While program is marked as required, the debug adapter launches anyway for remote GDB connections. For example to inspect an embedded target system's memory and other hardware resources without debugging a program.
gdbAsyncxxbooleanUse mi-async mode for communication with GDB. Always true if gdbNonStop is true.Default: true
gdbNonStopxxbooleanUse non-stop mode for controlling multiple threads. Default: false
auxiliaryGdbxxbooleanCreates an auxiliary GDB connection to the target TCP port to allow memory accesses and expression evaluation while the target is running.Default: falseNotes:* Requires support for multiple connections to the same TCP port in connected GDB server.* Requires gdbAsync mode and cannot be used with gdbNonStop mode.
verbosexxbooleanProduce verbose log output.
logFilexxstringAbsolute path to the file to log interaction with GDB.
openGdbConsolexxboolean(UNIX-only) Open a GDB console in your IDE while debugging.
preConnectCommandsxxstring[]List of GDB commands sent to initialize GDB before attaching to target.
initCommandsxxstring[]List of GDB commands sent to initialize debug target after attaching to it but before loading image and symbols.
preRunCommandsxxstring[]List of GDB commands sent after loading image on target before resuming target.
imageAndSymbolsxxobjectAdditional settings for loading images to the target and symbols into the debugger. See section "imageAndSymbols object" for details.
targetxxobjectAdditional settings to configure the remote GDB target. See section "target object" for details.
customResetCommandsxxstring[]List of GDB commands to perform a RESET of the connected target, for example through monitor ... commands of the connected GDB server.
updateThreadInfoxxstringControls when thread information is retrieved from GDB. See updateThreadInfo setting section for details.Supported values: missing, when-requested, neverDefault: missing

imageAndSymbols Object

Additional settings for loading images to the target and symbols into the debugger. This object can be used in launch and attach configurations for the gdbtarget debugger type for remote GDB connections.

SettinglaunchattachTypeDescription
symbolFileNamexxstringIf specified, a symbol file to load at the given (optional) offset. Also see symbolOffset.
symbolOffsetxxstringIf symbolFileName is specified, the offset added to symbol addresses when loaded.
imageFileNamexxstringIf specified, an image file to load at the given (optional) offset. Also see imageOffset.
imageOffsetxxstringIf imageFileName is specified, the offset used to load the image.

target Object

Additional settings to configure the remote GDB target. This object can be used in launch and attach configurations for the gdbtarget debugger type for remote GDB connections.

SettinglaunchattachTypeDescription
typexxstringThe kind of target debugging to do. This is passed to -target-select.Default: remote
parametersxxstring[]Target parameters for the type of target. Normally something like localhost:12345.Default: ${host}:${port}.
hostxxstringTarget host to connect to. Ignored if parameters is set.Default: localhost
portxxstringTarget port to connect to. Ignored if parameters is set.Default: Value captured by serverPortRegExp, otherwise defaults to 2331
cwdxstringSpecifies the working directory of the server.Default: Working directory of GDB
environmentxobjectEnvironment variables to use when launching server, defined as key-value pairs. Defaults to the environment used to launch GDB. Use null value to remove variable.Example:"environment": { "VARNAME": "value", "PATH": "/new/item:${env:PATH}", "REMOVEME": null}
serverxstringThe executable for the target server to launch (e.g. gdbserver or JLinkGDBServerCLExe). This can be an absolute path or the name of an executable on your PATH environment variable.Default: gdbserver
serverParametersxstring[]Command line arguments passed to server.Default: --once :0 ${args.program}
serverPortRegExpxstringRegular expression to extract port from by examining stdout/stderr of the GDB server. Once the server is launched, port will be set to this if unspecified. Defaults to matching a string like Listening on port 41551 which is what gdbserver provides. Ignored if port or parameters is set.
portDetectionTimeoutxnumberTimeout for port detection based on serverPortRegExp. Default value is 10000 (ms).
serverDisconnectTimeoutxnumberTimeout for GDB server disconnect request. Default value is 1000 (ms).
serverStartupDelayxnumberDelay, in milliseconds, after startup but before continuing launch. If serverPortRegExp is provided, it is the delay after that regexp is seen.
automaticallyKillServerxbooleanAutomatically terminate the launched server when client issues a disconnect.Default: true
watchServerProcessxbooleanWatch server process and handle when it (unexpectedly) exits.Default: true
uartxxobjectSettings related to displaying UART output in the debug console.
uart object

Settings related to displaying UART output in the debug console. This object can be used in the target object of launch and attach configurations for the gdbtarget debugger type for remote GDB connections.

SettinglaunchattachTypeDescription
serialPortxxstringPath to the serial port connected to the UART on the board.
socketPortxxstringTarget TCP port on the host machine to attach socket to print UART output.Default: 3456
baudRatexxnumberBaud Rate (in bits/s) of the serial port to be opened.Default: 115200.
characterSizexxnumberThe number of bits in each character of data sent across the serial line.Supported values: 5, 6, 7, 8Default: 8
parityxxstringThe type of parity check enabled with the transmitted data.Supported values: none, odd, even, mark, spaceDefault: none - no parity bit sent
stopBitsxxnumberThe number of stop bits sent to allow the receiver to detect the end of characters and resynchronize with the character stream.Supported values: 1, 1.5, 2Default: 1
handshakingMethodxxstringThe handshaking method used for flow control across the serial line.Supported values: none, XON/XOFF, RTS/CTSDefault: none - no handshaking
eolCharacterxxstringThe EOL character used to parse the UART output line-by-line.Supported values: LF, CRLFDefault: LF

##Memory Browser

The extension comes with a Memory Browser window. However, we have plans to deprecate and remove the window in favour of the Eclipse CDT Cloud Memory Inspector extension for Visual Studio Code which is available from the Visual Studio Code Marketplace and the Open VSX Registry.

Any feedback on these plans is welcomed in the discussion in GitHub issue #110.

##Contributions

We welcome any feedback and contributions on GitHub.

Please raise GitHub issues to submit feedback, defect reports, and enhancement requests.

Check our contribution guidelines for more information on how to contribute changes. And our developer documentation for how to build and develop the extension.

This open-source project is part of Eclipse CDT Cloud.

// Install

Open this extension directly in your IDE — no CLI, no extra tools.

Extension ID
eclipse-cdt.cdt-gdb-vscode

If your IDE doesn't open automatically, copy the ID above and paste it into the Extensions view (⌘P ext install <id>).

// Source signals

Publisher
Verified ✓
Downloads
792.8k
Published
2026-02-27
License
EPL-2.0
Source
repo
Homepage
link

Live from open-vsx.org. Refreshed hourly.

// Are you the author?

This listing is mirrored from Open VSX. Claim it to ship a native OXP build, customise the page, and respond to reviews.

Claim this listing

// Package Info

Version
2.7.0
Owner
@vsx-eclipse-cdt
Downloads
780.6k
Stars
0