DescriptionFix use-after-free of m_currentSpeechUtterance.
SpeechSynthesis.cpp incorrectly assumed that calling
m_platformSpeechSynthesizer->cancel() would immediately call
didFinishSpeaking or speakingErrorOccurred, which would null out
m_currentSpeechUtterance. This assumption was true in WebKit/Mac, but
Chromium's platform implementation is asynchronous, so that call may
come later.
Fix the issue and simplify the logic by getting rid of the raw pointer
to the current utterance altogether. Now the RefPtr at the front of the
utterance queue is the current utterance, and the platform implementation
is allowed to fire events on utterances that are no longer in the queue.
BUG=344881
R=abarth@chromium.org
Committed: https://src.chromium.org/viewvc/blink?view=rev&revision=168092
Committed: https://src.chromium.org/viewvc/blink?view=rev&revision=168169
Committed: https://src.chromium.org/viewvc/blink?view=rev&revision=168171
Patch Set 1 #Patch Set 2 : Added test #Patch Set 3 : Fix nullptr cast #Patch Set 4 : Fix nullptr again? #
Messages
Total messages: 8 (0 generated)
|