diff options
author | Takashi Iwai <tiwai@suse.de> | 2017-02-11 08:21:56 +0100 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2017-02-13 14:48:43 +0100 |
commit | e2acecf2c88370f9d7252e7a05cd7b6d43aed720 (patch) | |
tree | 649d2dfe02f2d5d59b1723158a4b934b1a7689e8 /scripts/show_delta | |
parent | 3fe2cf7eb21ada0a9683b26c1ae309e7f5e90131 (diff) | |
download | linux-e2acecf2c88370f9d7252e7a05cd7b6d43aed720.tar.gz linux-e2acecf2c88370f9d7252e7a05cd7b6d43aed720.tar.bz2 linux-e2acecf2c88370f9d7252e7a05cd7b6d43aed720.zip |
ALSA: x86: Handle reset at prepare callback
Currently the driver handles some reset procedure at the trigger STOP
and the underrun functions, where both are executed in the interrupt
context. Especially the underrun function has a sync-loop to clear
the UNDERRUN status bit, and this is supposed to be one of plausible
causes of GPU hangup.
Since the job to be done in the interrupt handler should be minimum,
we move the reset function out of trigger and underrun, and push it
into the prepare (and hw_free) callbacks instead. Here a new flag,
need_reset, is introduced to indicate the requirement of the reset
procedure. This is for avoiding the multiple resets when PCM prepare
is called sequentially.
Also in the UNDERRUN bit-clear sync loop, take a longer pause to be in
the safer side. Taking a longer delay is no longer a problem now
because we're running in the normal context.
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'scripts/show_delta')
0 files changed, 0 insertions, 0 deletions