diff options
author | Laurent Pinchart <laurent.pinchart@ideasonboard.com> | 2011-06-14 05:24:58 -0400 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2011-06-15 02:03:03 -0400 |
commit | a4aadc9311ed8459471a1d4580d3199230a88437 (patch) | |
tree | 28579a14e83e41f23e48b9c2000cccf82af823f9 /drivers/video/s3fb.c | |
parent | a1bb7010d494d3fcde3814d7a8ac609f1dff96ee (diff) |
s3fb: use display information in info not in var for panning
We must not use any information in the passed var besides xoffset,
yoffset and vmode as otherwise applications might abuse it.
Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Cc: Ondrej Zary <linux@rainbow-software.org>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'drivers/video/s3fb.c')
-rw-r--r-- | drivers/video/s3fb.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/video/s3fb.c b/drivers/video/s3fb.c index 4ca5d0c8fe84..0f9af1aa5077 100644 --- a/drivers/video/s3fb.c +++ b/drivers/video/s3fb.c | |||
@@ -1019,12 +1019,13 @@ static int s3fb_pan_display(struct fb_var_screeninfo *var, struct fb_info *info) | |||
1019 | unsigned int offset; | 1019 | unsigned int offset; |
1020 | 1020 | ||
1021 | /* Calculate the offset */ | 1021 | /* Calculate the offset */ |
1022 | if (var->bits_per_pixel == 0) { | 1022 | if (info->var.bits_per_pixel == 0) { |
1023 | offset = (var->yoffset / 16) * (var->xres_virtual / 2) + (var->xoffset / 2); | 1023 | offset = (var->yoffset / 16) * (info->var.xres_virtual / 2) |
1024 | + (var->xoffset / 2); | ||
1024 | offset = offset >> 2; | 1025 | offset = offset >> 2; |
1025 | } else { | 1026 | } else { |
1026 | offset = (var->yoffset * info->fix.line_length) + | 1027 | offset = (var->yoffset * info->fix.line_length) + |
1027 | (var->xoffset * var->bits_per_pixel / 8); | 1028 | (var->xoffset * info->var.bits_per_pixel / 8); |
1028 | offset = offset >> 2; | 1029 | offset = offset >> 2; |
1029 | } | 1030 | } |
1030 | 1031 | ||