Fix possible crash on AudioDriver::input_buffer_write

This commit is contained in:
Marcelo Fernandez 2019-03-02 15:01:26 -03:00
parent 90038a4eef
commit f529649cec
2 changed files with 13 additions and 7 deletions

View file

@ -150,7 +150,7 @@ void AudioStreamPlaybackMicrophone::_mix_internal(AudioFrame *p_buffer, int p_fr
input_ofs = 0; input_ofs = 0;
} else { } else {
for (int i = 0; i < p_frames; i++) { for (int i = 0; i < p_frames; i++) {
if (input_size > input_ofs) { if (input_size > input_ofs && (int)input_ofs < buf.size()) {
float l = (buf[input_ofs++] >> 16) / 32768.f; float l = (buf[input_ofs++] >> 16) / 32768.f;
if ((int)input_ofs >= buf.size()) { if ((int)input_ofs >= buf.size()) {
input_ofs = 0; input_ofs = 0;

View file

@ -90,6 +90,7 @@ void AudioDriver::input_buffer_init(int driver_buffer_frames) {
void AudioDriver::input_buffer_write(int32_t sample) { void AudioDriver::input_buffer_write(int32_t sample) {
if ((int)input_position < input_buffer.size()) {
input_buffer.write[input_position++] = sample; input_buffer.write[input_position++] = sample;
if ((int)input_position >= input_buffer.size()) { if ((int)input_position >= input_buffer.size()) {
input_position = 0; input_position = 0;
@ -97,6 +98,9 @@ void AudioDriver::input_buffer_write(int32_t sample) {
if ((int)input_size < input_buffer.size()) { if ((int)input_size < input_buffer.size()) {
input_size++; input_size++;
} }
} else {
WARN_PRINTS("input_buffer_write: Invalid input_position=" + itos(input_position) + " input_buffer.size()=" + itos(input_buffer.size()));
}
} }
AudioDriver::SpeakerMode AudioDriver::get_speaker_mode_by_total_channels(int p_channels) const { AudioDriver::SpeakerMode AudioDriver::get_speaker_mode_by_total_channels(int p_channels) const {
@ -145,6 +149,8 @@ AudioDriver::AudioDriver() {
_last_mix_time = 0; _last_mix_time = 0;
_mix_amount = 0; _mix_amount = 0;
input_position = 0;
input_size = 0;
#ifdef DEBUG_ENABLED #ifdef DEBUG_ENABLED
prof_time = 0; prof_time = 0;