[PATCH 3/3] 2.6.10 zr36067 driver - reduce stack size usage

From: Ronald S. Bultje
Date: Wed Dec 29 2004 - 17:58:18 EST


Hi Andrew/Linus,

>From original message (by Randy Dunlap):

"Reduce local variable (large struct) stack usage in zoran_do_ioctl()
from 1028 bytes to 324 bytes (on x86-32) by declaring & using only 1
"struct zoran_jpg_settings" instead of 5 instances of it. Reduced from 5
* 180 bytes to 1 * 180 bytes, plus other locals in each case."

Signed-off-by: Randy Dunlap <rddunlap@xxxxxxxx>
Signed-off-by: Ronald S. Bultje <rbultje@xxxxxxxxxxxxxxxxxxx>

Regards,

Ronald
--
Ronald S. Bultje <rbultje@xxxxxxxxxxxxxxxxxxx>
Index: linux-2.6.10/drivers/media/video/zoran_driver.c
===================================================================
--- linux-2.6.10.orig/drivers/media/video/zoran_driver.c 2004-12-29 21:56:27.714436423 +0100
+++ linux-2.6.10/drivers/media/video/zoran_driver.c 2004-12-29 21:57:20.784771392 +0100
@@ -2014,6 +2014,8 @@
{
struct zoran_fh *fh = file->private_data;
struct zoran *zr = fh->zr;
+ /* CAREFUL: used in multiple places here */
+ struct zoran_jpg_settings settings;

/* we might have older buffers lying around... We don't want
* to wait, but we do want to try cleaning them up ASAP. So
@@ -2462,7 +2464,6 @@
case BUZIOC_S_PARAMS:
{
struct zoran_params *bparams = arg;
- struct zoran_jpg_settings settings;
int res = 0;

dprintk(3, KERN_DEBUG "%s: BUZIOC_S_PARAMS\n", ZR_DEVNAME(zr));
@@ -2919,8 +2920,6 @@
}

if (fmt->fmt.pix.pixelformat == V4L2_PIX_FMT_MJPEG) {
- struct zoran_jpg_settings settings;
-
down(&zr->resource_lock);

settings = fh->jpg_settings;
@@ -3983,7 +3982,8 @@
{
struct v4l2_crop *crop = arg;
int res = 0;
- struct zoran_jpg_settings settings = fh->jpg_settings;
+
+ settings = fh->jpg_settings;

dprintk(3,
KERN_ERR
@@ -4065,9 +4065,10 @@
case VIDIOC_S_JPEGCOMP:
{
struct v4l2_jpegcompression *params = arg;
- struct zoran_jpg_settings settings = fh->jpg_settings;
int res = 0;

+ settings = fh->jpg_settings;
+
dprintk(3,
KERN_DEBUG
"%s: VIDIOC_S_JPEGCOMP - quality=%d, APPN=%d, APP_len=%d, COM_len=%d\n",
@@ -4151,8 +4152,7 @@
down(&zr->resource_lock);

if (fmt->fmt.pix.pixelformat == V4L2_PIX_FMT_MJPEG) {
- struct zoran_jpg_settings settings =
- fh->jpg_settings;
+ settings = fh->jpg_settings;

/* we actually need to set 'real' parameters now */
if ((fmt->fmt.pix.height * 2) >