diff options
author | Brian <brian.paul@tungstengraphics.com> | 2007-08-20 10:23:28 -0600 |
---|---|---|
committer | Brian <brian.paul@tungstengraphics.com> | 2007-08-20 10:23:28 -0600 |
commit | df1df82f1660996d09fa272e6129c194afde3ece (patch) | |
tree | a28e21bb697f637707ca95cdf20e09a8d3a94b9a /src/mesa/drivers | |
parent | 8339ca7d1e9a3fe90f46e6e81f7ec8574d121072 (diff) | |
parent | 14327705fd53e984b74f8e9adb053df03fba7aff (diff) |
Merge branch 'softpipe_0_1_branch' of git+ssh://brianp@git.freedesktop.org/git/mesa/mesa into softpipe_0_1_branch
Diffstat (limited to 'src/mesa/drivers')
-rw-r--r-- | src/mesa/drivers/x11/xm_softpipe.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/src/mesa/drivers/x11/xm_softpipe.c b/src/mesa/drivers/x11/xm_softpipe.c index 09edea6265..432f306e94 100644 --- a/src/mesa/drivers/x11/xm_softpipe.c +++ b/src/mesa/drivers/x11/xm_softpipe.c @@ -51,6 +51,7 @@ struct xm_softpipe_winsys struct xm_buffer { int refcount; + int size; void *data; void *mapped; }; @@ -129,8 +130,12 @@ xm_buffer_data(struct pipe_winsys *pws, struct pipe_buffer_handle *buf, unsigned size, const void *data ) { struct xm_buffer *xm_buf = xm_bo(buf); - assert(!xm_buf->data); - xm_buf->data = malloc(size); + if (xm_buf->size != size) { + if (xm_buf->data) + free(xm_buf->data); + xm_buf->data = malloc(size); + xm_buf->size = size; + } if (data) memcpy(xm_buf->data, data, size); } |