summaryrefslogtreecommitdiffstats
path: root/vidix/drivers/nvidia.h
blob: f19e9a6344de4a8e032c25f32ef6b31fc6e3eb7a (plain)
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include <inttypes.h>

#define RIVA_FIFO_FREE(hwptr, cnt) \
{ \
    while (nv_fifo_space < (cnt)) { \
	nv_fifo_space = hwptr->fifo_free >> 2; \
    } \
    nv_fifo_space -= (cnt); \
}

typedef struct {
    uint32_t	reserved00[4];
    uint16_t	fifo_free;
    uint16_t	nop[1];
    uint32_t	reserved01[0x03b];
    
    uint32_t	no_operation;
    uint32_t	notify;
    uint32_t	reserved02[0x01e];
    uint32_t	set_context_dma_notifies;
    uint32_t	set_context_dma_image;
    uint32_t	set_context_pattern;
    uint32_t	set_context_rop;
    uint32_t	set_context_beta1;
    uint32_t	set_context_surface;
    uint32_t	reserved03[0x05a];
    uint32_t	set_color_format;
    uint32_t	set_operation;
    int16_t	clip_x;
    int16_t	clip_y;
    uint16_t	clip_height;
    uint16_t	clip_width;
    int16_t	image_out_x;
    int16_t	image_out_y;
    uint16_t	image_out_height;
    uint16_t	image_out_width;
    uint32_t	du_dx;
    uint32_t	du_dy;
    uint32_t	reserved04[0x38];
    uint16_t	image_in_height;
    uint16_t	image_in_width;
    uint32_t	image_in_format;
    uint32_t	image_in_offset;
    uint32_t	image_in_point;
    uint32_t	reserved05[0x6fc];
} RivaScaledImage;

#define dump_scaledimage(x) { \
    printf("clip: pos: %dx%d, size: %dx%d\n", \
	x->clip_x, x->clip_y, x->clip_height, x->clip_width); \
    printf("image_out: pos: %dx%d, size: %dx%d\n", \
	x->image_out_x, x->image_out_y, x->image_out_height, x->image_out_width); \
    printf("image_in: size: %dx%d format: %x offset: %x\n", \
	x->image_in_height, x->image_in_width, x->image_in_format, x->image_in_offset); \
}