summaryrefslogtreecommitdiffstats
path: root/docs/specs/standard-vga.txt
blob: 8a4c1e93cd46f19d7ce3e66ab9a2e9fcb0f4963b (plain) (blame)
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
56
57
58
59
60
61
62
63
64
65

QEMU Standard VGA
=================

Exists in two variants, for isa and pci.

command line switches:
    -vga std            [ picks isa for -M isapc, otherwise pci ]
    -device VGA         [ pci variant ]
    -device isa-vga     [ isa variant ]


PCI spec
--------

Applies to the pci variant only for obvious reasons.

PCI ID: 1234:1111

PCI Region 0:
   Framebuffer memory, 16 MB in size (by default).
   Size is tunable via vga_mem_mb property.

PCI Region 1:
   Reserved (so we have the option to make the framebuffer bar 64bit).

PCI Region 2:
   MMIO bar, 4096 bytes in size (qemu 1.3+)

PCI ROM Region:
   Holds the vgabios (qemu 0.14+).


IO ports used
-------------

03c0 - 03df : standard vga ports
01ce        : bochs vbe interface index port
01cf        : bochs vbe interface data port (x86 only)
01d0        : bochs vbe interface data port


Memory regions used
-------------------

0xe0000000 : Framebuffer memory, isa variant only.

The pci variant used to mirror the framebuffer bar here, qemu 0.14+
stops doing that (except when in -M pc-$old compat mode).


MMIO area spec
--------------

Likewise applies to the pci variant only for obvious reasons.

0000 - 03ff : reserved, for possible virtio extension.
0400 - 041f : vga ioports (0x3c0 -> 0x3df), remapped 1:1.
              word access is supported, bytes are written
              in little endia order (aka index port first),
              so indexed registers can be updated with a
              single mmio write (and thus only one vmexit).
0500 - 0515 : bochs dispi interface registers, mapped flat
              without index/data ports.  Use (index << 1)
              as offset for (16bit) register access.