This section describes how to record time travel debugging (TTD) traces. There are two ways to record a Trace in WinDbg, Launch Executable (advanced) and Attach to a process.
Launch executable (advanced)
To launch an executable and record a TTD trace, follow these steps.
Enter the path to the user mode executable that you wish to record or select Browse to navigate to the executable. For information about working with the Launch Executable menu in WinDbg, see WinDbg - Start a user-mode session.
Check the Record with Time Travel Debugging box to record a trace when the executable is launched.
If you select Configure and Record you will be able to configure a location for the trace file.
To limit recording to specific modules, check "Record subset of execution" and type in the module names. For example, if you only want to record the execution of notepad.exe, type "notepad.exe" in the text box. If you want to record the execution of notepad.exe and kernelbase.dll, type "notepad.exe,kernelbase.dll" in the text box.
Select OK to launch the executable and start recording.
The recording dialog appears indicating the trace is being recorded.
To attach to a process and record a TTD trace, follow these steps.
In WinDbg, select File > Start debugging > Attach to process.
Select the user mode process that you wish to trace. For information about working with Attach to a process menu in WinDbg, see WinDbg - Start a user-mode session.
Check the Record Process with Time Travel Debugging box to create a trace when the executable is launched.
Select Attach to start recording.
The recording dialog appears indicating the trace is being recorded.
The process is being recorded, so this is where you need to cause the issue that you wish to debug. You may open a problematic file or select a specific button in the app to cause the event of interest to occur.
While the recording dialog box is being displayed you can:
Stop and debug - Choosing this will stop the recording, create the trace file and open the trace file so you can start debugging.
Cancel - Choosing this will stop the recording and create the trace file. You can open the trace file at a later time.
Once your recording is complete, close your app or hit Stop and debug.
Note
Both Stop and debug and Cancel will terminate the associated process.
When the application being recorded terminates, the trace file will be closed and written out to disk. This is the case if your program crashes as well.
When a trace file is opened, the debugger will automatically index the trace file. Indexing allows for more accurate and faster memory value look ups. This indexing process will take longer for larger trace files.
...
00007ffc`61f789d4 c3 ret
0:000> !index
Indexed 1/1 keyframes
Successfully created the index in 96ms.
Note
A keyframe is a location in a trace used for indexing. Keyframes are generated automatically. Larger traces will contain more keyframes. When the trace is indexed, the number of keyframes is displayed.
At this point you are at the beginning of the trace file and are ready to travel forward and backward in time.
Tip
Using breakpoints is a common approach to pause code execution at some event of interest. Unique to TTD, you can set a breakpoint and travel back in time until that breakpoint is hit after the trace has been recorded. The ability to examine the process state after an issue has happened, to determine the best location for a breakpoint, enables additional debugging workflows. For an example of using a breakpoint in the past, see Time Travel Debugging - Sample App Walkthrough.
Next Steps
Now that you have a recorded a TTD trace, you can replay the trace back or work with the trace file, for example sharing it with a co-worker. For more information, see these topics.
Learn how to efficiently debug your .NET app by using Visual Studio to fix your bugs quickly. Use the interactive debugger within Visual Studio to analyze and fix your C# applications.
In this episode of Defrag Tools, Chad Beeder is joined by James Pinkerton and Ivette Carreras to introduce a new feature of WinDbg Preview: Time Travel Debugging (TTD). Related Links: WinDbg Preview (download from Microsoft Store) Time Travel Debugging Overview (Online documentation) Debugging Tools for Windows Blog Time Travel Debugging FAQ Timeline: [00:00] Introductions [00:54] Introducing Time Travel Debugging (TTD) [05:06] Tracing [07:33] Debugging Forwards [09:23] Debugging Backwards! [13:31] Data is