public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH V0 0/1] ALSA: pcm: fix blocking while loop in
@ 2022-02-25 10:39 Raghu Bankapur
  2022-02-25 10:39 ` [PATCH V0 1/1] ALSA: pcm: fix blocking while loop in snd_pcm_update_hw_ptr0() Raghu Bankapur
  0 siblings, 1 reply; 5+ messages in thread
From: Raghu Bankapur @ 2022-02-25 10:39 UTC (permalink / raw)
  To: Vinod Koul, Jaroslav Kysela, Takashi Iwai, ierre-Louis Bossart,
	Mark Brown, Kai Vehmanen, Ranjani Sridharan, Takashi Sakamoto,
	Raghu Bankapur, alsa-devel, Zubin Mithra, linux-kernel
  Cc: Krishna Jha

When period interrupts are disabled, while loop in snd_pcm_update_hw_ptr0()
results in the machine locking up if runtime->hw_ptr_buffer_jiffies is 0.
Validate runtime->hw_ptr_buffer_jiffies value before while loop to avoid
delta check.


when runtime->hw_ptr_buffer_jiffies is 0 then update of while condition 
hdelta > xrun_threshold will be always true because hdelta will not
change. This will lead to infinite loop causing lock-up

This issue found during stability test, below log explains CPU lock-up on CPU1

[ 922.249028] sched: RT throttling activated for rt_rq ffffffc0f9970778 (cpu 1)
[ 922.249028] potential CPU hogs:
[ 922.249028] **FastCapture (11426)
[ 922.249105] ------------[ cut here ]---------

To fix this lock-up issue, added new condition to check if runtime->
hw_ptr_buffer_jiffies is ZERO or negative.

Raghu Bankapur (1):
  ALSA: pcm: fix blocking while loop in snd_pcm_update_hw_ptr0()

 sound/core/pcm_lib.c | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

-- 
2.17.1


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2022-02-28 15:58 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-02-25 10:39 [PATCH V0 0/1] ALSA: pcm: fix blocking while loop in Raghu Bankapur
2022-02-25 10:39 ` [PATCH V0 1/1] ALSA: pcm: fix blocking while loop in snd_pcm_update_hw_ptr0() Raghu Bankapur
2022-02-25 10:52   ` Jaroslav Kysela
2022-02-25 11:23     ` Takashi Iwai
     [not found]       ` <35bfd332-891f-1323-8b61-9e4e2fc5cd1c@quicinc.com>
2022-02-28 15:58         ` Takashi Iwai

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox