drivers/lcd: ssd1306: fix memory corruption caused by ssd1306_getrun(). ssd1306_getrun was writing one extra byte (with value 0) past target buffer when pixlen is multiple of 8. When pixlen was not multiple of 8, last byte of buffer was fully cleared, instead of modifying only the (pixlen % 8) bits of last byte.
This commit is contained in:
parent
3dfeb9e59f
commit
89cc4741ac
@ -569,7 +569,6 @@ static int ssd1306_getrun(fb_coord_t row, fb_coord_t col, FAR uint8_t *buffer,
|
|||||||
usrmask = LS_BIT;
|
usrmask = LS_BIT;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
*buffer = 0;
|
|
||||||
for (i = 0; i < pixlen; i++)
|
for (i = 0; i < pixlen; i++)
|
||||||
{
|
{
|
||||||
/* Set or clear the corresponding bit */
|
/* Set or clear the corresponding bit */
|
||||||
@ -583,17 +582,17 @@ static int ssd1306_getrun(fb_coord_t row, fb_coord_t col, FAR uint8_t *buffer,
|
|||||||
{
|
{
|
||||||
*buffer |= usrmask;
|
*buffer |= usrmask;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
*buffer &= ~usrmask;
|
||||||
|
}
|
||||||
|
|
||||||
/* Inc/Decrement to the next destination pixel. Hmmmm. It looks like
|
/* Inc/Decrement to the next destination pixel. */
|
||||||
* this logic could write past the end of the user buffer. Revisit
|
|
||||||
* this!
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifdef CONFIG_NX_PACKEDMSFIRST
|
#ifdef CONFIG_NX_PACKEDMSFIRST
|
||||||
if (usrmask == LS_BIT)
|
if (usrmask == LS_BIT)
|
||||||
{
|
{
|
||||||
buffer++;
|
buffer++;
|
||||||
*buffer = 0;
|
|
||||||
usrmask = MS_BIT;
|
usrmask = MS_BIT;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -604,7 +603,6 @@ static int ssd1306_getrun(fb_coord_t row, fb_coord_t col, FAR uint8_t *buffer,
|
|||||||
if (usrmask == MS_BIT)
|
if (usrmask == MS_BIT)
|
||||||
{
|
{
|
||||||
buffer++;
|
buffer++;
|
||||||
*buffer = 0;
|
|
||||||
usrmask = LS_BIT;
|
usrmask = LS_BIT;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
Loading…
Reference in New Issue
Block a user