Index: uspace/lib/display/src/disp_srv.c
===================================================================
--- uspace/lib/display/src/disp_srv.c	(revision 338d09353f53dcb5fd2a315562bcd0b2588792d0)
+++ uspace/lib/display/src/disp_srv.c	(revision a2e104e0deacc5a9fdacf4d8e3824726c77c47a5)
@@ -100,5 +100,5 @@
 	wnd_id = ipc_get_arg1(icall);
 
-	if (srv->ops->window_create == NULL) {
+	if (srv->ops->window_destroy == NULL) {
 		async_answer_0(icall, ENOTSUP);
 		return;
@@ -106,4 +106,42 @@
 
 	rc = srv->ops->window_destroy(srv->arg, wnd_id);
+	async_answer_0(icall, rc);
+}
+
+static void display_window_move_req_srv(display_srv_t *srv, ipc_call_t *icall)
+{
+	sysarg_t wnd_id;
+	ipc_call_t call;
+	gfx_coord2_t pos;
+	size_t size;
+	errno_t rc;
+
+	wnd_id = ipc_get_arg1(icall);
+
+	if (!async_data_write_receive(&call, &size)) {
+		async_answer_0(&call, EREFUSED);
+		async_answer_0(icall, EREFUSED);
+		return;
+	}
+
+	if (size != sizeof(gfx_coord2_t)) {
+		async_answer_0(&call, EINVAL);
+		async_answer_0(icall, EINVAL);
+		return;
+	}
+
+	rc = async_data_write_finalize(&call, &pos, size);
+	if (rc != EOK) {
+		async_answer_0(&call, rc);
+		async_answer_0(icall, rc);
+		return;
+	}
+
+	if (srv->ops->window_move_req == NULL) {
+		async_answer_0(icall, ENOTSUP);
+		return;
+	}
+
+	rc = srv->ops->window_move_req(srv->arg, wnd_id, &pos);
 	async_answer_0(icall, rc);
 }
@@ -215,4 +253,7 @@
 		case DISPLAY_WINDOW_DESTROY:
 			display_window_destroy_srv(srv, &call);
+			break;
+		case DISPLAY_WINDOW_MOVE_REQ:
+			display_window_move_req_srv(srv, &call);
 			break;
 		case DISPLAY_WINDOW_RESIZE:
Index: uspace/lib/display/src/display.c
===================================================================
--- uspace/lib/display/src/display.c	(revision 338d09353f53dcb5fd2a315562bcd0b2588792d0)
+++ uspace/lib/display/src/display.c	(revision a2e104e0deacc5a9fdacf4d8e3824726c77c47a5)
@@ -244,4 +244,36 @@
 }
 
+/** Request a window move.
+ *
+ * Request the display service to initiate a user window move operation
+ * (i.e. let the user move the window). Used when the client detects
+ * mouse press on the title bar or such.
+ *
+ * @param window Window
+ * @return EOK on success or an error code
+ */
+errno_t display_window_move_req(display_window_t *window, gfx_coord2_t *pos)
+{
+	async_exch_t *exch;
+	aid_t req;
+	ipc_call_t answer;
+	errno_t rc;
+
+	exch = async_exchange_begin(window->display->sess);
+	req = async_send_1(exch, DISPLAY_WINDOW_MOVE_REQ, window->id, &answer);
+	rc = async_data_write_start(exch, (void *)pos, sizeof (gfx_coord2_t));
+	async_exchange_end(exch);
+	if (rc != EOK) {
+		async_forget(req);
+		return rc;
+	}
+
+	async_wait_for(req, &rc);
+	if (rc != EOK)
+		return rc;
+
+	return EOK;
+}
+
 /** Resize display window.
  *
@@ -283,6 +315,5 @@
  * @param nrect New bounding rectangle
  * @param offs
- * @return EOK on success or an error code. In both cases @a window must
- *         not be accessed anymore
+ * @return EOK on success or an error code
  */
 errno_t display_window_resize(display_window_t *window, gfx_coord2_t *offs,
