mirror of
				https://github.com/PabloMK7/citra.git
				synced 2025-10-30 21:30:04 +00:00 
			
		
		
		
	audio_core: hle: mf: correctly handle stream change
This commit is contained in:
		
							parent
							
								
									01e0902fa4
								
							
						
					
					
						commit
						f0e041e27a
					
				
					 1 changed files with 12 additions and 7 deletions
				
			
		|  | @ -32,9 +32,7 @@ private: | ||||||
|     DWORD out_stream_id = 0; |     DWORD out_stream_id = 0; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| WMFDecoder::Impl::Impl(Memory::MemorySystem& memory) : memory(memory) { | WMFDecoder::Impl::Impl(Memory::MemorySystem& memory) : memory(memory) {} | ||||||
|     MFCoInit(); |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| WMFDecoder::Impl::~Impl() { | WMFDecoder::Impl::~Impl() { | ||||||
|     Clear(); |     Clear(); | ||||||
|  | @ -67,8 +65,8 @@ std::optional<BinaryResponse> WMFDecoder::Impl::ProcessRequest(const BinaryReque | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::optional<BinaryResponse> WMFDecoder::Impl::Initalize(const BinaryRequest& request) { | std::optional<BinaryResponse> WMFDecoder::Impl::Initalize(const BinaryRequest& request) { | ||||||
|     if (initialized) { |     if (!initialized) { | ||||||
|         Clear(); |         MFCoInit(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     BinaryResponse response; |     BinaryResponse response; | ||||||
|  | @ -141,7 +139,7 @@ MFOutputState WMFDecoder::Impl::DecodingLoop(ADTSData adts_header, | ||||||
|         // for status = 2, reset MF
 |         // for status = 2, reset MF
 | ||||||
|         if (output_status == MFOutputState::NeedReconfig) { |         if (output_status == MFOutputState::NeedReconfig) { | ||||||
|             Clear(); |             Clear(); | ||||||
|             return MFOutputState::FatalError; |             return MFOutputState::NeedReconfig; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // for status = 3, try again with new buffer
 |         // for status = 3, try again with new buffer
 | ||||||
|  | @ -182,6 +180,7 @@ std::optional<BinaryResponse> WMFDecoder::Impl::Decode(const BinaryRequest& requ | ||||||
|     std::array<std::vector<u8>, 2> out_streams; |     std::array<std::vector<u8>, 2> out_streams; | ||||||
|     unique_mfptr<IMFSample> sample; |     unique_mfptr<IMFSample> sample; | ||||||
|     MFInputState input_status = MFInputState::OK; |     MFInputState input_status = MFInputState::OK; | ||||||
|  |     MFOutputState output_status = MFOutputState::OK; | ||||||
|     std::optional<ADTSMeta> adts_meta = DetectMediaType((char*)data, request.size); |     std::optional<ADTSMeta> adts_meta = DetectMediaType((char*)data, request.size); | ||||||
| 
 | 
 | ||||||
|     if (!adts_meta) { |     if (!adts_meta) { | ||||||
|  | @ -209,8 +208,9 @@ std::optional<BinaryResponse> WMFDecoder::Impl::Decode(const BinaryRequest& requ | ||||||
| 
 | 
 | ||||||
|     while (true) { |     while (true) { | ||||||
|         input_status = SendSample(transform.get(), in_stream_id, sample.get()); |         input_status = SendSample(transform.get(), in_stream_id, sample.get()); | ||||||
|  |         output_status = DecodingLoop(adts_meta->ADTSHeader, out_streams); | ||||||
| 
 | 
 | ||||||
|         if (DecodingLoop(adts_meta->ADTSHeader, out_streams) == MFOutputState::FatalError) { |         if (output_status == MFOutputState::FatalError) { | ||||||
|             // if the decode issues are caused by MFT not accepting new samples, try again
 |             // if the decode issues are caused by MFT not accepting new samples, try again
 | ||||||
|             // NOTICE: you are required to check the output even if you already knew/guessed
 |             // NOTICE: you are required to check the output even if you already knew/guessed
 | ||||||
|             // MFT didn't accept the input sample
 |             // MFT didn't accept the input sample
 | ||||||
|  | @ -221,6 +221,11 @@ std::optional<BinaryResponse> WMFDecoder::Impl::Decode(const BinaryRequest& requ | ||||||
| 
 | 
 | ||||||
|             LOG_ERROR(Audio_DSP, "Errors occurred when receiving output"); |             LOG_ERROR(Audio_DSP, "Errors occurred when receiving output"); | ||||||
|             return response; |             return response; | ||||||
|  |         } else if (output_status == MFOutputState::NeedReconfig) { | ||||||
|  |             // re-initialize the whole thing to adapt to new parameters
 | ||||||
|  |             this->Initalize(request); | ||||||
|  |             // decode again
 | ||||||
|  |             return this->Decode(request); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         break; // jump out of the loop if at least we don't have obvious issues
 |         break; // jump out of the loop if at least we don't have obvious issues
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue