framebufferio: add dirty row tracking
This commit is contained in:
parent
5e4ed93415
commit
9c4f644641
@ -352,7 +352,8 @@ STATIC void rgbmatrix_rgbmatrix_get_bufinfo(mp_obj_t self_in, mp_buffer_info_t *
|
||||
|
||||
// These version exists so that the prototype matches the protocol,
|
||||
// avoiding a type cast that can hide errors
|
||||
STATIC void rgbmatrix_rgbmatrix_swapbuffers(mp_obj_t self_in) {
|
||||
STATIC void rgbmatrix_rgbmatrix_swapbuffers(mp_obj_t self_in, uint8_t *dirty_row_bitmap) {
|
||||
(void)dirty_row_bitmap;
|
||||
common_hal_rgbmatrix_rgbmatrix_refresh(self_in);
|
||||
}
|
||||
|
||||
|
@ -156,7 +156,8 @@ STATIC const displayio_area_t* _get_refresh_areas(framebufferio_framebufferdispl
|
||||
return NULL;
|
||||
}
|
||||
|
||||
STATIC bool _refresh_area(framebufferio_framebufferdisplay_obj_t* self, const displayio_area_t* area) {
|
||||
#define MARK_ROW_DIRTY(r) (dirty_row_bitmask[r/8] = (1 << (r & 7)))
|
||||
STATIC bool _refresh_area(framebufferio_framebufferdisplay_obj_t* self, const displayio_area_t* area, uint8_t *dirty_row_bitmask) {
|
||||
uint16_t buffer_size = 128; // In uint32_ts
|
||||
|
||||
displayio_area_t clipped;
|
||||
@ -235,6 +236,7 @@ STATIC bool _refresh_area(framebufferio_framebufferdisplay_obj_t* self, const di
|
||||
|
||||
for (uint16_t i = subrectangle.y1; i < subrectangle.y2; i++) {
|
||||
assert(dest >= buf && dest < endbuf && dest+rowsize <= endbuf);
|
||||
MARK_ROW_DIRTY(i);
|
||||
memcpy(dest, src, rowsize);
|
||||
dest += rowstride;
|
||||
src += rowsize;
|
||||
@ -251,12 +253,14 @@ STATIC void _refresh_display(framebufferio_framebufferdisplay_obj_t* self) {
|
||||
displayio_display_core_start_refresh(&self->core);
|
||||
const displayio_area_t* current_area = _get_refresh_areas(self);
|
||||
if (current_area) {
|
||||
uint8_t dirty_row_bitmask[(self->core.height + 7) / 8];
|
||||
memset(dirty_row_bitmask, 0, sizeof(dirty_row_bitmask));
|
||||
self->framebuffer_protocol->get_bufinfo(self->framebuffer, &self->bufinfo);
|
||||
while (current_area != NULL) {
|
||||
_refresh_area(self, current_area);
|
||||
_refresh_area(self, current_area, dirty_row_bitmask);
|
||||
current_area = current_area->next;
|
||||
}
|
||||
self->framebuffer_protocol->swapbuffers(self->framebuffer);
|
||||
self->framebuffer_protocol->swapbuffers(self->framebuffer, dirty_row_bitmask);
|
||||
}
|
||||
displayio_display_core_finish_refresh(&self->core);
|
||||
}
|
||||
|
@ -79,7 +79,7 @@ typedef int (*framebuffer_get_width_fun)(mp_obj_t);
|
||||
typedef mp_float_t (*framebuffer_get_brightness_fun)(mp_obj_t);
|
||||
typedef void (*framebuffer_deinit_fun)(mp_obj_t);
|
||||
typedef void (*framebuffer_get_bufinfo_fun)(mp_obj_t, mp_buffer_info_t *bufinfo);
|
||||
typedef void (*framebuffer_swapbuffers_fun)(mp_obj_t);
|
||||
typedef void (*framebuffer_swapbuffers_fun)(mp_obj_t, uint8_t *dirty_row_bitmask);
|
||||
|
||||
typedef struct _framebuffer_p_t {
|
||||
MP_PROTOCOL_HEAD // MP_QSTR_protocol_framebuffer
|
||||
|
Loading…
x
Reference in New Issue
Block a user