Подробности

[В начало]

Проблема в реализации № L0006

Краткое описание

drivers/media/video/usbvideo/quickcam_messenger.c: Возможно переполнение cam->input_physname, при использовании strncat (неверно задан третий параметр)

Подробное описание

В драйвере ./drivers/media/video/usbvideo/quickcam_messenger.c в строке 92 импользуется strncat:

  92         strncat(cam->input_physname, "/input0", sizeof(cam->input_physname));
где sizeof(cam->input_physname) вернет размер cam->input_phisname без длины нулевого символа. Но этот параметр должен быть - "максимальное количество байт для копирования", т.е. свободное место в cam->input_phisname - 1 (место под нулевой сивол): sizeof(cam->input_physname)-strlen(cam- >input_physname)-1. В этом случае в ядре используют strlcat, как в следующем драйвере: as: (код из 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/quickcam_messenger.c 
b/./b/drivers/media/video/usbvideo/quickcam_messenger.c
index 803d3e4..c4d1b96 100644
--- a/./a/drivers/media/video/usbvideo/quickcam_messenger.c
+++ b/./b/drivers/media/video/usbvideo/quickcam_messenger.c
@@ -89,7 +89,7 @@ static void qcm_register_input(struct qcm *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/217
commit

Статус

Исправлено в ядре 2.6.33-rc1

[В начало]