diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2012-12-06 16:55:00 +0000 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2012-12-06 16:55:00 +0000 |
commit | d733f7d1f1dc343ac34c4a27ac99d71fc0572bc2 (patch) | |
tree | 89650c55e67b2fd19cc4e4425b88a7e4e5e9cb9b /src/sna/gen5_render.c | |
parent | 13f47008ec411609968c40b8ec34dd495f14c50b (diff) |
sna/gen4+: Add common glyph-to-dst emitters
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'src/sna/gen5_render.c')
-rw-r--r-- | src/sna/gen5_render.c | 47 |
1 files changed, 45 insertions, 2 deletions
diff --git a/src/sna/gen5_render.c b/src/sna/gen5_render.c index 49542cc8..284e8da1 100644 --- a/src/sna/gen5_render.c +++ b/src/sna/gen5_render.c @@ -778,6 +778,45 @@ gen5_emit_composite_primitive_affine_source(struct sna *sna, } fastcall static void +gen5_emit_composite_primitive_identity_mask(struct sna *sna, + const struct sna_composite_op *op, + const struct sna_composite_rectangles *r) +{ + union { + struct sna_coordinate p; + float f; + } dst; + float msk_x, msk_y; + float w, h; + float *v; + + msk_x = r->mask.x + op->mask.offset[0]; + msk_y = r->mask.y + op->mask.offset[1]; + w = r->width; + h = r->height; + + v = sna->render.vertices + sna->render.vertex_used; + sna->render.vertex_used += 15; + + dst.p.x = r->dst.x + r->width; + dst.p.y = r->dst.y + r->height; + v[0] = dst.f; + v[3] = (msk_x + w) * op->mask.scale[0]; + v[9] = v[4] = (msk_y + h) * op->mask.scale[1]; + + dst.p.x = r->dst.x; + v[5] = dst.f; + v[13] = v[8] = msk_x * op->mask.scale[0]; + + dst.p.y = r->dst.y; + v[10] = dst.f; + v[14] = msk_y * op->mask.scale[1]; + + v[7] = v[2] = v[1] = 1; + v[12] = v[11] = v[6] = 0; +} + +fastcall static void gen5_emit_composite_primitive_identity_source_mask(struct sna *sna, const struct sna_composite_op *op, const struct sna_composite_rectangles *r) @@ -2393,8 +2432,12 @@ gen5_render_composite(struct sna *sna, tmp->is_affine &= tmp->mask.is_affine; - if (tmp->src.transform == NULL && tmp->mask.transform == NULL) - tmp->prim_emit = gen5_emit_composite_primitive_identity_source_mask; + if (tmp->src.transform == NULL && tmp->mask.transform == NULL) { + if (tmp->src.is_solid) + tmp->prim_emit = gen5_emit_composite_primitive_identity_mask; + else + tmp->prim_emit = gen5_emit_composite_primitive_identity_source_mask; + } tmp->floats_per_vertex = 5 + 2 * !tmp->is_affine; } else { |