External email: Use caution opening links or attachmentsalso to prevent blocking and to let is sleep and wakeup based on wait queue to evaluate condition to proceed with the task
06.04.2020 23:20, Sowjanya Komatineni ÐÐÑÐÑ:
On 4/6/20 1:02 PM, Dmitry Osipenko wrote:So the "interrupt" is for getting event about kthread_should_stop(),
External email: Use caution opening links or attachmentsTo allow it to sleep until wakeup on thread it to avoid constant
04.04.2020 04:25, Sowjanya Komatineni ÐÐÑÐÑ:
...
+static int chan_capture_kthread_start(void *data)Is it really okay that list_empty() isn't protected with a lock?
+{
+ struct tegra_vi_channel *chan = data;
+ struct tegra_channel_buffer *buf;
+ int err = 0;
+ int caps_inflight;
+
+ set_freezable();
+
+ while (1) {
+ try_to_freeze();
+
+ wait_event_interruptible(chan->start_wait,
+ !list_empty(&chan->capture) ||
+ kthread_should_stop());
Why wait_event is "interruptible"?
checking for condition even when no buffers are ready, basically to
prevent blocking.
correct?