Fix output destory: impl->destroy must be called last + obvious double-free
This commit is contained in:
parent
9a9dd15d5f
commit
db77530a35
|
@ -178,13 +178,16 @@ void wlr_output_destroy(struct wlr_output *output) {
|
||||||
wlr_texture_destroy(output->cursor.texture);
|
wlr_texture_destroy(output->cursor.texture);
|
||||||
wlr_renderer_destroy(output->cursor.renderer);
|
wlr_renderer_destroy(output->cursor.renderer);
|
||||||
|
|
||||||
output->impl->destroy(output);
|
|
||||||
for (size_t i = 0; output->modes && i < output->modes->length; ++i) {
|
for (size_t i = 0; output->modes && i < output->modes->length; ++i) {
|
||||||
struct wlr_output_mode *mode = output->modes->items[i];
|
struct wlr_output_mode *mode = output->modes->items[i];
|
||||||
free(mode);
|
free(mode);
|
||||||
free(mode);
|
|
||||||
}
|
}
|
||||||
list_free(output->modes);
|
list_free(output->modes);
|
||||||
|
if (output->impl->destroy) {
|
||||||
|
output->impl->destroy(output);
|
||||||
|
} else {
|
||||||
|
free(output);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wlr_output_effective_resolution(struct wlr_output *output,
|
void wlr_output_effective_resolution(struct wlr_output *output,
|
||||||
|
|
Loading…
Reference in New Issue