mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-02-23 20:11:14 +03:00
96 lines
2.8 KiB
Markdown
96 lines
2.8 KiB
Markdown
|
Proton Debugging Tips For Windows Developers
|
||
|
============================================
|
||
|
|
||
|
*This document is intended for people who are used to working with games natively
|
||
|
running on Windows and want to use familiar tools.*
|
||
|
|
||
|
Table Of Contents
|
||
|
-----------------
|
||
|
|
||
|
* [Analyzing Minidumps](#analyzing-minidumps)
|
||
|
* [Introduction](#introduction)
|
||
|
* [Visual Studio](#visual-studio)
|
||
|
* [WinDbg](#windbg)
|
||
|
* [Live Debugging](#live-debugging)
|
||
|
* [How To](#how-to)
|
||
|
* [Getting A Debug Build Of Proton](#getting-a-debug-build-of-proton)
|
||
|
|
||
|
Analyzing Minidumps
|
||
|
-------------------
|
||
|
|
||
|
### Introduction
|
||
|
|
||
|
Starting Proton 9 every released build (includes stable and experimental) the
|
||
|
build is uploaded to a symbol store. Any tool that can understand those (e.g.
|
||
|
Visual Studio, WinDbg) can be pointed to
|
||
|
<https://proton-archive.steamos.cloud/>.
|
||
|
|
||
|
|
||
|
### Visual Studio
|
||
|
|
||
|
1. After opening a minidump in Visual Studio you need to click on "set symbol
|
||
|
paths" or click Tools -> Options -> Debugging -> Symbols. This is global and
|
||
|
needs to be done only once.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/6d7ed/6d7ed5a3ebdac0c715988d8589d04bf717c64422" alt="screenshot of the action described above"
|
||
|
|
||
|
2. Click on the plus button and add <https://proton-archive.steamos.cloud/>.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/43147/43147927cfdcd7c0f8d2d043e041287c852712f0" alt="screenshot of the action described above"
|
||
|
|
||
|
3. Close the Options Window and proceed to any debugging action as you would
|
||
|
normally do. You should see symbols being loaded from the just added location.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/60862/60862f92e67e0a32585950029d55ac883933f728" alt="screenshot of the action described above"
|
||
|
|
||
|
4. Debugging should now work just like the native one including call stack,
|
||
|
variables, etc. Too see the Wine/Proton part of callstack you can select "show
|
||
|
external code".
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/6a009/6a009c56964434bdf822e903b74663509f5f77f6" alt="screenshot of the action described above"
|
||
|
|
||
|
|
||
|
### WinDbg
|
||
|
|
||
|
1. Click File -> Settings -> Debugging Settings
|
||
|
2. Enter `srv*https://proton-archive.steamos.cloud/` in the "symbol path" field.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/6e353/6e3532ed10e6efd2d74f1950c28d5e74551621bb" alt=""
|
||
|
|
||
|
4. Debugging should now work just like the native one including call stack,
|
||
|
variables, etc.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/b2497/b2497d1f68d9c31f620dffeee5e687ebdfa7c4d2" alt=""
|
||
|
|
||
|
|
||
|
Live Debugging
|
||
|
--------------
|
||
|
|
||
|
### How To
|
||
|
|
||
|
For loading dev builds of games onto a Steam Deck see
|
||
|
<https://partner.steamgames.com/doc/steamdeck/loadgames>
|
||
|
|
||
|
For live debugging see
|
||
|
<https://partner.steamgames.com/doc/steamdeck/debugging>
|
||
|
|
||
|
For best results either add a symbol server to Visual Studio as described above
|
||
|
or use a debug build of Proton.
|
||
|
|
||
|
|
||
|
### Getting A Debug Build Of Proton
|
||
|
|
||
|
Debug builds contain symbols and should be used for live debugging session.
|
||
|
|
||
|
1. Locate the version of proton you are using in your Steam Library (e.g. Proton
|
||
|
Experimental), click on a cog and select properties.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/0c5ae/0c5aee0ac09fb833c34f5b818f4173651a10ae6b" alt=""
|
||
|
|
||
|
2. In the "betas" tab select "debug - unstripped".
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/5162d/5162d9e6b809c1bb8bf3f2dfcd0a94e3f55da0c4" alt=""
|
||
|
|
||
|
3. Chosen Proton version will now download and update and the symbols will be
|
||
|
available.
|