diff options
Diffstat (limited to 'backend/x11')
| -rw-r--r-- | backend/x11/output.c | 41 | 
1 files changed, 22 insertions, 19 deletions
| diff --git a/backend/x11/output.c b/backend/x11/output.c index ba34fef7..3a599023 100644 --- a/backend/x11/output.c +++ b/backend/x11/output.c @@ -104,17 +104,17 @@ static void output_destroy(struct wlr_output *wlr_output) {  	free(output);  } -static bool output_test(struct wlr_output *wlr_output) { -	uint32_t unsupported = -		wlr_output->pending.committed & ~SUPPORTED_OUTPUT_STATE; +static bool output_test(struct wlr_output *wlr_output, +		const struct wlr_output_state *state) { +	uint32_t unsupported = state->committed & ~SUPPORTED_OUTPUT_STATE;  	if (unsupported != 0) {  		wlr_log(WLR_DEBUG, "Unsupported output state fields: 0x%"PRIx32,  			unsupported);  		return false;  	} -	if (wlr_output->pending.committed & WLR_OUTPUT_STATE_MODE) { -		assert(wlr_output->pending.mode_type == WLR_OUTPUT_STATE_MODE_CUSTOM); +	if (state->committed & WLR_OUTPUT_STATE_MODE) { +		assert(state->mode_type == WLR_OUTPUT_STATE_MODE_CUSTOM);  	}  	return true; @@ -257,10 +257,11 @@ static struct wlr_x11_buffer *get_or_create_x11_buffer(  	return create_x11_buffer(output, wlr_buffer);  } -static bool output_commit_buffer(struct wlr_x11_output *output) { +static bool output_commit_buffer(struct wlr_x11_output *output, +		const struct wlr_output_state *state) {  	struct wlr_x11_backend *x11 = output->x11; -	struct wlr_buffer *buffer = output->wlr_output.pending.buffer; +	struct wlr_buffer *buffer = state->buffer;  	struct wlr_x11_buffer *x11_buffer =  		get_or_create_x11_buffer(output, buffer);  	if (!x11_buffer) { @@ -268,8 +269,9 @@ static bool output_commit_buffer(struct wlr_x11_output *output) {  	}  	xcb_xfixes_region_t region = XCB_NONE; -	if (output->wlr_output.pending.committed & WLR_OUTPUT_STATE_DAMAGE) { -		pixman_region32_union(&output->exposed, &output->exposed, &output->wlr_output.pending.damage); +	if (state->committed & WLR_OUTPUT_STATE_DAMAGE) { +		pixman_region32_union(&output->exposed, &output->exposed, +			(pixman_region32_t *) &state->damage);  		int rects_len = 0;  		pixman_box32_t *rects = pixman_region32_rectangles(&output->exposed, &rects_len); @@ -315,26 +317,27 @@ error:  	return false;  } -static bool output_commit(struct wlr_output *wlr_output) { +static bool output_commit(struct wlr_output *wlr_output, +		const struct wlr_output_state *state) {  	struct wlr_x11_output *output = get_x11_output_from_output(wlr_output);  	struct wlr_x11_backend *x11 = output->x11; -	if (!output_test(wlr_output)) { +	if (!output_test(wlr_output, state)) {  		return false;  	} -	if (wlr_output->pending.committed & WLR_OUTPUT_STATE_MODE) { +	if (state->committed & WLR_OUTPUT_STATE_MODE) {  		if (!output_set_custom_mode(wlr_output, -				wlr_output->pending.custom_mode.width, -				wlr_output->pending.custom_mode.height, -				wlr_output->pending.custom_mode.refresh)) { +				state->custom_mode.width, +				state->custom_mode.height, +				state->custom_mode.refresh)) {  			return false;  		}  	} -	if (wlr_output->pending.committed & WLR_OUTPUT_STATE_ADAPTIVE_SYNC_ENABLED && +	if (state->committed & WLR_OUTPUT_STATE_ADAPTIVE_SYNC_ENABLED &&  			x11->atoms.variable_refresh != XCB_ATOM_NONE) { -		if (wlr_output->pending.adaptive_sync_enabled) { +		if (state->adaptive_sync_enabled) {  			uint32_t enabled = 1;  			xcb_change_property(x11->xcb, XCB_PROP_MODE_REPLACE, output->win,  				x11->atoms.variable_refresh, XCB_ATOM_CARDINAL, 32, 1, @@ -347,8 +350,8 @@ static bool output_commit(struct wlr_output *wlr_output) {  		}  	} -	if (wlr_output->pending.committed & WLR_OUTPUT_STATE_BUFFER) { -		if (!output_commit_buffer(output)) { +	if (state->committed & WLR_OUTPUT_STATE_BUFFER) { +		if (!output_commit_buffer(output, state)) {  			return false;  		}  	} | 
