diff options
author | Alexander Holler <holler@ahsoftware.de> | 2012-04-21 00:11:07 +0200 |
---|---|---|
committer | Ben Hutchings <ben@decadent.org.uk> | 2012-08-10 00:24:51 +0100 |
commit | efb6d7d667e9b142c7608666da2c7dd4d6bbbee3 (patch) | |
tree | 722e7b0c28316140d8e524b3d704ee325d989043 /drivers | |
parent | 4344b8578fb31bb06abd397219ac0376f116f6f2 (diff) | |
download | lwn-efb6d7d667e9b142c7608666da2c7dd4d6bbbee3.tar.gz lwn-efb6d7d667e9b142c7608666da2c7dd4d6bbbee3.zip |
video/smscufx: fix line counting in fb_write
commit 2fe2d9f47cfe1a3e66e7d087368b3d7155b04c15 upstream.
Line 0 and 1 were both written to line 0 (on the display) and all subsequent
lines had an offset of -1. The result was that the last line on the display
was never overwritten by writes to /dev/fbN.
The origin of this bug seems to have been udlfb.
Signed-off-by: Alexander Holler <holler@ahsoftware.de>
Signed-off-by: Florian Tobias Schandinat <FlorianSchandinat@gmx.de>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/video/smscufx.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/video/smscufx.c b/drivers/video/smscufx.c index aaccffac67ab..dd9533ac9f10 100644 --- a/drivers/video/smscufx.c +++ b/drivers/video/smscufx.c @@ -904,7 +904,7 @@ static ssize_t ufx_ops_write(struct fb_info *info, const char __user *buf, result = fb_sys_write(info, buf, count, ppos); if (result > 0) { - int start = max((int)(offset / info->fix.line_length) - 1, 0); + int start = max((int)(offset / info->fix.line_length), 0); int lines = min((u32)((result / info->fix.line_length) + 1), (u32)info->var.yres); |