| 
									
										
										
										
											2016-02-21 13:13:52 +00:00
										 |  |  | // Copyright 2016 Citra Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-06 21:13:12 +00:00
										 |  |  | #include <cstddef>
 | 
					
						
							| 
									
										
										
										
											2016-02-21 13:13:52 +00:00
										 |  |  | #include <vector>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace DSP { | 
					
						
							|  |  |  | namespace HLE { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Reset the pipes by setting pipe positions back to the beginning.
 | 
					
						
							|  |  |  | void ResetPipes(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-06 21:13:12 +00:00
										 |  |  | enum class DspPipe { | 
					
						
							|  |  |  |     Debug = 0, | 
					
						
							|  |  |  |     Dma = 1, | 
					
						
							|  |  |  |     Audio = 2, | 
					
						
							|  |  |  |     Binary = 3, | 
					
						
							|  |  |  |     DspPipe_MAX | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-21 13:13:52 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Read a DSP pipe. | 
					
						
							|  |  |  |  * @param pipe_number The Pipe ID | 
					
						
							|  |  |  |  * @param length How much data to request. | 
					
						
							|  |  |  |  * @return The data read from the pipe. The size of this vector can be less than the length requested. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-03-06 21:13:12 +00:00
										 |  |  | std::vector<u8> PipeRead(DspPipe pipe_number, u32 length); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * How much data is left in pipe | 
					
						
							|  |  |  |  * @param pipe_number The Pipe ID | 
					
						
							|  |  |  |  * @return The amount of data remaning in the pipe. This is the maximum length PipeRead will return. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | size_t GetPipeReadableSize(DspPipe pipe_number); | 
					
						
							| 
									
										
										
										
											2016-02-21 13:13:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Write to a DSP pipe. | 
					
						
							|  |  |  |  * @param pipe_number The Pipe ID | 
					
						
							|  |  |  |  * @param buffer The data to write to the pipe. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-03-06 21:13:12 +00:00
										 |  |  | void PipeWrite(DspPipe pipe_number, const std::vector<u8>& buffer); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum class DspState { | 
					
						
							|  |  |  |     Off, | 
					
						
							|  |  |  |     On, | 
					
						
							|  |  |  |     Sleeping | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | /// Get the state of the DSP
 | 
					
						
							|  |  |  | DspState GetDspState(); | 
					
						
							| 
									
										
										
										
											2016-02-21 13:13:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | } // namespace HLE
 | 
					
						
							|  |  |  | } // namespace DSP
 |