diff options
| author | Drew DeVault <sir@cmpwn.com> | 2017-11-02 23:34:02 -0400 | 
|---|---|---|
| committer | Drew DeVault <sir@cmpwn.com> | 2017-11-02 23:34:02 -0400 | 
| commit | 86b87299986a430a52b4eac3f2e0e7b659176c90 (patch) | |
| tree | ac8523d64c6b2faa8d7156093c8dc8f6998301b7 /backend | |
| parent | 975b9dc365d5a7bec531522320a1506323575525 (diff) | |
| parent | ec11a95d0c945d138cede66b7c6e53e343c82f8f (diff) | |
| download | wlroots-86b87299986a430a52b4eac3f2e0e7b659176c90.tar.xz | |
Merge remote-tracking branch 'origin/master' into hidpi
Diffstat (limited to 'backend')
| -rw-r--r-- | backend/drm/backend.c | 4 | ||||
| -rw-r--r-- | backend/drm/drm.c | 102 | ||||
| -rw-r--r-- | backend/libinput/backend.c | 8 | ||||
| -rw-r--r-- | backend/libinput/events.c | 1 | ||||
| -rw-r--r-- | backend/multi/backend.c | 4 | ||||
| -rw-r--r-- | backend/wayland/output.c | 3 | ||||
| -rw-r--r-- | backend/wayland/registry.c | 4 | ||||
| -rw-r--r-- | backend/wayland/wl_seat.c | 23 | 
8 files changed, 67 insertions, 82 deletions
| diff --git a/backend/drm/backend.c b/backend/drm/backend.c index af2619ff..87a4f708 100644 --- a/backend/drm/backend.c +++ b/backend/drm/backend.c @@ -29,8 +29,8 @@ static void wlr_drm_backend_destroy(struct wlr_backend *backend) {  	wlr_drm_restore_outputs(drm); -	struct wlr_drm_connector *conn; -	wl_list_for_each(conn, &drm->outputs, link) { +	struct wlr_drm_connector *conn, *next; +	wl_list_for_each_safe(conn, next, &drm->outputs, link) {  		wlr_output_destroy(&conn->output);  	} diff --git a/backend/drm/drm.c b/backend/drm/drm.c index 6cbb0535..dd247998 100644 --- a/backend/drm/drm.c +++ b/backend/drm/drm.c @@ -533,13 +533,14 @@ static bool wlr_drm_connector_set_cursor(struct wlr_output *output,  			return false;  		} -		if (!wlr_drm_surface_init(&plane->surf, renderer, w, h, GBM_FORMAT_ARGB8888, 0)) { +		if (!wlr_drm_surface_init(&plane->surf, renderer, w, h, +				GBM_FORMAT_ARGB8888, 0)) {  			wlr_log(L_ERROR, "Cannot allocate cursor resources");  			return false;  		} -		plane->cursor_bo = gbm_bo_create(renderer->gbm, w, h, GBM_FORMAT_ARGB8888, -			GBM_BO_USE_CURSOR | GBM_BO_USE_WRITE); +		plane->cursor_bo = gbm_bo_create(renderer->gbm, w, h, +			GBM_FORMAT_ARGB8888, GBM_BO_USE_CURSOR | GBM_BO_USE_WRITE);  		if (!plane->cursor_bo) {  			wlr_log_errno(L_ERROR, "Failed to create cursor bo");  			return false; @@ -552,45 +553,26 @@ static bool wlr_drm_connector_set_cursor(struct wlr_output *output,  		// TODO the image needs to be rotated depending on the output rotation -		plane->wlr_tex = wlr_render_texture_create(plane->surf.renderer->wlr_rend); +		plane->wlr_tex = +			wlr_render_texture_create(plane->surf.renderer->wlr_rend);  		if (!plane->wlr_tex) {  			return false;  		}  	} -	switch (output->transform) { -	case WL_OUTPUT_TRANSFORM_90: -		plane->cursor_hotspot_x = hotspot_x; -		plane->cursor_hotspot_y = -plane->surf.height + hotspot_y; -		break; -	case WL_OUTPUT_TRANSFORM_180: -		plane->cursor_hotspot_x = plane->surf.width - hotspot_x; -		plane->cursor_hotspot_y = plane->surf.height - hotspot_y; -		break; -	case WL_OUTPUT_TRANSFORM_270: -		plane->cursor_hotspot_x = -plane->surf.height + hotspot_x; -		plane->cursor_hotspot_y = hotspot_y; -		break; -	case WL_OUTPUT_TRANSFORM_FLIPPED: -		plane->cursor_hotspot_x = plane->surf.width - hotspot_x; -		plane->cursor_hotspot_y = hotspot_y; -		break; -	case WL_OUTPUT_TRANSFORM_FLIPPED_90: -		plane->cursor_hotspot_x = hotspot_x; -		plane->cursor_hotspot_y = -hotspot_y; -		break; -	case WL_OUTPUT_TRANSFORM_FLIPPED_180: -		plane->cursor_hotspot_x = hotspot_x; -		plane->cursor_hotspot_y = plane->surf.height - hotspot_y; -		break; -	case WL_OUTPUT_TRANSFORM_FLIPPED_270: -		plane->cursor_hotspot_x = -plane->surf.height + hotspot_x; -		plane->cursor_hotspot_y = plane->surf.width - hotspot_y; -		break; -	default: // WL_OUTPUT_TRANSFORM_NORMAL -		plane->cursor_hotspot_x = hotspot_x; -		plane->cursor_hotspot_y = hotspot_y; -	} +	struct wlr_box hotspot = { +		.width = plane->surf.width, +		.height = plane->surf.height, +		.x = hotspot_x, +		.y = hotspot_y, +	}; +	enum wl_output_transform transform = +		wlr_output_transform_invert(output->transform); +	struct wlr_box transformed_hotspot; +	wlr_output_transform_apply_to_box(transform, &hotspot, +		&transformed_hotspot); +	plane->cursor_hotspot_x = transformed_hotspot.x; +	plane->cursor_hotspot_y = transformed_hotspot.y;  	if (!update_pixels) {  		// Only update the cursor hotspot @@ -620,11 +602,13 @@ static bool wlr_drm_connector_set_cursor(struct wlr_output *output,  	float matrix[16];  	wlr_texture_get_matrix(plane->wlr_tex, &matrix, &plane->matrix, 0, 0); -	wlr_render_with_matrix(plane->surf.renderer->wlr_rend, plane->wlr_tex, &matrix); +	wlr_render_with_matrix(plane->surf.renderer->wlr_rend, plane->wlr_tex, +		&matrix);  	glFinish();  	glPixelStorei(GL_UNPACK_ROW_LENGTH_EXT, bo_stride); -	glReadPixels(0, 0, plane->surf.width, plane->surf.height, GL_BGRA_EXT, GL_UNSIGNED_BYTE, bo_data); +	glReadPixels(0, 0, plane->surf.width, plane->surf.height, GL_BGRA_EXT, +		GL_UNSIGNED_BYTE, bo_data);  	glPixelStorei(GL_UNPACK_ROW_LENGTH_EXT, 0);  	wlr_drm_surface_swap_buffers(&plane->surf); @@ -638,41 +622,30 @@ static bool wlr_drm_connector_move_cursor(struct wlr_output *output,  		int x, int y) {  	struct wlr_drm_connector *conn = (struct wlr_drm_connector *)output;  	struct wlr_drm_backend *drm = (struct wlr_drm_backend *)output->backend; -  	struct wlr_drm_plane *plane = conn->crtc->cursor; -	x -= plane->cursor_hotspot_x; -	y -= plane->cursor_hotspot_y; -	int width, height, tmp; -	wlr_output_effective_resolution(output, &width, &height); +	struct wlr_box box; +	box.x = x; +	box.y = y; +	wlr_output_effective_resolution(output, &box.width, &box.height); -	switch (output->transform) { -	case WL_OUTPUT_TRANSFORM_NORMAL: -	case WL_OUTPUT_TRANSFORM_FLIPPED: -	case WL_OUTPUT_TRANSFORM_FLIPPED_180: -		// nothing to do -		break; -	case WL_OUTPUT_TRANSFORM_270: -	case WL_OUTPUT_TRANSFORM_FLIPPED_270: -		tmp = x; -		x = y; -		y = -(tmp - width); -		break; -	case WL_OUTPUT_TRANSFORM_90: -	case WL_OUTPUT_TRANSFORM_FLIPPED_90: -		tmp = x; -		x = -(y - height); -		y = tmp; -		break; -	} +	enum wl_output_transform transform = +		wlr_output_transform_invert(output->transform); +	struct wlr_box transformed_box; +	wlr_output_transform_apply_to_box(transform, &box, &transformed_box); + +	transformed_box.x -= plane->cursor_hotspot_x; +	transformed_box.y -= plane->cursor_hotspot_y; -	return drm->iface->crtc_move_cursor(drm, conn->crtc, x, y); +	return drm->iface->crtc_move_cursor(drm, conn->crtc, transformed_box.x, +		transformed_box.y);  }  static void wlr_drm_connector_destroy(struct wlr_output *output) {  	struct wlr_drm_connector *conn = (struct wlr_drm_connector *)output;  	wlr_drm_connector_cleanup(conn);  	wl_event_source_remove(conn->retry_pageflip); +	wl_list_remove(&conn->link);  	free(conn);  } @@ -851,6 +824,7 @@ void wlr_drm_scan_connectors(struct wlr_drm_backend *drm) {  		drmModeFreeCrtc(conn->old_crtc);  		wl_event_source_remove(conn->retry_pageflip); +		wl_list_remove(&conn->link);  		free(conn);  	}  } diff --git a/backend/libinput/backend.c b/backend/libinput/backend.c index 781314a3..45b4e368 100644 --- a/backend/libinput/backend.c +++ b/backend/libinput/backend.c @@ -99,13 +99,13 @@ static void wlr_libinput_backend_destroy(struct wlr_backend *_backend) {  	}  	struct wlr_libinput_backend *backend = (struct wlr_libinput_backend *)_backend;  	for (size_t i = 0; i < backend->wlr_device_lists->length; i++) { -		struct wlr_list *wlr_devices = backend->wlr_device_lists->items[i]; -		for (size_t j = 0; j < wlr_devices->length; j++) { -			struct wlr_input_device *wlr_dev = wlr_devices->items[j]; +		struct wl_list *wlr_devices = backend->wlr_device_lists->items[i]; +		struct wlr_input_device *wlr_dev, *next; +		wl_list_for_each_safe(wlr_dev, next, wlr_devices, link) {  			wl_signal_emit(&backend->backend.events.input_remove, wlr_dev);  			wlr_input_device_destroy(wlr_dev);  		} -		wlr_list_free(wlr_devices); +		free(wlr_devices);  	}  	wlr_list_free(backend->wlr_device_lists);  	wl_event_source_remove(backend->input_event); diff --git a/backend/libinput/events.c b/backend/libinput/events.c index 053cab02..5da45c67 100644 --- a/backend/libinput/events.c +++ b/backend/libinput/events.c @@ -26,6 +26,7 @@ struct wlr_input_device *get_appropriate_device(  static void wlr_libinput_device_destroy(struct wlr_input_device *_dev) {  	struct wlr_libinput_input_device *dev = (struct wlr_libinput_input_device *)_dev;  	libinput_device_unref(dev->handle); +	wl_list_remove(&dev->wlr_input_device.link);  	free(dev);  } diff --git a/backend/multi/backend.c b/backend/multi/backend.c index a7ee648c..c35303e0 100644 --- a/backend/multi/backend.c +++ b/backend/multi/backend.c @@ -30,8 +30,8 @@ static bool multi_backend_start(struct wlr_backend *_backend) {  static void multi_backend_destroy(struct wlr_backend *_backend) {  	struct wlr_multi_backend *backend = (struct wlr_multi_backend *)_backend; -	struct subbackend_state *sub; -	wl_list_for_each(sub, &backend->backends, link) { +	struct subbackend_state *sub, *next; +	wl_list_for_each_safe(sub, next, &backend->backends, link) {  		wlr_backend_destroy(sub->backend);  		free(sub);  	} diff --git a/backend/wayland/output.c b/backend/wayland/output.c index 494e0522..90f8b39a 100644 --- a/backend/wayland/output.c +++ b/backend/wayland/output.c @@ -59,6 +59,7 @@ static bool wlr_wl_output_set_cursor(struct wlr_output *_output,  		(struct wlr_wl_backend_output *)_output;  	struct wlr_wl_backend *backend = output->backend; +	// TODO: use output->wlr_output.transform to transform pixels and hotpot  	output->cursor.hotspot_x = hotspot_x;  	output->cursor.hotspot_y = hotspot_y; @@ -222,7 +223,7 @@ static void xdg_toplevel_handle_configure(void *data, struct zxdg_toplevel_v6 *x  static void xdg_toplevel_handle_close(void *data, struct zxdg_toplevel_v6 *xdg_toplevel) {  	struct wlr_wl_backend_output *output = data; -        assert(output && output->xdg_toplevel == xdg_toplevel); +	assert(output && output->xdg_toplevel == xdg_toplevel);  	wl_display_terminate(output->backend->local_display);  } diff --git a/backend/wayland/registry.c b/backend/wayland/registry.c index d6f61aa7..0dec0ec5 100644 --- a/backend/wayland/registry.c +++ b/backend/wayland/registry.c @@ -9,11 +9,11 @@  static void xdg_shell_handle_ping(void *data, struct zxdg_shell_v6 *shell,  		uint32_t serial) { -        zxdg_shell_v6_pong(shell, serial); +	zxdg_shell_v6_pong(shell, serial);  }  static const struct zxdg_shell_v6_listener xdg_shell_listener = { -        xdg_shell_handle_ping, +	xdg_shell_handle_ping,  }; diff --git a/backend/wayland/wl_seat.c b/backend/wayland/wl_seat.c index 0d8e5b1f..deed215e 100644 --- a/backend/wayland/wl_seat.c +++ b/backend/wayland/wl_seat.c @@ -42,21 +42,30 @@ static void pointer_handle_motion(void *data, struct wl_pointer *wl_pointer,  		uint32_t time, wl_fixed_t surface_x, wl_fixed_t surface_y) {  	struct wlr_input_device *dev = data;  	assert(dev && dev->pointer); -	struct wlr_wl_pointer *wlr_wl_pointer = (struct wlr_wl_pointer *)dev->pointer; +	struct wlr_wl_pointer *wlr_wl_pointer = +		(struct wlr_wl_pointer *)dev->pointer;  	if (!wlr_wl_pointer->current_output) {  		wlr_log(L_ERROR, "pointer motion event without current output");  		return;  	} -	int width, height; + +	struct wlr_box box;  	wl_egl_window_get_attached_size(wlr_wl_pointer->current_output->egl_window, -		&width, &height); +		&box.width, &box.height); +	box.x = wl_fixed_to_int(surface_x); +	box.y = wl_fixed_to_int(surface_y); +	struct wlr_box transformed; +	wlr_output_transform_apply_to_box( +		wlr_wl_pointer->current_output->wlr_output.transform, &box, +		&transformed); +  	struct wlr_event_pointer_motion_absolute wlr_event;  	wlr_event.device = dev;  	wlr_event.time_msec = time; -	wlr_event.width_mm = width; -	wlr_event.height_mm = height; -	wlr_event.x_mm = wl_fixed_to_double(surface_x); -	wlr_event.y_mm = wl_fixed_to_double(surface_y); +	wlr_event.width_mm = transformed.width; +	wlr_event.height_mm = transformed.height; +	wlr_event.x_mm = transformed.x; +	wlr_event.y_mm = transformed.y;  	wl_signal_emit(&dev->pointer->events.motion_absolute, &wlr_event);  } | 
