parent
							
								
									b13989f11e
								
							
						
					
					
						commit
						5811eade37
					
				
					 1 changed files with 6 additions and 6 deletions
				
			
		|  | @ -13,11 +13,11 @@ Xcode seems to be more willing to harness an application properly if it's nomina | |||
| 2. In Xcode, create a New Project. For the template, navigate to "Other", then search for or select "External Build System". For the "Build Tool", provide the location of your `dotnet` installation. For me, this is `/usr/local/share/dotnet/dotnet`. Create the project in any directory you wish; for convenience, you may want to create a folder in your cloned Ryujinx repository named `macos-xcode` or similar.  | ||||
| 3. With your project created, for the build Arguments, substitute `build -c debug src/Ryujinx`. For the directory, browse and pick the base directory for your cloned Ryujinx repository that contains the `Ryujinx.sln` file. Uncheck "Pass build settings in environment." | ||||
|     * *If you have better knowledge of Ryujinx dotnet build arguments, please put whatever here for your preferred Ryujinx build settings. This is just the most minimal way I found to get it building without poring over Ryujinx build scripts.* | ||||
| 5. Optionally, add all project files to the project with "File->Add Files to...", creating folder references and selecting the build target. | ||||
| 7. Build the project. | ||||
| 8. Tell Xcode the binary you want it to debug by navigating to Product->Scheme->Edit Scheme. Under Info, then Executable, select Other.... Then, at the prompt, navigate to your repository folder, then the binary location. In the example from step 3, this would be `<base directory>/src/Ryujinx/bin/Debug/net8.0/Ryujinx`. | ||||
| 9. Also in the Scheme editor, under Options, then "GPU Frame Capture", select "Metal" instead of "Automatically." | ||||
| 10. At this point, Ryujinx should be building properly, and launching and harnessing properly within the Xcode debugger. However, we're not done yet! | ||||
| 4. Optionally, add all project files to the project with "File->Add Files to...", creating folder references and selecting the build target. | ||||
| 5. Build the project. | ||||
| 6. Tell Xcode the binary you want it to debug by navigating to Product->Scheme->Edit Scheme. Under Info, then Executable, select Other.... Then, at the prompt, navigate to your repository folder, then the binary location. In the example from step 3, this would be `<base directory>/src/Ryujinx/bin/Debug/net8.0/Ryujinx`. | ||||
| 7. Also in the Scheme editor, under Options, then "GPU Frame Capture", select "Metal" instead of "Automatically." | ||||
| 8. At this point, Ryujinx should be building properly, and launching and harnessing properly within the Xcode debugger. However, we're not done yet! | ||||
| 
 | ||||
| ### Build Debug MoltenVK | ||||
| 
 | ||||
|  | @ -32,5 +32,5 @@ With debug MoltenVK in hand, replace the `libMoltenVK.dylib` binary in the `src/ | |||
| 
 | ||||
| You should now be able to produce frame captures stably within Xcode of Ryujinx titles. To save a capture as a shareable file, use the Export button in the Summary tab. A couple of other notes: | ||||
| * You will need to tell lldb to ignore `SIGUSR1`; for whatever reason, this pops up everywhere once guest code is loaded. To do so within your current lldb debugger session, just enter ```pro hand -p true -s false SIGUSR1```. | ||||
| * We did not enter any of the usual "secret sauce" for enabling capture, like adding `Metal Capture Enabled = YES` to the Info.plist file or `MTL_CAPTURE_ENABLE=1` to our environment variables. In my testing, none of these variables actually exposed the option for frame capture in Xcode. Rather, the important determinant in the option being enabled was what we did in Step 9. If you better integrate Ryujinx's build scripts, these other options might come into play more. | ||||
| * We did not enter any of the usual "secret sauce" for enabling capture, like adding `Metal Capture Enabled = YES` to the Info.plist file or `MTL_CAPTURE_ENABLE=1` to our environment variables. In my testing, none of these variables actually exposed the option for frame capture in Xcode. Rather, the important determinant in the option being enabled was what we did in Step 7. If you better integrate Ryujinx's build scripts, these other options might come into play more. | ||||
| * The usual caveats for Ryujinx debugging apply. Mainly, if we aren't using the Hypervisor, we need to use the Software memory mode, or else hit segfaults nearly instantly in guest code. | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 jcm
						jcm