1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25: static void
26: glue(cirrus_bitblt_rop_fwd_, ROP_NAME)(CirrusVGAState *s,
27: uint8_t *dst,const uint8_t *src,
28: int dstpitch,int srcpitch,
29: int bltwidth,int bltheight)
30: {
31: int x,y;
32: dstpitch -= bltwidth;
33: srcpitch -= bltwidth;
34: for (y = 0; y < bltheight; y++) {
35: for (x = 0; x < bltwidth; x++) {
36: ROP_OP(*dst, *src);
37: dst++;
38: src++;
39: }
40: dst += dstpitch;
41: src += srcpitch;
42: }
43: }
44:
45: static void
46: glue(cirrus_bitblt_rop_bkwd_, ROP_NAME)(CirrusVGAState *s,
47: uint8_t *dst,const uint8_t *src,
48: int dstpitch,int srcpitch,
49: int bltwidth,int bltheight)
50: {
51: int x,y;
52: dstpitch += bltwidth;
53: srcpitch += bltwidth;
54: for (y = 0; y < bltheight; y++) {
55: for (x = 0; x < bltwidth; x++) {
56: ROP_OP(*dst, *src);
57: dst--;
58: src--;
59: }
60: dst += dstpitch;
61: src += srcpitch;
62: }
63: }
64:
65: static void
66: glue(glue(cirrus_bitblt_rop_fwd_transp_, ROP_NAME),_8)(CirrusVGAState *s,
67: uint8_t *dst,const uint8_t *src,
68: int dstpitch,int srcpitch,
69: int bltwidth,int bltheight)
70: {
71: int x,y;
72: uint8_t p;
73: dstpitch -= bltwidth;
74: srcpitch -= bltwidth;
75: for (y = 0; y < bltheight; y++) {
76: for (x = 0; x < bltwidth; x++) {
77: p = *dst;
78: ROP_OP(p, *src);
79: if (p != s->gr[0x34]) *dst = p;
80: dst++;
81: src++;
82: }
83: dst += dstpitch;
84: src += srcpitch;
85: }
86: }
87:
88: static void
89: glue(glue(cirrus_bitblt_rop_bkwd_transp_, ROP_NAME),_8)(CirrusVGAState *s,
90: uint8_t *dst,const uint8_t *src,
91: int dstpitch,int srcpitch,
92: int bltwidth,int bltheight)
93: {
94: int x,y;
95: uint8_t p;
96: dstpitch += bltwidth;
97: srcpitch += bltwidth;
98: for (y = 0; y < bltheight; y++) {
99: for (x = 0; x < bltwidth; x++) {
100: p = *dst;
101: ROP_OP(p, *src);
102: if (p != s->gr[0x34]) *dst = p;
103: dst--;
104: src--;
105: }
106: dst += dstpitch;
107: src += srcpitch;
108: }
109: }
110:
111: static void
112: glue(glue(cirrus_bitblt_rop_fwd_transp_, ROP_NAME),_16)(CirrusVGAState *s,
113: uint8_t *dst,const uint8_t *src,
114: int dstpitch,int srcpitch,
115: int bltwidth,int bltheight)
116: {
117: int x,y;
118: uint8_t p1, p2;
119: dstpitch -= bltwidth;
120: srcpitch -= bltwidth;
121: for (y = 0; y < bltheight; y++) {
122: for (x = 0; x < bltwidth; x+=2) {
123: p1 = *dst;
124: p2 = *(dst+1);
125: ROP_OP(p1, *src);
126: ROP_OP(p2, *(src+1));
127: if ((p1 != s->gr[0x34]) || (p2 != s->gr[0x35])) {
128: *dst = p1;
129: *(dst+1) = p2;
130: }
131: dst+=2;
132: src+=2;
133: }
134: dst += dstpitch;
135: src += srcpitch;
136: }
137: }
138:
139: static void
140: glue(glue(cirrus_bitblt_rop_bkwd_transp_, ROP_NAME),_16)(CirrusVGAState *s,
141: uint8_t *dst,const uint8_t *src,
142: int dstpitch,int srcpitch,
143: int bltwidth,int bltheight)
144: {
145: int x,y;
146: uint8_t p1, p2;
147: dstpitch += bltwidth;
148: srcpitch += bltwidth;
149: for (y = 0; y < bltheight; y++) {
150: for (x = 0; x < bltwidth; x+=2) {
151: p1 = *(dst-1);
152: p2 = *dst;
153: ROP_OP(p1, *(src-1));
154: ROP_OP(p2, *src);
155: if ((p1 != s->gr[0x34]) || (p2 != s->gr[0x35])) {
156: *(dst-1) = p1;
157: *dst = p2;
158: }
159: dst-=2;
160: src-=2;
161: }
162: dst += dstpitch;
163: src += srcpitch;
164: }
165: }
166:
167: #define DEPTH 8
168: #include "cirrus_vga_rop2.h"
169:
170: #define DEPTH 16
171: #include "cirrus_vga_rop2.h"
172:
173: #define DEPTH 24
174: #include "cirrus_vga_rop2.h"
175:
176: #define DEPTH 32
177: #include "cirrus_vga_rop2.h"
178:
179: #undef ROP_NAME
180: #undef ROP_OP