|
|
@ -26,6 +26,7 @@ |
|
|
|
|
|
|
|
|
|
|
|
struct wlsc_shm_buffer { |
|
|
|
struct wlsc_shm_buffer { |
|
|
|
struct wl_buffer buffer; |
|
|
|
struct wl_buffer buffer; |
|
|
|
|
|
|
|
struct wl_list surfaces_attached_to; |
|
|
|
int32_t stride; |
|
|
|
int32_t stride; |
|
|
|
void *data; |
|
|
|
void *data; |
|
|
|
int mapped; |
|
|
|
int mapped; |
|
|
@ -36,18 +37,18 @@ destroy_buffer(struct wl_resource *resource, struct wl_client *client) |
|
|
|
{ |
|
|
|
{ |
|
|
|
struct wlsc_shm_buffer *buffer = |
|
|
|
struct wlsc_shm_buffer *buffer = |
|
|
|
container_of(resource, struct wlsc_shm_buffer, buffer.resource); |
|
|
|
container_of(resource, struct wlsc_shm_buffer, buffer.resource); |
|
|
|
struct wlsc_compositor *compositor =
|
|
|
|
struct wlsc_surface *es, *next; |
|
|
|
(struct wlsc_compositor *) buffer->buffer.compositor; |
|
|
|
|
|
|
|
struct wlsc_surface *es; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (buffer->mapped) |
|
|
|
if (buffer->mapped) |
|
|
|
munmap(buffer->data, buffer->stride * buffer->buffer.height); |
|
|
|
munmap(buffer->data, buffer->stride * buffer->buffer.height); |
|
|
|
else |
|
|
|
else |
|
|
|
free(buffer->data); |
|
|
|
free(buffer->data); |
|
|
|
|
|
|
|
|
|
|
|
wl_list_for_each(es, &compositor->surface_list, link) |
|
|
|
wl_list_for_each_safe(es, next, &buffer->surfaces_attached_to, |
|
|
|
if (es->buffer == (struct wl_buffer *) buffer) |
|
|
|
buffer_link) { |
|
|
|
es->buffer = NULL; |
|
|
|
es->buffer = NULL; |
|
|
|
|
|
|
|
wl_list_remove(&es->buffer_link); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
free(buffer); |
|
|
|
free(buffer); |
|
|
|
} |
|
|
|
} |
|
|
@ -58,14 +59,9 @@ buffer_damage(struct wl_client *client, struct wl_buffer *buffer_base, |
|
|
|
{ |
|
|
|
{ |
|
|
|
struct wlsc_shm_buffer *buffer = |
|
|
|
struct wlsc_shm_buffer *buffer = |
|
|
|
(struct wlsc_shm_buffer *) buffer_base; |
|
|
|
(struct wlsc_shm_buffer *) buffer_base; |
|
|
|
struct wlsc_compositor *compositor =
|
|
|
|
|
|
|
|
(struct wlsc_compositor *) buffer->buffer.compositor; |
|
|
|
|
|
|
|
struct wlsc_surface *es; |
|
|
|
struct wlsc_surface *es; |
|
|
|
|
|
|
|
|
|
|
|
wl_list_for_each(es, &compositor->surface_list, link) { |
|
|
|
wl_list_for_each(es, &buffer->surfaces_attached_to, buffer_link) { |
|
|
|
if (es->buffer != buffer_base) |
|
|
|
|
|
|
|
continue; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
glBindTexture(GL_TEXTURE_2D, es->texture); |
|
|
|
glBindTexture(GL_TEXTURE_2D, es->texture); |
|
|
|
glTexImage2D(GL_TEXTURE_2D, 0, GL_BGRA_EXT, |
|
|
|
glTexImage2D(GL_TEXTURE_2D, 0, GL_BGRA_EXT, |
|
|
|
buffer->buffer.width, buffer->buffer.height, 0, |
|
|
|
buffer->buffer.width, buffer->buffer.height, 0, |
|
|
@ -111,6 +107,10 @@ wlsc_shm_buffer_attach(struct wl_buffer *buffer_base, |
|
|
|
buffer->buffer.width, buffer->buffer.height, 0, |
|
|
|
buffer->buffer.width, buffer->buffer.height, 0, |
|
|
|
GL_BGRA_EXT, GL_UNSIGNED_BYTE, buffer->data); |
|
|
|
GL_BGRA_EXT, GL_UNSIGNED_BYTE, buffer->data); |
|
|
|
es->visual = buffer->buffer.visual; |
|
|
|
es->visual = buffer->buffer.visual; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (es->buffer) |
|
|
|
|
|
|
|
wl_list_remove(&es->buffer_link); |
|
|
|
|
|
|
|
wl_list_insert(&buffer->surfaces_attached_to, &es->buffer_link); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static struct wlsc_shm_buffer * |
|
|
|
static struct wlsc_shm_buffer * |
|
|
@ -132,6 +132,8 @@ wlsc_shm_buffer_init(struct wlsc_compositor *compositor, |
|
|
|
buffer->stride = stride; |
|
|
|
buffer->stride = stride; |
|
|
|
buffer->data = data; |
|
|
|
buffer->data = data; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
wl_list_init(&buffer->surfaces_attached_to); |
|
|
|
|
|
|
|
|
|
|
|
buffer->buffer.resource.object.interface = &wl_buffer_interface; |
|
|
|
buffer->buffer.resource.object.interface = &wl_buffer_interface; |
|
|
|
buffer->buffer.resource.object.implementation = (void (**)(void)) |
|
|
|
buffer->buffer.resource.object.implementation = (void (**)(void)) |
|
|
|
&buffer_interface; |
|
|
|
&buffer_interface; |
|
|
|