Подробности
        
                          [В начало]
Проблема в реализации № L0008
Краткое описание
drivers/media/video/usbvideo/koniacwc.c: Возможно переполнение cam->input_physname, при использовании strncat (неверно задан третий параметр)
Подробное описание
В драйвере ./drivers/media/video/usbvideo/konicawc.c в строке 227:
227 usb_make_path(dev, cam->input_physname, sizeof(cam- >input_physname)); After this line we use strncat: 228 strncat(cam->input_physname, "/input0", sizeof(cam- >input_physname));В этом коде sizeof(cam->input_physname) возвращает длину буффера cam->input_phisname без длины нулевого сивола. В действительности этот параметр должен быть максимальным количеством символов, которые можно скопировать в буффер назначения -1 ("maximum numbers of bytes to copy"), т.е.: sizeof(cam->input_physname)-strlen(cam- >input_physname)-1. В этом случае, после вызова usb_make_path в драцерах обычно используется функция strlcat. Как в драйвере drivers/hid/usbhid/hid-core.c:
1152 usb_make_path(dev, hid->phys, sizeof(hid->phys)); 1153 strlcat(hid->phys, "/input", sizeof(hid->phys));
Способы устранения
diff --git a/./a/drivers/media/video/usbvideo/konicawc.c 
b/./b/drivers/media/video/usbvideo/konicawc.c
index 31d57f2..a0addcb 100644
--- a/./a/drivers/media/video/usbvideo/konicawc.c
+++ b/./b/drivers/media/video/usbvideo/konicawc.c
@@ -225,7 +225,7 @@ static void konicawc_register_input(struct konicawc *cam, 
struct usb_device *dev
 	int error;
 
 	usb_make_path(dev, cam->input_physname, sizeof(cam->input_physname));
-	strncat(cam->input_physname, "/input0", sizeof(cam->input_physname));
+	strlcat(cam->input_physname, "/input0", sizeof(cam->input_physname));
 
 	cam->input = input_dev = input_allocate_device();
 	if (!input_dev) {
                    Компонент
linux-kernel 2.6.31
Принято
http://lkml.org/lkml/2009/10/7/218
commit
Статус
Исправлено в ядре 2.6.33-rc1
[В начало]
»