hle/ipc_helpers: Allow pushing signed values
This is kind of a large hole in the API, given we allow popping signed values. This fixes that.
This commit is contained in:
		
							parent
							
								
									8036154738
								
							
						
					
					
						commit
						7a8e2f3538
					
				
					 1 changed files with 22 additions and 0 deletions
				
			
		|  | @ -216,6 +216,11 @@ private: | |||
| 
 | ||||
| /// Push ///
 | ||||
| 
 | ||||
| template <> | ||||
| inline void ResponseBuilder::Push(s32 value) { | ||||
|     cmdbuf[index++] = static_cast<u32>(value); | ||||
| } | ||||
| 
 | ||||
| template <> | ||||
| inline void ResponseBuilder::Push(u32 value) { | ||||
|     cmdbuf[index++] = value; | ||||
|  | @ -234,11 +239,28 @@ inline void ResponseBuilder::Push(ResultCode value) { | |||
|     Push<u32>(0); | ||||
| } | ||||
| 
 | ||||
| template <> | ||||
| inline void ResponseBuilder::Push(s8 value) { | ||||
|     PushRaw(value); | ||||
| } | ||||
| 
 | ||||
| template <> | ||||
| inline void ResponseBuilder::Push(s16 value) { | ||||
|     PushRaw(value); | ||||
| } | ||||
| 
 | ||||
| template <> | ||||
| inline void ResponseBuilder::Push(s64 value) { | ||||
|     Push(static_cast<u32>(value)); | ||||
|     Push(static_cast<u32>(value >> 32)); | ||||
| } | ||||
| 
 | ||||
| template <> | ||||
| inline void ResponseBuilder::Push(u8 value) { | ||||
|     PushRaw(value); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| template <> | ||||
| inline void ResponseBuilder::Push(u16 value) { | ||||
|     PushRaw(value); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash