Merge branch 'v0.20.x'
This commit is contained in:
		| @@ -178,6 +178,20 @@ VorbisDecoder::SubmitInit() | ||||
| 	client.Ready(audio_format, eos_granulepos > 0, duration); | ||||
| } | ||||
|  | ||||
| #ifdef HAVE_TREMOR | ||||
| static inline int16_t tremor_clip_sample(int32_t x) | ||||
| { | ||||
| 	x >>= 9; | ||||
|  | ||||
| 	if (x < INT16_MIN) | ||||
| 		return INT16_MIN; | ||||
| 	if (x > INT16_MAX) | ||||
| 		return INT16_MAX; | ||||
|  | ||||
| 	return x; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| bool | ||||
| VorbisDecoder::SubmitSomePcm() | ||||
| { | ||||
| @@ -197,7 +211,7 @@ VorbisDecoder::SubmitSomePcm() | ||||
| 		auto *dest = &buffer[c]; | ||||
|  | ||||
| 		for (size_t i = 0; i < n_frames; ++i) { | ||||
| 			*dest = *src++; | ||||
| 			*dest = tremor_clip_sample(*src++); | ||||
| 			dest += channels; | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Max Kellermann
					Max Kellermann