Подробности
[В начало]
Проблема в реализации № L0003
Краткое описание
drivers/media/video/hdpvr/hdpvr-core.c(hdpvr-video.c): Нарушен баланс блокировки мютекса
Подробное описание
В драйвере ./drivers/media/video/hdpvr/hdpvr-core.c в функции device_authorization: Если, после блокировки мютекса (строка 4) функция usb_control_msg вернула ret!=46, то мы идем на метку error. В этом случае, перед выходом из функции, мютекс должен быть разблокирован.
01) static int device_authorization(struct hdpvr_device *dev) 02) { 03) ............ 04) mutex_lock(&dev->usbc_mutex); 05) ret = usb_control_msg(dev->udev, 06) usb_rcvctrlpipe(dev->udev, 0), 07) rcv_request, 0x80 | request_type, 08) 0x0400, 0x0003, 09) dev->usbc_buf, 46,10000); 10) if (ret != 46) { 11) v4l2_err(&dev->v4l2_dev, 12) "unexpected answer of status request, len %d ", ret); 13) goto error; 14) } 15) ................. 16) error: 17) 18) return retval; 19) }
Способы устранения
--- diff --git a/a/drivers/media/video/hdpvr/hdpvr-core.c b/b/drivers/media/video/hdpvr/hdpvr-core.c index 188bd5a..1d03d1c 100644 --- a/a/drivers/media/video/hdpvr/hdpvr-core.c +++ b/b/drivers/media/video/hdpvr/hdpvr-core.c @@ -126,7 +126,7 @@ static int device_authorization(struct hdpvr_device *dev) char *print_buf = kzalloc(5*buf_size+1, GFP_KERNEL); if (!print_buf) { v4l2_err(&dev->v4l2_dev, "Out of memory "); - goto error; + return retval; } #endif @@ -188,10 +188,10 @@ static int device_authorization(struct hdpvr_device *dev) 10000); v4l2_dbg(MSG_INFO, hdpvr_debug, &dev->v4l2_dev, "magic request returned %d ", ret); - mutex_unlock(&dev->usbc_mutex); retval = ret != 8; error: + moutex_unlock(&dev->usbc_mutex); return retval; }
Компонент
linux-kernel 2.6.30
Принято
http://lkml.org/lkml/2009/6/19/274
commit
Статус
Исправлено в ядре 2.6.32
[В начало]
»