[ALSA] timer: fix timer instance memory allocation checks
Modules: Timer Midlevel Add checks to return -ENOMEM in case snd_timer_instance_new() fails. Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
This commit is contained in:
parent
2dfbeca9e9
commit
2fd43d1159
|
@ -251,6 +251,10 @@ int snd_timer_open(snd_timer_instance_t **ti,
|
||||||
}
|
}
|
||||||
down(®ister_mutex);
|
down(®ister_mutex);
|
||||||
timeri = snd_timer_instance_new(owner, NULL);
|
timeri = snd_timer_instance_new(owner, NULL);
|
||||||
|
if (!timeri) {
|
||||||
|
up(®ister_mutex);
|
||||||
|
return -ENOMEM;
|
||||||
|
}
|
||||||
timeri->slave_class = tid->dev_sclass;
|
timeri->slave_class = tid->dev_sclass;
|
||||||
timeri->slave_id = tid->device;
|
timeri->slave_id = tid->device;
|
||||||
timeri->flags |= SNDRV_TIMER_IFLG_SLAVE;
|
timeri->flags |= SNDRV_TIMER_IFLG_SLAVE;
|
||||||
|
@ -272,27 +276,29 @@ int snd_timer_open(snd_timer_instance_t **ti,
|
||||||
timer = snd_timer_find(tid);
|
timer = snd_timer_find(tid);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (timer) {
|
if (!timer) {
|
||||||
if (!list_empty(&timer->open_list_head)) {
|
|
||||||
timeri = (snd_timer_instance_t *)list_entry(timer->open_list_head.next, snd_timer_instance_t, open_list);
|
|
||||||
if (timeri->flags & SNDRV_TIMER_IFLG_EXCLUSIVE) {
|
|
||||||
up(®ister_mutex);
|
|
||||||
return -EBUSY;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
timeri = snd_timer_instance_new(owner, timer);
|
|
||||||
if (timeri) {
|
|
||||||
timeri->slave_class = tid->dev_sclass;
|
|
||||||
timeri->slave_id = slave_id;
|
|
||||||
if (list_empty(&timer->open_list_head) && timer->hw.open)
|
|
||||||
timer->hw.open(timer);
|
|
||||||
list_add_tail(&timeri->open_list, &timer->open_list_head);
|
|
||||||
snd_timer_check_master(timeri);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
up(®ister_mutex);
|
up(®ister_mutex);
|
||||||
return -ENODEV;
|
return -ENODEV;
|
||||||
}
|
}
|
||||||
|
if (!list_empty(&timer->open_list_head)) {
|
||||||
|
timeri = list_entry(timer->open_list_head.next,
|
||||||
|
snd_timer_instance_t, open_list);
|
||||||
|
if (timeri->flags & SNDRV_TIMER_IFLG_EXCLUSIVE) {
|
||||||
|
up(®ister_mutex);
|
||||||
|
return -EBUSY;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
timeri = snd_timer_instance_new(owner, timer);
|
||||||
|
if (!timeri) {
|
||||||
|
up(®ister_mutex);
|
||||||
|
return -ENOMEM;
|
||||||
|
}
|
||||||
|
timeri->slave_class = tid->dev_sclass;
|
||||||
|
timeri->slave_id = slave_id;
|
||||||
|
if (list_empty(&timer->open_list_head) && timer->hw.open)
|
||||||
|
timer->hw.open(timer);
|
||||||
|
list_add_tail(&timeri->open_list, &timer->open_list_head);
|
||||||
|
snd_timer_check_master(timeri);
|
||||||
up(®ister_mutex);
|
up(®ister_mutex);
|
||||||
*ti = timeri;
|
*ti = timeri;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
Loading…
Reference in New Issue