summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSøren Sandmann <ssp@localhost.localdomain>2010-11-11 08:38:37 -0500
committerSøren Sandmann <ssp@localhost.localdomain>2010-11-11 08:38:37 -0500
commit6768b98ddb393eee9a43467ae0db1dcf17af57fe (patch)
tree3f63108272f59e5b9302b57561e31dbe8575d214
parentf9b4f5a03d8db0f1768dd495afbd5a4259c94543 (diff)
Don't unmap memory until after uxa_close_screen; allow surface creation without vtSema
-rw-r--r--src/qxl_driver.c12
-rw-r--r--src/qxl_surface.c32
2 files changed, 25 insertions, 19 deletions
diff --git a/src/qxl_driver.c b/src/qxl_driver.c
index 4dc362b..226c331 100644
--- a/src/qxl_driver.c
+++ b/src/qxl_driver.c
@@ -312,12 +312,6 @@ qxl_close_screen(int scrnIndex, ScreenPtr pScreen)
qxl_screen_t *qxl = pScrn->driverPrivate;
Bool result;
- if (pScrn->vtSema) {
- qxl_restore_state(pScrn);
- qxl_unmap_memory(qxl, scrnIndex);
- }
- pScrn->vtSema = FALSE;
-
ErrorF ("Freeing %p\n", qxl->fb);
free(qxl->fb);
qxl->fb = NULL;
@@ -329,6 +323,12 @@ qxl_close_screen(int scrnIndex, ScreenPtr pScreen)
result = pScreen->CloseScreen(scrnIndex, pScreen);
+ if (pScrn->vtSema) {
+ qxl_restore_state(pScrn);
+ qxl_unmap_memory(qxl, scrnIndex);
+ }
+ pScrn->vtSema = FALSE;
+
return result;
}
diff --git a/src/qxl_surface.c b/src/qxl_surface.c
index 67340a1..372637c 100644
--- a/src/qxl_surface.c
+++ b/src/qxl_surface.c
@@ -240,13 +240,10 @@ push_surface_cmd (qxl_screen_t *qxl, struct qxl_surface_cmd *cmd)
{
struct qxl_command command;
- if (qxl->pScrn->vtSema)
- {
- command.type = QXL_CMD_SURFACE;
- command.data = physical_address (qxl, cmd, qxl->main_mem_slot);
-
- qxl_ring_push (qxl->command_ring, &command);
- }
+ command.type = QXL_CMD_SURFACE;
+ command.data = physical_address (qxl, cmd, qxl->main_mem_slot);
+
+ qxl_ring_push (qxl->command_ring, &command);
}
enum ROPDescriptor
@@ -359,12 +356,8 @@ qxl_surface_create (qxl_screen_t *qxl,
pixman_format_code_t pformat;
int stride;
uint32_t *dev_addr;
- static int count;
int n_attempts = 0;
- if (++count < 10)
- return NULL;
-
#if 0
ErrorF (" qxl_surface: attempting to allocate %d x %d @ %d\n", width, height, bpp);
#endif
@@ -408,7 +401,6 @@ retry:
#if 0
ErrorF (" Surface allocated: %u\n", surface->id);
- ErrorF ("Allocated %d\n", surface->id);
#endif
if (width == 0 || height == 0)
@@ -490,6 +482,10 @@ retry2:
push_surface_cmd (qxl, cmd);
+#if 0
+ ErrorF ("Allocated %d\n", surface->id);
+#endif
+
dev_addr = (uint32_t *)((uint8_t *)surface->address + stride * (height - 1));
surface->dev_image = pixman_image_create_bits (
@@ -551,6 +547,10 @@ qxl_surface_unref (qxl_screen_t *qxl, uint32_t id)
struct qxl_surface_cmd *cmd;
cmd = make_surface_cmd (qxl, surface->id, QXL_SURFACE_CMD_DESTROY);
+
+#if 0
+ ErrorF ("Destroying %d\n", id);
+#endif
push_surface_cmd (qxl, cmd);
}
@@ -602,6 +602,10 @@ download_box (qxl_surface_t *surface, int x1, int y1, int x2, int y2)
ram_header->update_surface = surface->id;
+#if 0
+ ErrorF ("Issuing update command for %d\n", surface->id);
+#endif
+
outb (surface->qxl->io_base + QXL_IO_UPDATE_AREA, 0);
pixman_image_composite (PIXMAN_OP_SRC,
@@ -802,8 +806,9 @@ qxl_surface_evacuate_all (qxl_screen_t *qxl)
assert (get_surface (evacuated->pixmap) == s);
#if 0
- ErrorF ("%d => %p\n", s->id, evacuated->pixmap);
+ ErrorF ("Evacuated %d => %p\n", s->id, evacuated->pixmap);
#endif
+
evacuated->Bpp = s->Bpp;
s->host_image = NULL;
@@ -844,6 +849,7 @@ qxl_surface_replace_all (qxl_screen_t *qxl, void *data)
surface = qxl_surface_create (qxl, width, height, ev->Bpp * 8);
#if 0
+ ErrorF ("recreated %d\n", surface->id);
ErrorF ("%d => %p\n", surface->id, ev->pixmap);
#endif