forked from eden-emu/eden
		
	gdbstub: Remove global variable from public interface
Currently, this is only ever queried, so adding a function to check if the server is enabled is more sensible. If directly modifying this externally is ever desirable, it should be done by adding a function to the interface, rather than exposing implementation details directly.
This commit is contained in:
		
							parent
							
								
									3e4cc6b3d2
								
							
						
					
					
						commit
						ba20dd9b61
					
				
					 5 changed files with 23 additions and 16 deletions
				
			
		|  | @ -5,6 +5,7 @@ | |||
| // Originally written by Sven Peter <sven@fail0verflow.com> for anergistic.
 | ||||
| 
 | ||||
| #include <algorithm> | ||||
| #include <atomic> | ||||
| #include <climits> | ||||
| #include <csignal> | ||||
| #include <cstdarg> | ||||
|  | @ -130,7 +131,10 @@ static u16 gdbstub_port = 24689; | |||
| 
 | ||||
| static bool halt_loop = true; | ||||
| static bool step_loop = false; | ||||
| std::atomic<bool> g_server_enabled(false); | ||||
| 
 | ||||
| // If set to false, the server will never be started and no
 | ||||
| // gdbstub-related functions will be executed.
 | ||||
| static std::atomic<bool> server_enabled(false); | ||||
| 
 | ||||
| #ifdef _WIN32 | ||||
| WSADATA InitData; | ||||
|  | @ -902,7 +906,7 @@ void SetServerPort(u16 port) { | |||
| 
 | ||||
| void ToggleServer(bool status) { | ||||
|     if (status) { | ||||
|         g_server_enabled = status; | ||||
|         server_enabled = status; | ||||
| 
 | ||||
|         // Start server
 | ||||
|         if (!IsConnected() && Core::g_sys_core != nullptr) { | ||||
|  | @ -914,12 +918,12 @@ void ToggleServer(bool status) { | |||
|             Shutdown(); | ||||
|         } | ||||
| 
 | ||||
|         g_server_enabled = status; | ||||
|         server_enabled = status; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| static void Init(u16 port) { | ||||
|     if (!g_server_enabled) { | ||||
|     if (!server_enabled) { | ||||
|         // Set the halt loop to false in case the user enabled the gdbstub mid-execution.
 | ||||
|         // This way the CPU can still execute normally.
 | ||||
|         halt_loop = false; | ||||
|  | @ -998,7 +1002,7 @@ void Init() { | |||
| } | ||||
| 
 | ||||
| void Shutdown() { | ||||
|     if (!g_server_enabled) { | ||||
|     if (!server_enabled) { | ||||
|         return; | ||||
|     } | ||||
| 
 | ||||
|  | @ -1015,8 +1019,12 @@ void Shutdown() { | |||
|     LOG_INFO(Debug_GDBStub, "GDB stopped."); | ||||
| } | ||||
| 
 | ||||
| bool IsServerEnabled() { | ||||
|     return server_enabled; | ||||
| } | ||||
| 
 | ||||
| bool IsConnected() { | ||||
|     return g_server_enabled && gdbserver_socket != -1; | ||||
|     return IsServerEnabled() && gdbserver_socket != -1; | ||||
| } | ||||
| 
 | ||||
| bool GetCpuHaltFlag() { | ||||
|  |  | |||
|  | @ -5,7 +5,7 @@ | |||
| // Originally written by Sven Peter <sven@fail0verflow.com> for anergistic.
 | ||||
| 
 | ||||
| #pragma once | ||||
| #include <atomic> | ||||
| 
 | ||||
| #include "common/common_types.h" | ||||
| 
 | ||||
| namespace GDBStub { | ||||
|  | @ -24,10 +24,6 @@ struct BreakpointAddress { | |||
|     BreakpointType type; | ||||
| }; | ||||
| 
 | ||||
| /// If set to false, the server will never be started and no gdbstub-related functions will be
 | ||||
| /// executed.
 | ||||
| extern std::atomic<bool> g_server_enabled; | ||||
| 
 | ||||
| /**
 | ||||
|  * Set the port the gdbstub should use to listen for connections. | ||||
|  * | ||||
|  | @ -36,7 +32,7 @@ extern std::atomic<bool> g_server_enabled; | |||
| void SetServerPort(u16 port); | ||||
| 
 | ||||
| /**
 | ||||
|  * Set the g_server_enabled flag and start or stop the server if possible. | ||||
|  * Starts or stops the server if possible. | ||||
|  * | ||||
|  * @param status Set the server to enabled or disabled. | ||||
|  */ | ||||
|  | @ -48,6 +44,9 @@ void Init(); | |||
| /// Stop gdbstub server.
 | ||||
| void Shutdown(); | ||||
| 
 | ||||
| /// Checks if the gdbstub server is enabled.
 | ||||
| bool IsServerEnabled(); | ||||
| 
 | ||||
| /// Returns true if there is an active socket connection.
 | ||||
| bool IsConnected(); | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash