patch-2.4.7 linux/drivers/char/drm/radeon_bufs.c

Next file: linux/drivers/char/dsp56k.c
Previous file: linux/drivers/char/drm/r128_bufs.c
Back to the patch index
Back to the overall index

diff -u --recursive --new-file v2.4.6/linux/drivers/char/drm/radeon_bufs.c linux/drivers/char/drm/radeon_bufs.c
@@ -100,6 +100,15 @@
 		return -ENOMEM; /* May only call once for each order */
 	}
 
+	/* Might be too low a limit. XFree folks need to fix this properly */
+	
+	if(count < 0 || count > 4096)
+	{
+		up(&dev->struct_sem);
+		atomic_dec(&dev->buf_alloc);
+		return -EINVAL;
+	}
+		
 	entry->buflist = drm_alloc(count * sizeof(*entry->buflist),
 				   DRM_MEM_BUFS);
 	if (!entry->buflist) {

FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)