2 Copyright © 1995-2008, The AROS Development Team. All rights reserved.
5 Desc: vmware svga hardware functions
9 #define DEBUG 1 /* no SysBase */
10 #include <aros/debug.h>
14 #include "vmwaresvgahardware.h"
16 #include "vmwaresvgaclass.h"
18 ULONG
vmwareReadReg(struct HWData
*data
, ULONG reg
)
20 outl(reg
, data
->indexReg
);
21 return inl(data
->valueReg
);
24 void vmwareWriteReg(struct HWData
*data
, ULONG reg
, ULONG val
)
26 outl(reg
, data
->indexReg
);
27 outl(val
, data
->valueReg
);
31 extern struct ExecBase
*SysBase
;
33 ULONG
getVMWareSVGAID(struct HWData
*data
)
37 vmwareWriteReg(data
, SVGA_REG_ID
, SVGA_ID_2
);
38 id
= vmwareReadReg(data
, SVGA_REG_ID
);
41 vmwareWriteReg(data
, SVGA_REG_ID
, SVGA_ID_1
);
42 id
= vmwareReadReg(data
, SVGA_REG_ID
);
47 return SVGA_ID_INVALID
;
50 VOID
initVMWareSVGAFIFO(struct HWData
*data
)
55 vmwareWriteReg(data
, SVGA_REG_CONFIG_DONE
, 0); //Stop vmware from reading the fifo
57 fifo
= data
->mmiobase
= vmwareReadReg(data
, SVGA_REG_MEM_START
);
58 data
->mmiosize
= vmwareReadReg(data
, SVGA_REG_MEM_SIZE
) & ~3;
60 if (data
->capabilities
& SVGA_CAP_EXTENDED_FIFO
)
61 fifomin
= vmwareReadReg(data
, SVGA_REG_MEM_REGS
);
65 fifo
[SVGA_FIFO_MIN
] = fifomin
* sizeof(ULONG
);
67 /* reduce size of FIFO queue to prevent VMWare from failing */
68 fifo
[SVGA_FIFO_MAX
] = (data
->mmiosize
> 65536) ? 65536 : data
->mmiosize
;
69 fifo
[SVGA_FIFO_NEXT_CMD
] = fifomin
* sizeof(ULONG
);
70 fifo
[SVGA_FIFO_STOP
] = fifomin
* sizeof(ULONG
);
72 vmwareWriteReg(data
, SVGA_REG_CONFIG_DONE
, 1);
75 VOID
syncVMWareSVGAFIFO(struct HWData
*data
)
77 vmwareWriteReg(data
, SVGA_REG_SYNC
, 1);
78 while (vmwareReadReg(data
, SVGA_REG_BUSY
) != 0);
79 #warning "maybe wait (delay) some time"
82 VOID
writeVMWareSVGAFIFO(struct HWData
*data
, ULONG val
)
86 fifo
= data
->mmiobase
;
88 (fifo
[SVGA_FIFO_NEXT_CMD
]+4 == fifo
[SVGA_FIFO_STOP
]) ||
90 (fifo
[SVGA_FIFO_NEXT_CMD
] == (fifo
[SVGA_FIFO_MAX
]-4)) &&
91 (fifo
[SVGA_FIFO_STOP
] == fifo
[SVGA_FIFO_MIN
])
94 syncVMWareSVGAFIFO(data
);
96 fifo
[fifo
[SVGA_FIFO_NEXT_CMD
] / 4] = val
;
97 fifo
[SVGA_FIFO_NEXT_CMD
] += 4;
99 if (fifo
[SVGA_FIFO_NEXT_CMD
] == fifo
[SVGA_FIFO_MAX
])
100 fifo
[SVGA_FIFO_NEXT_CMD
] = fifo
[SVGA_FIFO_MIN
];
103 BOOL
initVMWareSVGAHW(struct HWData
*data
, OOP_Object
*device
)
108 id
= getVMWareSVGAID(data
);
109 if ((id
== SVGA_ID_0
) || (id
== SVGA_ID_INVALID
))
114 initVMWareSVGAFIFO(data
);
116 data
->capabilities
= vmwareReadReg(data
, SVGA_REG_CAPABILITIES
);
118 if (data
->capabilities
& SVGA_CAP_8BIT_EMULATION
)
120 data
->bitsperpixel
= vmwareReadReg(data
, SVGA_REG_HOST_BITS_PER_PIXEL
);
121 vmwareWriteReg(data
,SVGA_REG_BITS_PER_PIXEL
, data
->bitsperpixel
);
123 data
->bitsperpixel
= vmwareReadReg(data
, SVGA_REG_BITS_PER_PIXEL
);
125 data
->depth
= vmwareReadReg(data
, SVGA_REG_DEPTH
);
126 data
->maxwidth
= vmwareReadReg(data
, SVGA_REG_MAX_WIDTH
);
127 data
->maxheight
= vmwareReadReg(data
, SVGA_REG_MAX_HEIGHT
);
128 data
->redmask
= vmwareReadReg(data
, SVGA_REG_RED_MASK
);
129 data
->greenmask
= vmwareReadReg(data
, SVGA_REG_GREEN_MASK
);
130 data
->bluemask
= vmwareReadReg(data
, SVGA_REG_BLUE_MASK
);
131 data
->bytesperpixel
= 1;
134 data
->bytesperpixel
= 4;
135 else if (data
->depth
>8)
136 data
->bytesperpixel
= 2;
138 if (data
->capabilities
& SVGA_CAP_MULTIMON
)
140 data
->displaycount
= vmwareReadReg(data
, SVGA_REG_NUM_DISPLAYS
);
144 data
->displaycount
= 1;
147 data
->vramsize
= vmwareReadReg(data
, SVGA_REG_VRAM_SIZE
);
148 data
->vrambase
= vmwareReadReg(data
, SVGA_REG_FB_START
);
149 data
->pseudocolor
= vmwareReadReg(data
, SVGA_REG_PSEUDOCOLOR
);
151 D(bug("[VMWareSVGA] Init: VRAM at 0x%08x size %d\n",data
->vrambase
, data
->vramsize
));
152 D(bug("[VMWareSVGA] Init: no.displays: %d\n",data
->displaycount
));
153 D(bug("[VMWareSVGA] Init: caps : 0x%08x\n",data
->capabilities
));
154 D(bug("[VMWareSVGA] Init: no.displays: %d\n",data
->displaycount
));
155 D(bug("[VMWareSVGA] Init: depth: %d\n",data
->depth
));
156 D(bug("[VMWareSVGA] Init: bpp : %d\n",data
->bitsperpixel
));
157 D(bug("[VMWareSVGA] Init: maxw: %d\n",data
->maxwidth
));
158 D(bug("[VMWareSVGA] Init: maxh: %d\n",data
->maxheight
));
163 VOID
setModeVMWareSVGA(struct HWData
*data
, ULONG width
, ULONG height
)
165 D(bug("[VMWareSVGA] SetMode: %dx%d\n",width
,height
));
166 vmwareWriteReg(data
, SVGA_REG_ENABLE
, 0);
167 vmwareWriteReg(data
, SVGA_REG_WIDTH
, width
);
168 vmwareWriteReg(data
, SVGA_REG_HEIGHT
, height
);
170 if (data
->capabilities
& SVGA_CAP_8BIT_EMULATION
)
171 vmwareWriteReg(data
, SVGA_REG_BITS_PER_PIXEL
,data
->bitsperpixel
);
173 vmwareWriteReg(data
, SVGA_REG_ENABLE
, 1);
175 data
->fboffset
= vmwareReadReg(data
, SVGA_REG_FB_OFFSET
);
176 data
->bytesperline
= vmwareReadReg(data
, SVGA_REG_BYTES_PER_LINE
);
177 data
->depth
= vmwareReadReg(data
, SVGA_REG_DEPTH
);
178 data
->redmask
= vmwareReadReg(data
, SVGA_REG_RED_MASK
);
179 data
->greenmask
= vmwareReadReg(data
, SVGA_REG_GREEN_MASK
);
180 data
->bluemask
= vmwareReadReg(data
, SVGA_REG_BLUE_MASK
);
181 data
->pseudocolor
= vmwareReadReg(data
, SVGA_REG_PSEUDOCOLOR
);
184 VOID
refreshAreaVMWareSVGA(struct HWData
*data
, struct Box
*box
)
186 writeVMWareSVGAFIFO(data
, SVGA_CMD_UPDATE
);
187 writeVMWareSVGAFIFO(data
, box
->x1
);
188 writeVMWareSVGAFIFO(data
, box
->y1
);
189 writeVMWareSVGAFIFO(data
, box
->x2
-box
->x1
+1);
190 writeVMWareSVGAFIFO(data
, box
->y2
-box
->y1
+1);
193 VOID
rectFillVMWareSVGA(struct HWData
*data
, ULONG color
, LONG x
, LONG y
, LONG width
, LONG height
)
195 writeVMWareSVGAFIFO(data
, SVGA_CMD_RECT_FILL
);
196 writeVMWareSVGAFIFO(data
, color
);
197 writeVMWareSVGAFIFO(data
, x
);
198 writeVMWareSVGAFIFO(data
, y
);
199 writeVMWareSVGAFIFO(data
, width
);
200 writeVMWareSVGAFIFO(data
, height
);
201 syncVMWareSVGAFIFO(data
);
204 VOID
ropFillVMWareSVGA(struct HWData
*data
, ULONG color
, LONG x
, LONG y
, LONG width
, LONG height
, ULONG mode
)
206 writeVMWareSVGAFIFO(data
, SVGA_CMD_RECT_ROP_FILL
);
207 writeVMWareSVGAFIFO(data
, color
);
208 writeVMWareSVGAFIFO(data
, x
);
209 writeVMWareSVGAFIFO(data
, y
);
210 writeVMWareSVGAFIFO(data
, width
);
211 writeVMWareSVGAFIFO(data
, height
);
212 writeVMWareSVGAFIFO(data
, mode
);
213 syncVMWareSVGAFIFO(data
);
216 VOID
ropCopyVMWareSVGA(struct HWData
*data
, LONG sx
, LONG sy
, LONG dx
, LONG dy
, ULONG width
, ULONG height
, ULONG mode
)
218 writeVMWareSVGAFIFO(data
, SVGA_CMD_RECT_ROP_COPY
);
219 writeVMWareSVGAFIFO(data
, sx
);
220 writeVMWareSVGAFIFO(data
, sy
);
221 writeVMWareSVGAFIFO(data
, dx
);
222 writeVMWareSVGAFIFO(data
, dy
);
223 writeVMWareSVGAFIFO(data
, width
);
224 writeVMWareSVGAFIFO(data
, height
);
225 writeVMWareSVGAFIFO(data
, mode
);
226 syncVMWareSVGAFIFO(data
);
229 VOID
defineCursorVMWareSVGA(struct HWData
*data
, struct MouseData
*mouse
)
232 ULONG
*cshape
= mouse
->shape
;
234 ULONG andmask
[SVGA_PIXMAP_SIZE(mouse
->width
, mouse
->height
, data
->bitsperpixel
)];
238 #warning "convert mouse shape to current depth"
239 writeVMWareSVGAFIFO(data
, SVGA_CMD_DEFINE_CURSOR
);
240 writeVMWareSVGAFIFO(data
, 1);
241 writeVMWareSVGAFIFO(data
, 0); /* hot x value */
242 writeVMWareSVGAFIFO(data
, 0); /* hot y value */
243 writeVMWareSVGAFIFO(data
, mouse
->width
); /* width */
244 writeVMWareSVGAFIFO(data
, mouse
->height
); /* height */
245 writeVMWareSVGAFIFO(data
, data
->bitsperpixel
); /* bits per pixel */
246 writeVMWareSVGAFIFO(data
, data
->bitsperpixel
); /* bits per pixel */
249 for (i
= 0; i
<(SVGA_PIXMAP_SIZE(mouse
->width
, mouse
->height
, data
->bitsperpixel
)*2);i
++)
251 *((UWORD
*)a
) = *((UWORD
*)b
) ? 0 : ~0;
253 a
= ((UWORD
*)a
) + 1;
254 b
= ((UWORD
*)b
) + 1;
257 for (i
= 0; i
<SVGA_PIXMAP_SIZE(mouse
->width
, mouse
->height
, data
->bitsperpixel
);i
++)
258 writeVMWareSVGAFIFO(data
, *a
++);
259 for (i
= 0; i
<SVGA_PIXMAP_SIZE(mouse
->width
, mouse
->height
, data
->bitsperpixel
);i
++)
260 writeVMWareSVGAFIFO(data
, *cshape
++);
261 syncVMWareSVGAFIFO(data
);
264 VOID
displayCursorVMWareSVGA(struct HWData
*data
, LONG mode
)
267 writeVMWareSVGAFIFO(data
, SVGA_CMD_DISPLAY_CURSOR
);
268 writeVMWareSVGAFIFO(data
, 1);
269 writeVMWareSVGAFIFO(data
, mode
);
270 syncVMWareSVGAFIFO(data
);
272 vmwareWriteReg(data
, SVGA_REG_CURSOR_ID
, 1);
273 vmwareWriteReg(data
, SVGA_REG_CURSOR_ON
, mode
);
277 VOID
moveCursorVMWareSVGA(struct HWData
*data
, LONG x
, LONG y
)
280 writeVMWareSVGAFIFO(data
, SVGA_CMD_MOVE_CURSOR
);
281 writeVMWareSVGAFIFO(data
, x
);
282 writeVMWareSVGAFIFO(data
, y
);
283 syncVMWareSVGAFIFO(data
);
285 vmwareWriteReg(data
, SVGA_REG_CURSOR_ID
, 1);
286 vmwareWriteReg(data
, SVGA_REG_CURSOR_X
, x
);
287 vmwareWriteReg(data
, SVGA_REG_CURSOR_Y
, y
);
288 vmwareWriteReg(data
, SVGA_REG_CURSOR_ON
, 1);