summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorChris Wilson <chris@chris-wilson.co.uk>2011-11-09 13:14:04 +0000
committerChris Wilson <chris@chris-wilson.co.uk>2011-11-09 14:00:16 +0000
commit8fdbd01c94c0f6f56247feed8f225901ba39e18e (patch)
treebb6621689de186d528df9607c623b08cbb4e6e9e /src
parent436a78684507129ca1245e065ff68870eb27624b (diff)
sna/video: Use the normal bo cache for texture video streams
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src')
-rw-r--r--src/sna/sna_video.c41
-rw-r--r--src/sna/sna_video.h11
-rw-r--r--src/sna/sna_video_overlay.c9
-rw-r--r--src/sna/sna_video_textured.c10
4 files changed, 41 insertions, 30 deletions
diff --git a/src/sna/sna_video.c b/src/sna/sna_video.c
index fd5f3f19..d3788fd0 100644
--- a/src/sna/sna_video.c
+++ b/src/sna/sna_video.c
@@ -94,16 +94,25 @@ void sna_video_free_buffers(struct sna *sna, struct sna_video *video)
}
}
-void sna_video_frame_fini(struct sna *sna,
- struct sna_video *video,
- struct sna_video_frame *frame)
+struct kgem_bo *
+sna_video_buffer(struct sna *sna,
+ struct sna_video *video,
+ struct sna_video_frame *frame)
{
- struct kgem_bo *bo;
+ /* Free the current buffer if we're going to have to reallocate */
+ if (video->buf && video->buf->size < frame->size)
+ sna_video_free_buffers(sna, video);
- if (!frame->bo->reusable) {
- kgem_bo_destroy(&sna->kgem, frame->bo);
- return;
- }
+ if (video->buf == NULL)
+ video->buf = kgem_create_linear(&sna->kgem, frame->size);
+
+ return video->buf;
+}
+
+void sna_video_buffer_fini(struct sna *sna,
+ struct sna_video *video)
+{
+ struct kgem_bo *bo;
bo = video->old_buf[1];
video->old_buf[1] = video->old_buf[0];
@@ -245,21 +254,6 @@ sna_video_frame_init(struct sna *sna,
}
}
-static struct kgem_bo *
-sna_video_buffer(struct sna *sna,
- struct sna_video *video,
- struct sna_video_frame *frame)
-{
- /* Free the current buffer if we're going to have to reallocate */
- if (video->buf && video->buf->size < frame->size)
- sna_video_free_buffers(sna, video);
-
- if (video->buf == NULL)
- video->buf = kgem_create_linear(&sna->kgem, frame->size);
-
- return video->buf;
-}
-
static void sna_memcpy_plane(uint8_t *dst, const uint8_t *src,
int height, int width,
int dstPitch, int srcPitch,
@@ -442,7 +436,6 @@ sna_video_copy_data(struct sna *sna,
{
uint8_t *dst;
- frame->bo = sna_video_buffer(sna, video, frame);
if (frame->bo == NULL)
return FALSE;
diff --git a/src/sna/sna_video.h b/src/sna/sna_video.h
index ab8289b6..47ddab0f 100644
--- a/src/sna/sna_video.h
+++ b/src/sna/sna_video.h
@@ -117,15 +117,20 @@ sna_video_frame_init(struct sna *sna,
int id, short width, short height,
struct sna_video_frame *frame);
+struct kgem_bo *
+sna_video_buffer(struct sna *sna,
+ struct sna_video *video,
+ struct sna_video_frame *frame);
+
Bool
sna_video_copy_data(struct sna *sna,
struct sna_video *video,
struct sna_video_frame *frame,
const uint8_t *buf);
-void sna_video_frame_fini(struct sna *sna,
- struct sna_video *video,
- struct sna_video_frame *frame);
+void sna_video_buffer_fini(struct sna *sna,
+ struct sna_video *video);
+
void sna_video_free_buffers(struct sna *sna, struct sna_video *video);
#endif /* SNA_VIDEO_H */
diff --git a/src/sna/sna_video_overlay.c b/src/sna/sna_video_overlay.c
index 491baa87..9ba78ef4 100644
--- a/src/sna/sna_video_overlay.c
+++ b/src/sna/sna_video_overlay.c
@@ -504,6 +504,13 @@ sna_video_overlay_put_image(ScrnInfoPtr scrn,
/* overlay can't handle rotation natively, store it for the copy func */
video->rotation = crtc->rotation;
+
+ frame.bo = sna_video_buffer(sna, video, &frame);
+ if (frame.bo == NULL) {
+ DBG(("%s: failed to allocate video bo\n", __FUNCTION__));
+ return BadAlloc;
+ }
+
if (!sna_video_copy_data(sna, video, &frame, buf)) {
DBG(("%s: failed to copy video data\n", __FUNCTION__));
return BadAlloc;
@@ -515,7 +522,7 @@ sna_video_overlay_put_image(ScrnInfoPtr scrn,
return BadAlloc;
}
- sna_video_frame_fini(sna, video, &frame);
+ sna_video_buffer_fini(sna, video);
/* update cliplist */
if (!REGION_EQUAL(scrn->pScreen, &video->clip, clip)) {
diff --git a/src/sna/sna_video_textured.c b/src/sna/sna_video_textured.c
index 3461dc54..dadf8b93 100644
--- a/src/sna/sna_video_textured.c
+++ b/src/sna/sna_video_textured.c
@@ -262,8 +262,14 @@ sna_video_textured_put_image(ScrnInfoPtr scrn,
if (frame.bo == NULL)
return BadAlloc;
} else {
- if (!sna_video_copy_data(sna, video, &frame, buf))
+ frame.bo = kgem_create_linear(&sna->kgem, frame.size);
+ if (frame.bo == NULL)
+ return BadAlloc;
+
+ if (!sna_video_copy_data(sna, video, &frame, buf)) {
+ kgem_bo_destroy(&sna->kgem, frame.bo);
return BadAlloc;
+ }
}
if (crtc && video->SyncToVblank != 0)
@@ -275,7 +281,7 @@ sna_video_textured_put_image(ScrnInfoPtr scrn,
drw_w, drw_h,
pixmap);
- sna_video_frame_fini(sna, video, &frame);
+ kgem_bo_destroy(&sna->kgem, frame.bo);
DamageDamageRegion(drawable, clip);