Statistics
| Branch: | Revision:

root / hw / cirrus_vga_rop.h @ 2802bfe3

History | View | Annotate | Download (2.4 kB)

1
/*
2
 * QEMU Cirrus CLGD 54xx VGA Emulator.
3
 * 
4
 * Copyright (c) 2004 Fabrice Bellard
5
 * 
6
 * Permission is hereby granted, free of charge, to any person obtaining a copy
7
 * of this software and associated documentation files (the "Software"), to deal
8
 * in the Software without restriction, including without limitation the rights
9
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10
 * copies of the Software, and to permit persons to whom the Software is
11
 * furnished to do so, subject to the following conditions:
12
 *
13
 * The above copyright notice and this permission notice shall be included in
14
 * all copies or substantial portions of the Software.
15
 *
16
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
22
 * THE SOFTWARE.
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
#define DEPTH 8
66
#include "cirrus_vga_rop2.h"
67

    
68
#define DEPTH 16
69
#include "cirrus_vga_rop2.h"
70

    
71
#define DEPTH 24
72
#include "cirrus_vga_rop2.h"
73

    
74
#define DEPTH 32
75
#include "cirrus_vga_rop2.h"
76

    
77
#undef ROP_NAME
78
#undef ROP_OP