v86 0.3.6 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Readme.md +17 -6
- package/bios/seabios/.config +113 -0
- package/bios/seabios/.config.old +114 -0
- package/bios/seabios/.gitignore +4 -0
- package/bios/seabios/COPYING +674 -0
- package/bios/seabios/COPYING.LESSER +165 -0
- package/bios/seabios/Makefile +286 -0
- package/bios/seabios/README +17 -0
- package/bios/seabios/docs/Build_overview.md +104 -0
- package/bios/seabios/docs/Contributing.md +20 -0
- package/bios/seabios/docs/Debugging.md +111 -0
- package/bios/seabios/docs/Developer_Documentation.md +25 -0
- package/bios/seabios/docs/Developer_links.md +86 -0
- package/bios/seabios/docs/Download.md +27 -0
- package/bios/seabios/docs/Execution_and_code_flow.md +178 -0
- package/bios/seabios/docs/Linking_overview.md +160 -0
- package/bios/seabios/docs/Mailinglist.md +8 -0
- package/bios/seabios/docs/Memory_Model.md +253 -0
- package/bios/seabios/docs/README +5 -0
- package/bios/seabios/docs/Releases.md +482 -0
- package/bios/seabios/docs/Runtime_config.md +193 -0
- package/bios/seabios/docs/SeaBIOS.md +17 -0
- package/bios/seabios/docs/SeaVGABIOS.md +39 -0
- package/bios/seabios/out/autoconf.h +117 -0
- package/bios/seabios/out/include/config/acpi/dsdt.h +0 -0
- package/bios/seabios/out/include/config/acpi.h +0 -0
- package/bios/seabios/out/include/config/ahci.h +0 -0
- package/bios/seabios/out/include/config/apmbios.h +0 -0
- package/bios/seabios/out/include/config/ata/dma.h +0 -0
- package/bios/seabios/out/include/config/ata/pio32.h +0 -0
- package/bios/seabios/out/include/config/ata.h +0 -0
- package/bios/seabios/out/include/config/auto.conf +69 -0
- package/bios/seabios/out/include/config/auto.conf.cmd +9 -0
- package/bios/seabios/out/include/config/boot.h +0 -0
- package/bios/seabios/out/include/config/bootorder.h +0 -0
- package/bios/seabios/out/include/config/build/vgabios.h +0 -0
- package/bios/seabios/out/include/config/call32/smm.h +0 -0
- package/bios/seabios/out/include/config/cdrom/boot.h +0 -0
- package/bios/seabios/out/include/config/cdrom/emu.h +0 -0
- package/bios/seabios/out/include/config/debug/level.h +0 -0
- package/bios/seabios/out/include/config/drives.h +0 -0
- package/bios/seabios/out/include/config/entry/extrastack.h +0 -0
- package/bios/seabios/out/include/config/esp/scsi.h +0 -0
- package/bios/seabios/out/include/config/flash/floppy.h +0 -0
- package/bios/seabios/out/include/config/floppy.h +0 -0
- package/bios/seabios/out/include/config/fw/romfile/load.h +0 -0
- package/bios/seabios/out/include/config/hardware/irq.h +0 -0
- package/bios/seabios/out/include/config/kbd/call/int15/4f.h +0 -0
- package/bios/seabios/out/include/config/keyboard.h +0 -0
- package/bios/seabios/out/include/config/lpt.h +0 -0
- package/bios/seabios/out/include/config/lsi/scsi.h +0 -0
- package/bios/seabios/out/include/config/malloc/uppermemory.h +0 -0
- package/bios/seabios/out/include/config/megasas.h +0 -0
- package/bios/seabios/out/include/config/mouse.h +0 -0
- package/bios/seabios/out/include/config/mpt/scsi.h +0 -0
- package/bios/seabios/out/include/config/mptable.h +0 -0
- package/bios/seabios/out/include/config/mtrr/init.h +0 -0
- package/bios/seabios/out/include/config/optionroms.h +0 -0
- package/bios/seabios/out/include/config/override/pci/id.h +0 -0
- package/bios/seabios/out/include/config/pcibios.h +0 -0
- package/bios/seabios/out/include/config/pirtable.h +0 -0
- package/bios/seabios/out/include/config/pmm.h +0 -0
- package/bios/seabios/out/include/config/pmtimer.h +0 -0
- package/bios/seabios/out/include/config/pnpbios.h +0 -0
- package/bios/seabios/out/include/config/ps2port.h +0 -0
- package/bios/seabios/out/include/config/pvscsi.h +0 -0
- package/bios/seabios/out/include/config/qemu/hardware.h +0 -0
- package/bios/seabios/out/include/config/qemu.h +0 -0
- package/bios/seabios/out/include/config/rom/size.h +0 -0
- package/bios/seabios/out/include/config/rtc/timer.h +0 -0
- package/bios/seabios/out/include/config/s3/resume.h +0 -0
- package/bios/seabios/out/include/config/sdcard.h +0 -0
- package/bios/seabios/out/include/config/serial.h +0 -0
- package/bios/seabios/out/include/config/tcgbios.h +0 -0
- package/bios/seabios/out/include/config/threads.h +0 -0
- package/bios/seabios/out/include/config/tristate.conf +4 -0
- package/bios/seabios/out/include/config/tsc/timer.h +0 -0
- package/bios/seabios/out/include/config/use/smm.h +0 -0
- package/bios/seabios/out/include/config/vga/allocate/extra/stack.h +0 -0
- package/bios/seabios/out/include/config/vga/bochs/stdvga.h +0 -0
- package/bios/seabios/out/include/config/vga/bochs.h +0 -0
- package/bios/seabios/out/include/config/vga/did.h +0 -0
- package/bios/seabios/out/include/config/vga/extra/stack/size.h +0 -0
- package/bios/seabios/out/include/config/vga/fixup/asm.h +0 -0
- package/bios/seabios/out/include/config/vga/pci.h +0 -0
- package/bios/seabios/out/include/config/vga/stdvga/ports.h +0 -0
- package/bios/seabios/out/include/config/vga/vbe.h +0 -0
- package/bios/seabios/out/include/config/vga/vid.h +0 -0
- package/bios/seabios/out/include/config/vgahooks.h +0 -0
- package/bios/seabios/out/include/config/virtio/blk.h +0 -0
- package/bios/seabios/out/include/config/virtio/scsi.h +0 -0
- package/bios/seabios/out/include/config/xen.h +0 -0
- package/bios/seabios/out/scripts/kconfig/conf +0 -0
- package/bios/seabios/out/scripts/kconfig/conf.o +0 -0
- package/bios/seabios/out/scripts/kconfig/zconf.hash.c +289 -0
- package/bios/seabios/out/scripts/kconfig/zconf.lex.c +2420 -0
- package/bios/seabios/out/scripts/kconfig/zconf.tab.c +2538 -0
- package/bios/seabios/out/scripts/kconfig/zconf.tab.o +0 -0
- package/bios/seabios/scripts/acpi_extract.py +366 -0
- package/bios/seabios/scripts/acpi_extract_preprocess.py +41 -0
- package/bios/seabios/scripts/buildrom.py +56 -0
- package/bios/seabios/scripts/buildversion.py +134 -0
- package/bios/seabios/scripts/checkrom.py +95 -0
- package/bios/seabios/scripts/checkstack.py +226 -0
- package/bios/seabios/scripts/checksum.py +16 -0
- package/bios/seabios/scripts/encodeint.py +21 -0
- package/bios/seabios/scripts/gen-offsets.sh +17 -0
- package/bios/seabios/scripts/kconfig/.gitignore +22 -0
- package/bios/seabios/scripts/kconfig/Makefile +331 -0
- package/bios/seabios/scripts/kconfig/POTFILES.in +12 -0
- package/bios/seabios/scripts/kconfig/check.sh +13 -0
- package/bios/seabios/scripts/kconfig/conf.c +718 -0
- package/bios/seabios/scripts/kconfig/confdata.c +1250 -0
- package/bios/seabios/scripts/kconfig/expr.c +1168 -0
- package/bios/seabios/scripts/kconfig/expr.h +241 -0
- package/bios/seabios/scripts/kconfig/gconf.c +1542 -0
- package/bios/seabios/scripts/kconfig/gconf.glade +661 -0
- package/bios/seabios/scripts/kconfig/images.c +326 -0
- package/bios/seabios/scripts/kconfig/kxgettext.c +235 -0
- package/bios/seabios/scripts/kconfig/lex.zconf.c +2430 -0
- package/bios/seabios/scripts/kconfig/list.h +131 -0
- package/bios/seabios/scripts/kconfig/lkc.h +200 -0
- package/bios/seabios/scripts/kconfig/lkc_proto.h +57 -0
- package/bios/seabios/scripts/kconfig/lxdialog/.gitignore +4 -0
- package/bios/seabios/scripts/kconfig/lxdialog/BIG.FAT.WARNING +4 -0
- package/bios/seabios/scripts/kconfig/lxdialog/check-lxdialog.sh +87 -0
- package/bios/seabios/scripts/kconfig/lxdialog/checklist.c +332 -0
- package/bios/seabios/scripts/kconfig/lxdialog/dialog.h +257 -0
- package/bios/seabios/scripts/kconfig/lxdialog/inputbox.c +301 -0
- package/bios/seabios/scripts/kconfig/lxdialog/menubox.c +437 -0
- package/bios/seabios/scripts/kconfig/lxdialog/textbox.c +408 -0
- package/bios/seabios/scripts/kconfig/lxdialog/util.c +713 -0
- package/bios/seabios/scripts/kconfig/lxdialog/yesno.c +114 -0
- package/bios/seabios/scripts/kconfig/mconf.c +1036 -0
- package/bios/seabios/scripts/kconfig/menu.c +697 -0
- package/bios/seabios/scripts/kconfig/merge_config.sh +150 -0
- package/bios/seabios/scripts/kconfig/nconf.c +1556 -0
- package/bios/seabios/scripts/kconfig/nconf.gui.c +656 -0
- package/bios/seabios/scripts/kconfig/nconf.h +96 -0
- package/bios/seabios/scripts/kconfig/qconf.cc +1795 -0
- package/bios/seabios/scripts/kconfig/qconf.h +338 -0
- package/bios/seabios/scripts/kconfig/streamline_config.pl +647 -0
- package/bios/seabios/scripts/kconfig/symbol.c +1373 -0
- package/bios/seabios/scripts/kconfig/util.c +157 -0
- package/bios/seabios/scripts/kconfig/zconf.gperf +48 -0
- package/bios/seabios/scripts/kconfig/zconf.hash.c_shipped +289 -0
- package/bios/seabios/scripts/kconfig/zconf.l +363 -0
- package/bios/seabios/scripts/kconfig/zconf.lex.c_shipped +2420 -0
- package/bios/seabios/scripts/kconfig/zconf.tab.c_shipped +2538 -0
- package/bios/seabios/scripts/kconfig/zconf.y +733 -0
- package/bios/seabios/scripts/layoutrom.py +705 -0
- package/bios/seabios/scripts/python23compat.py +14 -0
- package/bios/seabios/scripts/readserial.py +190 -0
- package/bios/seabios/scripts/tarball.sh +36 -0
- package/bios/seabios/scripts/test-build.sh +90 -0
- package/bios/seabios/scripts/transdump.py +53 -0
- package/bios/seabios/scripts/vgafixup.py +96 -0
- package/bios/seabios/src/Kconfig +579 -0
- package/bios/seabios/src/apm.c +215 -0
- package/bios/seabios/src/asm-offsets.c +23 -0
- package/bios/seabios/src/biosvar.h +130 -0
- package/bios/seabios/src/block.c +623 -0
- package/bios/seabios/src/block.h +121 -0
- package/bios/seabios/src/bmp.c +117 -0
- package/bios/seabios/src/boot.c +793 -0
- package/bios/seabios/src/bootsplash.c +255 -0
- package/bios/seabios/src/bregs.h +80 -0
- package/bios/seabios/src/byteorder.h +71 -0
- package/bios/seabios/src/cdrom.c +322 -0
- package/bios/seabios/src/clock.c +506 -0
- package/bios/seabios/src/code16gcc.s +1 -0
- package/bios/seabios/src/config.h +108 -0
- package/bios/seabios/src/cp437.c +275 -0
- package/bios/seabios/src/cp437.h +1 -0
- package/bios/seabios/src/disk.c +779 -0
- package/bios/seabios/src/e820map.c +152 -0
- package/bios/seabios/src/e820map.h +26 -0
- package/bios/seabios/src/entryfuncs.S +165 -0
- package/bios/seabios/src/farptr.h +208 -0
- package/bios/seabios/src/font.c +139 -0
- package/bios/seabios/src/fw/acpi-dsdt-cpu-hotplug.dsl +78 -0
- package/bios/seabios/src/fw/acpi-dsdt-dbug.dsl +26 -0
- package/bios/seabios/src/fw/acpi-dsdt-hpet.dsl +36 -0
- package/bios/seabios/src/fw/acpi-dsdt-isa.dsl +102 -0
- package/bios/seabios/src/fw/acpi-dsdt-pci-crs.dsl +90 -0
- package/bios/seabios/src/fw/acpi-dsdt.dsl +342 -0
- package/bios/seabios/src/fw/acpi-dsdt.hex +554 -0
- package/bios/seabios/src/fw/acpi.c +685 -0
- package/bios/seabios/src/fw/biostables.c +491 -0
- package/bios/seabios/src/fw/coreboot.c +569 -0
- package/bios/seabios/src/fw/csm.c +347 -0
- package/bios/seabios/src/fw/dev-pci.h +52 -0
- package/bios/seabios/src/fw/dev-piix.h +29 -0
- package/bios/seabios/src/fw/dev-q35.h +52 -0
- package/bios/seabios/src/fw/lzmadecode.c +398 -0
- package/bios/seabios/src/fw/lzmadecode.h +67 -0
- package/bios/seabios/src/fw/mptable.c +197 -0
- package/bios/seabios/src/fw/mtrr.c +105 -0
- package/bios/seabios/src/fw/multiboot.c +111 -0
- package/bios/seabios/src/fw/paravirt.c +624 -0
- package/bios/seabios/src/fw/paravirt.h +63 -0
- package/bios/seabios/src/fw/pciinit.c +1187 -0
- package/bios/seabios/src/fw/pirtable.c +103 -0
- package/bios/seabios/src/fw/q35-acpi-dsdt.dsl +450 -0
- package/bios/seabios/src/fw/romfile_loader.c +259 -0
- package/bios/seabios/src/fw/romfile_loader.h +91 -0
- package/bios/seabios/src/fw/shadow.c +208 -0
- package/bios/seabios/src/fw/smbios.c +585 -0
- package/bios/seabios/src/fw/smm.c +269 -0
- package/bios/seabios/src/fw/smp.c +194 -0
- package/bios/seabios/src/fw/ssdt-misc.dsl +104 -0
- package/bios/seabios/src/fw/ssdt-misc.hex +88 -0
- package/bios/seabios/src/fw/ssdt-pcihp.dsl +36 -0
- package/bios/seabios/src/fw/ssdt-pcihp.hex +38 -0
- package/bios/seabios/src/fw/ssdt-proc.dsl +48 -0
- package/bios/seabios/src/fw/ssdt-proc.hex +35 -0
- package/bios/seabios/src/fw/xen.c +149 -0
- package/bios/seabios/src/fw/xen.h +125 -0
- package/bios/seabios/src/gen-defs.h +19 -0
- package/bios/seabios/src/hw/ahci.c +697 -0
- package/bios/seabios/src/hw/ahci.h +201 -0
- package/bios/seabios/src/hw/ata.c +1046 -0
- package/bios/seabios/src/hw/ata.h +163 -0
- package/bios/seabios/src/hw/blockcmd.c +372 -0
- package/bios/seabios/src/hw/blockcmd.h +114 -0
- package/bios/seabios/src/hw/dma.c +67 -0
- package/bios/seabios/src/hw/esp-scsi.c +241 -0
- package/bios/seabios/src/hw/esp-scsi.h +8 -0
- package/bios/seabios/src/hw/floppy.c +741 -0
- package/bios/seabios/src/hw/lsi-scsi.c +221 -0
- package/bios/seabios/src/hw/lsi-scsi.h +8 -0
- package/bios/seabios/src/hw/megasas.c +405 -0
- package/bios/seabios/src/hw/megasas.h +8 -0
- package/bios/seabios/src/hw/mpt-scsi.c +319 -0
- package/bios/seabios/src/hw/mpt-scsi.h +8 -0
- package/bios/seabios/src/hw/nvme-int.h +199 -0
- package/bios/seabios/src/hw/nvme.c +708 -0
- package/bios/seabios/src/hw/nvme.h +17 -0
- package/bios/seabios/src/hw/pci.c +133 -0
- package/bios/seabios/src/hw/pci.h +47 -0
- package/bios/seabios/src/hw/pci_ids.h +2632 -0
- package/bios/seabios/src/hw/pci_regs.h +556 -0
- package/bios/seabios/src/hw/pcidevice.c +192 -0
- package/bios/seabios/src/hw/pcidevice.h +76 -0
- package/bios/seabios/src/hw/pic.c +115 -0
- package/bios/seabios/src/hw/pic.h +60 -0
- package/bios/seabios/src/hw/ps2port.c +543 -0
- package/bios/seabios/src/hw/ps2port.h +67 -0
- package/bios/seabios/src/hw/pvscsi.c +333 -0
- package/bios/seabios/src/hw/pvscsi.h +8 -0
- package/bios/seabios/src/hw/ramdisk.c +108 -0
- package/bios/seabios/src/hw/rtc.c +100 -0
- package/bios/seabios/src/hw/rtc.h +75 -0
- package/bios/seabios/src/hw/sdcard.c +572 -0
- package/bios/seabios/src/hw/serialio.c +113 -0
- package/bios/seabios/src/hw/serialio.h +29 -0
- package/bios/seabios/src/hw/timer.c +259 -0
- package/bios/seabios/src/hw/tpm_drivers.c +636 -0
- package/bios/seabios/src/hw/tpm_drivers.h +127 -0
- package/bios/seabios/src/hw/usb-ehci.c +650 -0
- package/bios/seabios/src/hw/usb-ehci.h +177 -0
- package/bios/seabios/src/hw/usb-hid.c +442 -0
- package/bios/seabios/src/hw/usb-hid.h +29 -0
- package/bios/seabios/src/hw/usb-hub.c +205 -0
- package/bios/seabios/src/hw/usb-hub.h +64 -0
- package/bios/seabios/src/hw/usb-msc.c +222 -0
- package/bios/seabios/src/hw/usb-msc.h +10 -0
- package/bios/seabios/src/hw/usb-ohci.c +568 -0
- package/bios/seabios/src/hw/usb-ohci.h +144 -0
- package/bios/seabios/src/hw/usb-uas.c +289 -0
- package/bios/seabios/src/hw/usb-uas.h +9 -0
- package/bios/seabios/src/hw/usb-uhci.c +571 -0
- package/bios/seabios/src/hw/usb-uhci.h +128 -0
- package/bios/seabios/src/hw/usb-xhci.c +1161 -0
- package/bios/seabios/src/hw/usb-xhci.h +133 -0
- package/bios/seabios/src/hw/usb.c +499 -0
- package/bios/seabios/src/hw/usb.h +254 -0
- package/bios/seabios/src/hw/virtio-blk.c +211 -0
- package/bios/seabios/src/hw/virtio-blk.h +43 -0
- package/bios/seabios/src/hw/virtio-pci.c +501 -0
- package/bios/seabios/src/hw/virtio-pci.h +151 -0
- package/bios/seabios/src/hw/virtio-ring.c +147 -0
- package/bios/seabios/src/hw/virtio-ring.h +121 -0
- package/bios/seabios/src/hw/virtio-scsi.c +220 -0
- package/bios/seabios/src/hw/virtio-scsi.h +47 -0
- package/bios/seabios/src/jpeg.c +1055 -0
- package/bios/seabios/src/kbd.c +599 -0
- package/bios/seabios/src/list.h +91 -0
- package/bios/seabios/src/malloc.c +561 -0
- package/bios/seabios/src/malloc.h +70 -0
- package/bios/seabios/src/memmap.h +21 -0
- package/bios/seabios/src/misc.c +195 -0
- package/bios/seabios/src/mouse.c +342 -0
- package/bios/seabios/src/optionroms.c +475 -0
- package/bios/seabios/src/output.c +584 -0
- package/bios/seabios/src/output.h +68 -0
- package/bios/seabios/src/pcibios.c +241 -0
- package/bios/seabios/src/pmm.c +176 -0
- package/bios/seabios/src/pnpbios.c +88 -0
- package/bios/seabios/src/post.c +337 -0
- package/bios/seabios/src/resume.c +157 -0
- package/bios/seabios/src/romfile.c +146 -0
- package/bios/seabios/src/romfile.h +21 -0
- package/bios/seabios/src/romlayout.S +698 -0
- package/bios/seabios/src/sercon.c +677 -0
- package/bios/seabios/src/serial.c +317 -0
- package/bios/seabios/src/sha1.c +147 -0
- package/bios/seabios/src/sha1.h +8 -0
- package/bios/seabios/src/stacks.c +771 -0
- package/bios/seabios/src/stacks.h +68 -0
- package/bios/seabios/src/std/LegacyBios.h +985 -0
- package/bios/seabios/src/std/acpi.h +323 -0
- package/bios/seabios/src/std/bda.h +174 -0
- package/bios/seabios/src/std/disk.h +175 -0
- package/bios/seabios/src/std/mptable.h +77 -0
- package/bios/seabios/src/std/multiboot.h +260 -0
- package/bios/seabios/src/std/optionrom.h +59 -0
- package/bios/seabios/src/std/pirtable.h +35 -0
- package/bios/seabios/src/std/pmm.h +19 -0
- package/bios/seabios/src/std/pnpbios.h +24 -0
- package/bios/seabios/src/std/smbios.h +167 -0
- package/bios/seabios/src/std/tcg.h +554 -0
- package/bios/seabios/src/std/vbe.h +156 -0
- package/bios/seabios/src/std/vga.h +63 -0
- package/bios/seabios/src/string.c +251 -0
- package/bios/seabios/src/string.h +31 -0
- package/bios/seabios/src/system.c +357 -0
- package/bios/seabios/src/tcgbios.c +2014 -0
- package/bios/seabios/src/tcgbios.h +19 -0
- package/bios/seabios/src/types.h +156 -0
- package/bios/seabios/src/util.h +251 -0
- package/bios/seabios/src/version.c +5 -0
- package/bios/seabios/src/vgahooks.c +355 -0
- package/bios/seabios/src/x86.c +23 -0
- package/bios/seabios/src/x86.h +277 -0
- package/bios/seabios/vgasrc/Kconfig +211 -0
- package/bios/seabios/vgasrc/bochsdisplay.c +59 -0
- package/bios/seabios/vgasrc/bochsvga.c +447 -0
- package/bios/seabios/vgasrc/bochsvga.h +57 -0
- package/bios/seabios/vgasrc/cbvga.c +337 -0
- package/bios/seabios/vgasrc/clext.c +627 -0
- package/bios/seabios/vgasrc/geodevga.c +434 -0
- package/bios/seabios/vgasrc/geodevga.h +89 -0
- package/bios/seabios/vgasrc/ramfb.c +163 -0
- package/bios/seabios/vgasrc/stdvga.c +485 -0
- package/bios/seabios/vgasrc/stdvga.h +81 -0
- package/bios/seabios/vgasrc/stdvgaio.c +186 -0
- package/bios/seabios/vgasrc/stdvgamodes.c +534 -0
- package/bios/seabios/vgasrc/swcursor.c +96 -0
- package/bios/seabios/vgasrc/vbe.c +432 -0
- package/bios/seabios/vgasrc/vgabios.c +1131 -0
- package/bios/seabios/vgasrc/vgabios.h +88 -0
- package/bios/seabios/vgasrc/vgaentry.S +161 -0
- package/bios/seabios/vgasrc/vgafb.c +661 -0
- package/bios/seabios/vgasrc/vgafb.h +42 -0
- package/bios/seabios/vgasrc/vgafonts.c +785 -0
- package/bios/seabios/vgasrc/vgahw.h +152 -0
- package/bios/seabios/vgasrc/vgainit.c +202 -0
- package/bios/seabios/vgasrc/vgalayout.lds.S +23 -0
- package/bios/seabios/vgasrc/vgautil.h +103 -0
- package/bios/seabios/vgasrc/vgaversion.c +6 -0
- package/build/binaries.js +1 -1
- package/build/index-debug.cjs +1 -1
- package/build/index-debug.js +1 -1
- package/build/index.cjs +1 -1
- package/build/index.js +1 -1
- package/build/v86-debug.wasm +0 -0
- package/build/v86.wasm +0 -0
- package/package.json +1 -1
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
// Initialize the VGA console and possibly show a boot splash image.
|
|
2
|
+
//
|
|
3
|
+
// Copyright (C) 2009-2010 coresystems GmbH
|
|
4
|
+
// Copyright (C) 2010 Kevin O'Connor <kevin@koconnor.net>
|
|
5
|
+
//
|
|
6
|
+
// This file may be distributed under the terms of the GNU LGPLv3 license.
|
|
7
|
+
|
|
8
|
+
#include "bregs.h" // struct bregs
|
|
9
|
+
#include "config.h" // CONFIG_*
|
|
10
|
+
#include "farptr.h" // FLATPTR_TO_SEG
|
|
11
|
+
#include "malloc.h" // free
|
|
12
|
+
#include "output.h" // dprintf
|
|
13
|
+
#include "romfile.h" // romfile_loadfile
|
|
14
|
+
#include "stacks.h" // call16_int
|
|
15
|
+
#include "std/vbe.h" // struct vbe_info
|
|
16
|
+
#include "string.h" // memset
|
|
17
|
+
#include "util.h" // enable_bootsplash
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
/****************************************************************
|
|
21
|
+
* Helper functions
|
|
22
|
+
****************************************************************/
|
|
23
|
+
|
|
24
|
+
// Call int10 vga handler.
|
|
25
|
+
static void
|
|
26
|
+
call16_int10(struct bregs *br)
|
|
27
|
+
{
|
|
28
|
+
br->flags = F_IF;
|
|
29
|
+
start_preempt();
|
|
30
|
+
call16_int(0x10, br);
|
|
31
|
+
finish_preempt();
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
/****************************************************************
|
|
36
|
+
* VGA text / graphics console
|
|
37
|
+
****************************************************************/
|
|
38
|
+
|
|
39
|
+
void
|
|
40
|
+
enable_vga_console(void)
|
|
41
|
+
{
|
|
42
|
+
dprintf(1, "Turning on vga text mode console\n");
|
|
43
|
+
struct bregs br;
|
|
44
|
+
|
|
45
|
+
/* Enable VGA text mode */
|
|
46
|
+
memset(&br, 0, sizeof(br));
|
|
47
|
+
br.ax = 0x0003;
|
|
48
|
+
call16_int10(&br);
|
|
49
|
+
|
|
50
|
+
// Write to screen.
|
|
51
|
+
printf("SeaBIOS (version %s)\n", VERSION);
|
|
52
|
+
display_uuid();
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
static int
|
|
56
|
+
find_videomode(struct vbe_info *vesa_info, struct vbe_mode_info *mode_info
|
|
57
|
+
, int width, int height, int bpp_req)
|
|
58
|
+
{
|
|
59
|
+
dprintf(3, "Finding vesa mode with dimensions %d/%d\n", width, height);
|
|
60
|
+
u16 *videomodes = SEGOFF_TO_FLATPTR(vesa_info->video_mode);
|
|
61
|
+
for (;; videomodes++) {
|
|
62
|
+
u16 videomode = *videomodes;
|
|
63
|
+
if (videomode == 0xffff) {
|
|
64
|
+
dprintf(1, "Unable to find vesa video mode dimensions %d/%d\n"
|
|
65
|
+
, width, height);
|
|
66
|
+
return -1;
|
|
67
|
+
}
|
|
68
|
+
struct bregs br;
|
|
69
|
+
memset(&br, 0, sizeof(br));
|
|
70
|
+
br.ax = 0x4f01;
|
|
71
|
+
br.cx = videomode;
|
|
72
|
+
br.di = FLATPTR_TO_OFFSET(mode_info);
|
|
73
|
+
br.es = FLATPTR_TO_SEG(mode_info);
|
|
74
|
+
call16_int10(&br);
|
|
75
|
+
if (br.ax != 0x4f) {
|
|
76
|
+
dprintf(1, "get_mode failed.\n");
|
|
77
|
+
continue;
|
|
78
|
+
}
|
|
79
|
+
if (mode_info->xres != width
|
|
80
|
+
|| mode_info->yres != height)
|
|
81
|
+
continue;
|
|
82
|
+
u8 depth = mode_info->bits_per_pixel;
|
|
83
|
+
if (bpp_req == 0) {
|
|
84
|
+
if ((depth != 16 && depth != 24 && depth != 32)
|
|
85
|
+
|| mode_info->green_size == 5)
|
|
86
|
+
continue;
|
|
87
|
+
} else {
|
|
88
|
+
if (depth != bpp_req)
|
|
89
|
+
continue;
|
|
90
|
+
}
|
|
91
|
+
return videomode;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
static int BootsplashActive;
|
|
96
|
+
|
|
97
|
+
void
|
|
98
|
+
enable_bootsplash(void)
|
|
99
|
+
{
|
|
100
|
+
if (!CONFIG_BOOTSPLASH)
|
|
101
|
+
return;
|
|
102
|
+
/* splash picture can be bmp or jpeg file */
|
|
103
|
+
dprintf(3, "Checking for bootsplash\n");
|
|
104
|
+
u8 type = 0; /* 0 means jpg, 1 means bmp, default is 0=jpg */
|
|
105
|
+
int filesize;
|
|
106
|
+
u8 *filedata = romfile_loadfile("bootsplash.jpg", &filesize);
|
|
107
|
+
if (!filedata) {
|
|
108
|
+
filedata = romfile_loadfile("bootsplash.bmp", &filesize);
|
|
109
|
+
if (!filedata)
|
|
110
|
+
return;
|
|
111
|
+
type = 1;
|
|
112
|
+
}
|
|
113
|
+
dprintf(3, "start showing bootsplash\n");
|
|
114
|
+
|
|
115
|
+
u8 *picture = NULL; /* data buff used to be flushed to the video buf */
|
|
116
|
+
struct jpeg_decdata *jpeg = NULL;
|
|
117
|
+
struct bmp_decdata *bmp = NULL;
|
|
118
|
+
struct vbe_info *vesa_info = malloc_tmplow(sizeof(*vesa_info));
|
|
119
|
+
struct vbe_mode_info *mode_info = malloc_tmplow(sizeof(*mode_info));
|
|
120
|
+
if (!vesa_info || !mode_info) {
|
|
121
|
+
warn_noalloc();
|
|
122
|
+
goto done;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
/* Check whether we have a VESA 2.0 compliant BIOS */
|
|
126
|
+
memset(vesa_info, 0, sizeof(struct vbe_info));
|
|
127
|
+
vesa_info->signature = VBE2_SIGNATURE;
|
|
128
|
+
struct bregs br;
|
|
129
|
+
memset(&br, 0, sizeof(br));
|
|
130
|
+
br.ax = 0x4f00;
|
|
131
|
+
br.di = FLATPTR_TO_OFFSET(vesa_info);
|
|
132
|
+
br.es = FLATPTR_TO_SEG(vesa_info);
|
|
133
|
+
call16_int10(&br);
|
|
134
|
+
if (vesa_info->signature != VESA_SIGNATURE) {
|
|
135
|
+
dprintf(1,"No VBE2 found.\n");
|
|
136
|
+
goto done;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
/* Print some debugging information about our card. */
|
|
140
|
+
char *vendor = SEGOFF_TO_FLATPTR(vesa_info->oem_vendor_string);
|
|
141
|
+
char *product = SEGOFF_TO_FLATPTR(vesa_info->oem_product_string);
|
|
142
|
+
dprintf(3, "VESA %d.%d\nVENDOR: %s\nPRODUCT: %s\n",
|
|
143
|
+
vesa_info->version>>8, vesa_info->version&0xff,
|
|
144
|
+
vendor, product);
|
|
145
|
+
|
|
146
|
+
int ret, width, height;
|
|
147
|
+
int bpp_require = 0;
|
|
148
|
+
if (type == 0) {
|
|
149
|
+
jpeg = jpeg_alloc();
|
|
150
|
+
if (!jpeg) {
|
|
151
|
+
warn_noalloc();
|
|
152
|
+
goto done;
|
|
153
|
+
}
|
|
154
|
+
/* Parse jpeg and get image size. */
|
|
155
|
+
dprintf(5, "Decoding bootsplash.jpg\n");
|
|
156
|
+
ret = jpeg_decode(jpeg, filedata);
|
|
157
|
+
if (ret) {
|
|
158
|
+
dprintf(1, "jpeg_decode failed with return code %d...\n", ret);
|
|
159
|
+
goto done;
|
|
160
|
+
}
|
|
161
|
+
jpeg_get_size(jpeg, &width, &height);
|
|
162
|
+
} else {
|
|
163
|
+
bmp = bmp_alloc();
|
|
164
|
+
if (!bmp) {
|
|
165
|
+
warn_noalloc();
|
|
166
|
+
goto done;
|
|
167
|
+
}
|
|
168
|
+
/* Parse bmp and get image size. */
|
|
169
|
+
dprintf(5, "Decoding bootsplash.bmp\n");
|
|
170
|
+
ret = bmp_decode(bmp, filedata, filesize);
|
|
171
|
+
if (ret) {
|
|
172
|
+
dprintf(1, "bmp_decode failed with return code %d...\n", ret);
|
|
173
|
+
goto done;
|
|
174
|
+
}
|
|
175
|
+
bmp_get_size(bmp, &width, &height);
|
|
176
|
+
bpp_require = 24;
|
|
177
|
+
}
|
|
178
|
+
/* jpeg would use 16 or 24 bpp video mode, BMP use 24bpp mode only */
|
|
179
|
+
|
|
180
|
+
// Try to find a graphics mode with the corresponding dimensions.
|
|
181
|
+
int videomode = find_videomode(vesa_info, mode_info, width, height,
|
|
182
|
+
bpp_require);
|
|
183
|
+
if (videomode < 0) {
|
|
184
|
+
dprintf(1, "failed to find a videomode with %dx%d %dbpp (0=any).\n",
|
|
185
|
+
width, height, bpp_require);
|
|
186
|
+
goto done;
|
|
187
|
+
}
|
|
188
|
+
void *framebuffer = (void *)mode_info->phys_base;
|
|
189
|
+
int depth = mode_info->bits_per_pixel;
|
|
190
|
+
dprintf(3, "mode: %04x\n", videomode);
|
|
191
|
+
dprintf(3, "framebuffer: %p\n", framebuffer);
|
|
192
|
+
dprintf(3, "bytes per scanline: %d\n", mode_info->bytes_per_scanline);
|
|
193
|
+
dprintf(3, "bits per pixel: %d\n", depth);
|
|
194
|
+
|
|
195
|
+
// Allocate space for image and decompress it.
|
|
196
|
+
int imagesize = height * mode_info->bytes_per_scanline;
|
|
197
|
+
picture = malloc_tmphigh(imagesize);
|
|
198
|
+
if (!picture) {
|
|
199
|
+
warn_noalloc();
|
|
200
|
+
goto done;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
if (type == 0) {
|
|
204
|
+
dprintf(5, "Decompressing bootsplash.jpg\n");
|
|
205
|
+
ret = jpeg_show(jpeg, picture, width, height, depth,
|
|
206
|
+
mode_info->bytes_per_scanline);
|
|
207
|
+
if (ret) {
|
|
208
|
+
dprintf(1, "jpeg_show failed with return code %d...\n", ret);
|
|
209
|
+
goto done;
|
|
210
|
+
}
|
|
211
|
+
} else {
|
|
212
|
+
dprintf(5, "Decompressing bootsplash.bmp\n");
|
|
213
|
+
ret = bmp_show(bmp, picture, width, height, depth,
|
|
214
|
+
mode_info->bytes_per_scanline);
|
|
215
|
+
if (ret) {
|
|
216
|
+
dprintf(1, "bmp_show failed with return code %d...\n", ret);
|
|
217
|
+
goto done;
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
/* Switch to graphics mode */
|
|
222
|
+
dprintf(5, "Switching to graphics mode\n");
|
|
223
|
+
memset(&br, 0, sizeof(br));
|
|
224
|
+
br.ax = 0x4f02;
|
|
225
|
+
br.bx = videomode | VBE_MODE_LINEAR_FRAME_BUFFER;
|
|
226
|
+
call16_int10(&br);
|
|
227
|
+
if (br.ax != 0x4f) {
|
|
228
|
+
dprintf(1, "set_mode failed.\n");
|
|
229
|
+
goto done;
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
/* Show the picture */
|
|
233
|
+
dprintf(5, "Showing bootsplash picture\n");
|
|
234
|
+
iomemcpy(framebuffer, picture, imagesize);
|
|
235
|
+
dprintf(5, "Bootsplash copy complete\n");
|
|
236
|
+
BootsplashActive = 1;
|
|
237
|
+
|
|
238
|
+
done:
|
|
239
|
+
free(filedata);
|
|
240
|
+
free(picture);
|
|
241
|
+
free(vesa_info);
|
|
242
|
+
free(mode_info);
|
|
243
|
+
free(jpeg);
|
|
244
|
+
free(bmp);
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
void
|
|
249
|
+
disable_bootsplash(void)
|
|
250
|
+
{
|
|
251
|
+
if (!CONFIG_BOOTSPLASH || !BootsplashActive)
|
|
252
|
+
return;
|
|
253
|
+
BootsplashActive = 0;
|
|
254
|
+
enable_vga_console();
|
|
255
|
+
}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
// Structure layout of cpu registers that the bios uses.
|
|
2
|
+
//
|
|
3
|
+
// Copyright (C) 2008 Kevin O'Connor <kevin@koconnor.net>
|
|
4
|
+
//
|
|
5
|
+
// This file may be distributed under the terms of the GNU LGPLv3 license.
|
|
6
|
+
|
|
7
|
+
#ifndef __BREGS_H
|
|
8
|
+
#define __BREGS_H
|
|
9
|
+
|
|
10
|
+
#include "types.h" // u16
|
|
11
|
+
#include "x86.h" // F_CF
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
/****************************************************************
|
|
15
|
+
* Registers saved/restored in romlayout.S
|
|
16
|
+
****************************************************************/
|
|
17
|
+
|
|
18
|
+
#define UREG(ER, R, RH, RL) union { u32 ER; struct { u16 R; u16 R ## _hi; }; struct { u8 RL; u8 RH; u8 R ## _hilo; u8 R ## _hihi; }; }
|
|
19
|
+
|
|
20
|
+
// Layout of registers passed in to irq handlers. Note that this
|
|
21
|
+
// layout corresponds to code in romlayout.S - don't change it here
|
|
22
|
+
// without also updating the assembler code.
|
|
23
|
+
struct bregs {
|
|
24
|
+
u16 ds;
|
|
25
|
+
u16 es;
|
|
26
|
+
UREG(edi, di, di8u, di8l);
|
|
27
|
+
UREG(esi, si, si8u, si8l);
|
|
28
|
+
UREG(ebp, bp, bp8u, bp8l);
|
|
29
|
+
UREG(ebx, bx, bh, bl);
|
|
30
|
+
UREG(edx, dx, dh, dl);
|
|
31
|
+
UREG(ecx, cx, ch, cl);
|
|
32
|
+
UREG(eax, ax, ah, al);
|
|
33
|
+
struct segoff_s code;
|
|
34
|
+
u16 flags;
|
|
35
|
+
} PACKED;
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
/****************************************************************
|
|
39
|
+
* Helper functions
|
|
40
|
+
****************************************************************/
|
|
41
|
+
|
|
42
|
+
static inline void
|
|
43
|
+
set_cf(struct bregs *regs, int cond)
|
|
44
|
+
{
|
|
45
|
+
if (cond)
|
|
46
|
+
regs->flags |= F_CF;
|
|
47
|
+
else
|
|
48
|
+
regs->flags &= ~F_CF;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// Frequently used return codes
|
|
52
|
+
#define RET_EUNSUPPORTED 0x86
|
|
53
|
+
|
|
54
|
+
static inline void
|
|
55
|
+
set_success(struct bregs *regs)
|
|
56
|
+
{
|
|
57
|
+
set_cf(regs, 0);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
static inline void
|
|
61
|
+
set_code_success(struct bregs *regs)
|
|
62
|
+
{
|
|
63
|
+
regs->ah = 0;
|
|
64
|
+
set_cf(regs, 0);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
static inline void
|
|
68
|
+
set_invalid_silent(struct bregs *regs)
|
|
69
|
+
{
|
|
70
|
+
set_cf(regs, 1);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
static inline void
|
|
74
|
+
set_code_invalid_silent(struct bregs *regs, u8 code)
|
|
75
|
+
{
|
|
76
|
+
regs->ah = code;
|
|
77
|
+
set_cf(regs, 1);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
#endif // bregs.h
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
#ifndef __BYTEORDER_H
|
|
2
|
+
#define __BYTEORDER_H
|
|
3
|
+
|
|
4
|
+
#include "types.h" // u32
|
|
5
|
+
|
|
6
|
+
static inline u16 __swab16_constant(u16 val) {
|
|
7
|
+
return (val<<8) | (val>>8);
|
|
8
|
+
}
|
|
9
|
+
static inline u32 __swab32_constant(u32 val) {
|
|
10
|
+
return (val<<24) | ((val&0xff00)<<8) | ((val&0xff0000)>>8) | (val>>24);
|
|
11
|
+
}
|
|
12
|
+
static inline u64 __swab64_constant(u64 val) {
|
|
13
|
+
return ((u64)__swab32_constant(val) << 32) | __swab32_constant(val>>32);
|
|
14
|
+
}
|
|
15
|
+
static inline u32 __swab32(u32 val) {
|
|
16
|
+
asm("bswapl %0" : "+r"(val));
|
|
17
|
+
return val;
|
|
18
|
+
}
|
|
19
|
+
static inline u64 __swab64(u64 val) {
|
|
20
|
+
union u64_u32_u i, o;
|
|
21
|
+
i.val = val;
|
|
22
|
+
o.lo = __swab32(i.hi);
|
|
23
|
+
o.hi = __swab32(i.lo);
|
|
24
|
+
return o.val;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
#define swab16(x) __swab16_constant(x)
|
|
28
|
+
#define swab32(x) (__builtin_constant_p((u32)(x)) \
|
|
29
|
+
? __swab32_constant(x) : __swab32(x))
|
|
30
|
+
#define swab64(x) (__builtin_constant_p((u64)(x)) \
|
|
31
|
+
? __swab64_constant(x) : __swab64(x))
|
|
32
|
+
|
|
33
|
+
static inline u16 cpu_to_le16(u16 x) {
|
|
34
|
+
return x;
|
|
35
|
+
}
|
|
36
|
+
static inline u32 cpu_to_le32(u32 x) {
|
|
37
|
+
return x;
|
|
38
|
+
}
|
|
39
|
+
static inline u64 cpu_to_le64(u64 x) {
|
|
40
|
+
return x;
|
|
41
|
+
}
|
|
42
|
+
static inline u16 le16_to_cpu(u16 x) {
|
|
43
|
+
return x;
|
|
44
|
+
}
|
|
45
|
+
static inline u32 le32_to_cpu(u32 x) {
|
|
46
|
+
return x;
|
|
47
|
+
}
|
|
48
|
+
static inline u64 le64_to_cpu(u64 x) {
|
|
49
|
+
return x;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
static inline u16 cpu_to_be16(u16 x) {
|
|
53
|
+
return swab16(x);
|
|
54
|
+
}
|
|
55
|
+
static inline u32 cpu_to_be32(u32 x) {
|
|
56
|
+
return swab32(x);
|
|
57
|
+
}
|
|
58
|
+
static inline u64 cpu_to_be64(u64 x) {
|
|
59
|
+
return swab64(x);
|
|
60
|
+
}
|
|
61
|
+
static inline u16 be16_to_cpu(u16 x) {
|
|
62
|
+
return swab16(x);
|
|
63
|
+
}
|
|
64
|
+
static inline u32 be32_to_cpu(u32 x) {
|
|
65
|
+
return swab32(x);
|
|
66
|
+
}
|
|
67
|
+
static inline u64 be64_to_cpu(u64 x) {
|
|
68
|
+
return swab64(x);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
#endif // byteorder.h
|