diff options
| -rw-r--r-- | drivers/oled/oled_driver.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/drivers/oled/oled_driver.c b/drivers/oled/oled_driver.c index 082115d53..53bdc196d 100644 --- a/drivers/oled/oled_driver.c +++ b/drivers/oled/oled_driver.c | |||
| @@ -491,8 +491,9 @@ void oled_write_raw(const char *data, uint16_t size) { | |||
| 491 | uint16_t cursor_start_index = oled_cursor - &oled_buffer[0]; | 491 | uint16_t cursor_start_index = oled_cursor - &oled_buffer[0]; |
| 492 | if ((size + cursor_start_index) > OLED_MATRIX_SIZE) size = OLED_MATRIX_SIZE - cursor_start_index; | 492 | if ((size + cursor_start_index) > OLED_MATRIX_SIZE) size = OLED_MATRIX_SIZE - cursor_start_index; |
| 493 | for (uint16_t i = cursor_start_index; i < cursor_start_index + size; i++) { | 493 | for (uint16_t i = cursor_start_index; i < cursor_start_index + size; i++) { |
| 494 | if (oled_buffer[i] == data[i]) continue; | 494 | uint8_t c = *data++; |
| 495 | oled_buffer[i] = data[i]; | 495 | if (oled_buffer[i] == c) continue; |
| 496 | oled_buffer[i] = c; | ||
| 496 | oled_dirty |= ((OLED_BLOCK_TYPE)1 << (i / OLED_BLOCK_SIZE)); | 497 | oled_dirty |= ((OLED_BLOCK_TYPE)1 << (i / OLED_BLOCK_SIZE)); |
| 497 | } | 498 | } |
| 498 | } | 499 | } |
