displayio, framebufferio: Remove spurious call to supervisor_start_terminal

A call to supervisor_start_terminal remained in
common_hal_displayio_display_construct and was copied to other display
_construct functions, even though it was also being done in
displayio_display_core_construct when that was factored out.

Originally, this was harmless, except it created an extra allocation.
When investigating #3482, I found that this bug became harmful,
especially for displays that were created in Python code, because it
caused a supervisor allocation to leak.

I believe that it is safe to merge #3482 after this PR is merged.
This commit is contained in:
Jeff Epler 2020-10-11 21:09:08 -05:00
parent 40a3d11d64
commit 774f2e16ba
3 changed files with 0 additions and 6 deletions

View File

@ -107,8 +107,6 @@ void common_hal_displayio_display_construct(displayio_display_obj_t* self,
i += 2 + data_size; i += 2 + data_size;
} }
supervisor_start_terminal(width, height);
// Always set the backlight type in case we're reusing memory. // Always set the backlight type in case we're reusing memory.
self->backlight_inout.base.type = &mp_type_NoneType; self->backlight_inout.base.type = &mp_type_NoneType;
if (backlight_pin != NULL && common_hal_mcu_pin_is_free(backlight_pin)) { if (backlight_pin != NULL && common_hal_mcu_pin_is_free(backlight_pin)) {

View File

@ -90,8 +90,6 @@ void common_hal_displayio_epaperdisplay_construct(displayio_epaperdisplay_obj_t*
// TODO: Clear // TODO: Clear
} }
supervisor_start_terminal(width, height);
// Set the group after initialization otherwise we may send pixels while we delay in // Set the group after initialization otherwise we may send pixels while we delay in
// initialization. // initialization.
common_hal_displayio_epaperdisplay_show(self, &circuitpython_splash); common_hal_displayio_epaperdisplay_show(self, &circuitpython_splash);

View File

@ -96,8 +96,6 @@ void common_hal_framebufferio_framebufferdisplay_construct(framebufferio_framebu
common_hal_framebufferio_framebufferdisplay_set_rotation(self, rotation); common_hal_framebufferio_framebufferdisplay_set_rotation(self, rotation);
} }
supervisor_start_terminal(self->core.width, self->core.height);
// Set the group after initialization otherwise we may send pixels while we delay in // Set the group after initialization otherwise we may send pixels while we delay in
// initialization. // initialization.
common_hal_framebufferio_framebufferdisplay_show(self, &circuitpython_splash); common_hal_framebufferio_framebufferdisplay_show(self, &circuitpython_splash);