2
0

vga-isa.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. * QEMU ISA VGA Emulator.
  3. *
  4. * see docs/specs/standard-vga.txt for virtual hardware specs.
  5. *
  6. * Copyright (c) 2003 Fabrice Bellard
  7. *
  8. * Permission is hereby granted, free of charge, to any person obtaining a copy
  9. * of this software and associated documentation files (the "Software"), to deal
  10. * in the Software without restriction, including without limitation the rights
  11. * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  12. * copies of the Software, and to permit persons to whom the Software is
  13. * furnished to do so, subject to the following conditions:
  14. *
  15. * The above copyright notice and this permission notice shall be included in
  16. * all copies or substantial portions of the Software.
  17. *
  18. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  19. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  20. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  21. * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  22. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  23. * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
  24. * THE SOFTWARE.
  25. */
  26. #include "hw/hw.h"
  27. #include "ui/console.h"
  28. #include "hw/i386/pc.h"
  29. #include "vga_int.h"
  30. #include "ui/pixel_ops.h"
  31. #include "qemu/timer.h"
  32. #include "hw/loader.h"
  33. #define TYPE_ISA_VGA "isa-vga"
  34. #define ISA_VGA(obj) OBJECT_CHECK(ISAVGAState, (obj), TYPE_ISA_VGA)
  35. typedef struct ISAVGAState {
  36. ISADevice parent_obj;
  37. struct VGACommonState state;
  38. } ISAVGAState;
  39. static void vga_isa_reset(DeviceState *dev)
  40. {
  41. ISAVGAState *d = ISA_VGA(dev);
  42. VGACommonState *s = &d->state;
  43. vga_common_reset(s);
  44. }
  45. static void vga_isa_realizefn(DeviceState *dev, Error **errp)
  46. {
  47. ISADevice *isadev = ISA_DEVICE(dev);
  48. ISAVGAState *d = ISA_VGA(dev);
  49. VGACommonState *s = &d->state;
  50. MemoryRegion *vga_io_memory;
  51. const MemoryRegionPortio *vga_ports, *vbe_ports;
  52. vga_common_init(s, OBJECT(dev));
  53. s->legacy_address_space = isa_address_space(isadev);
  54. vga_io_memory = vga_init_io(s, OBJECT(dev), &vga_ports, &vbe_ports);
  55. isa_register_portio_list(isadev, 0x3b0, vga_ports, s, "vga");
  56. if (vbe_ports) {
  57. isa_register_portio_list(isadev, 0x1ce, vbe_ports, s, "vbe");
  58. }
  59. memory_region_add_subregion_overlap(isa_address_space(isadev),
  60. isa_mem_base + 0x000a0000,
  61. vga_io_memory, 1);
  62. memory_region_set_coalescing(vga_io_memory);
  63. s->con = graphic_console_init(DEVICE(dev), 0, s->hw_ops, s);
  64. vga_init_vbe(s, OBJECT(dev), isa_address_space(isadev));
  65. /* ROM BIOS */
  66. rom_add_vga(VGABIOS_FILENAME);
  67. }
  68. static Property vga_isa_properties[] = {
  69. DEFINE_PROP_UINT32("vgamem_mb", ISAVGAState, state.vram_size_mb, 8),
  70. DEFINE_PROP_END_OF_LIST(),
  71. };
  72. static void vga_isa_class_initfn(ObjectClass *klass, void *data)
  73. {
  74. DeviceClass *dc = DEVICE_CLASS(klass);
  75. dc->realize = vga_isa_realizefn;
  76. dc->reset = vga_isa_reset;
  77. dc->vmsd = &vmstate_vga_common;
  78. dc->props = vga_isa_properties;
  79. set_bit(DEVICE_CATEGORY_DISPLAY, dc->categories);
  80. }
  81. static const TypeInfo vga_isa_info = {
  82. .name = TYPE_ISA_VGA,
  83. .parent = TYPE_ISA_DEVICE,
  84. .instance_size = sizeof(ISAVGAState),
  85. .class_init = vga_isa_class_initfn,
  86. };
  87. static void vga_isa_register_types(void)
  88. {
  89. type_register_static(&vga_isa_info);
  90. }
  91. type_init(vga_isa_register_types)