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,337 @@
|
|
|
1
|
+
// 32bit code to Power On Self Test (POST) a machine.
|
|
2
|
+
//
|
|
3
|
+
// Copyright (C) 2008-2013 Kevin O'Connor <kevin@koconnor.net>
|
|
4
|
+
// Copyright (C) 2002 MandrakeSoft S.A.
|
|
5
|
+
//
|
|
6
|
+
// This file may be distributed under the terms of the GNU LGPLv3 license.
|
|
7
|
+
|
|
8
|
+
#include "biosvar.h" // SET_BDA
|
|
9
|
+
#include "block.h" // block_setup
|
|
10
|
+
#include "bregs.h" // struct bregs
|
|
11
|
+
#include "config.h" // CONFIG_*
|
|
12
|
+
#include "e820map.h" // e820_add
|
|
13
|
+
#include "fw/paravirt.h" // qemu_cfg_preinit
|
|
14
|
+
#include "fw/xen.h" // xen_preinit
|
|
15
|
+
#include "hw/pic.h" // pic_setup
|
|
16
|
+
#include "hw/ps2port.h" // ps2port_setup
|
|
17
|
+
#include "hw/rtc.h" // rtc_write
|
|
18
|
+
#include "hw/serialio.h" // serial_debug_preinit
|
|
19
|
+
#include "hw/usb.h" // usb_setup
|
|
20
|
+
#include "malloc.h" // malloc_init
|
|
21
|
+
#include "memmap.h" // SYMBOL
|
|
22
|
+
#include "output.h" // dprintf
|
|
23
|
+
#include "string.h" // memset
|
|
24
|
+
#include "util.h" // kbd_init
|
|
25
|
+
#include "tcgbios.h" // tpm_*
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
/****************************************************************
|
|
29
|
+
* BIOS initialization and hardware setup
|
|
30
|
+
****************************************************************/
|
|
31
|
+
|
|
32
|
+
static void
|
|
33
|
+
ivt_init(void)
|
|
34
|
+
{
|
|
35
|
+
dprintf(3, "init ivt\n");
|
|
36
|
+
|
|
37
|
+
// Initialize all vectors to the default handler.
|
|
38
|
+
int i;
|
|
39
|
+
for (i=0; i<256; i++)
|
|
40
|
+
SET_IVT(i, FUNC16(entry_iret_official));
|
|
41
|
+
|
|
42
|
+
// Initialize all hw vectors to a default hw handler.
|
|
43
|
+
for (i=BIOS_HWIRQ0_VECTOR; i<BIOS_HWIRQ0_VECTOR+8; i++)
|
|
44
|
+
SET_IVT(i, FUNC16(entry_hwpic1));
|
|
45
|
+
for (i=BIOS_HWIRQ8_VECTOR; i<BIOS_HWIRQ8_VECTOR+8; i++)
|
|
46
|
+
SET_IVT(i, FUNC16(entry_hwpic2));
|
|
47
|
+
|
|
48
|
+
// Initialize software handlers.
|
|
49
|
+
SET_IVT(0x02, FUNC16(entry_02));
|
|
50
|
+
SET_IVT(0x05, FUNC16(entry_05));
|
|
51
|
+
SET_IVT(0x10, FUNC16(entry_10));
|
|
52
|
+
SET_IVT(0x11, FUNC16(entry_11));
|
|
53
|
+
SET_IVT(0x12, FUNC16(entry_12));
|
|
54
|
+
SET_IVT(0x13, FUNC16(entry_13_official));
|
|
55
|
+
SET_IVT(0x14, FUNC16(entry_14));
|
|
56
|
+
SET_IVT(0x15, FUNC16(entry_15_official));
|
|
57
|
+
SET_IVT(0x16, FUNC16(entry_16));
|
|
58
|
+
SET_IVT(0x17, FUNC16(entry_17));
|
|
59
|
+
SET_IVT(0x18, FUNC16(entry_18));
|
|
60
|
+
SET_IVT(0x19, FUNC16(entry_19_official));
|
|
61
|
+
SET_IVT(0x1a, FUNC16(entry_1a_official));
|
|
62
|
+
SET_IVT(0x40, FUNC16(entry_40));
|
|
63
|
+
|
|
64
|
+
// INT 60h-66h reserved for user interrupt
|
|
65
|
+
for (i=0x60; i<=0x66; i++)
|
|
66
|
+
SET_IVT(i, SEGOFF(0, 0));
|
|
67
|
+
|
|
68
|
+
// set vector 0x79 to zero
|
|
69
|
+
// this is used by 'gardian angel' protection system
|
|
70
|
+
SET_IVT(0x79, SEGOFF(0, 0));
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
static void
|
|
74
|
+
bda_init(void)
|
|
75
|
+
{
|
|
76
|
+
dprintf(3, "init bda\n");
|
|
77
|
+
|
|
78
|
+
struct bios_data_area_s *bda = MAKE_FLATPTR(SEG_BDA, 0);
|
|
79
|
+
memset(bda, 0, sizeof(*bda));
|
|
80
|
+
|
|
81
|
+
int esize = EBDA_SIZE_START;
|
|
82
|
+
u16 ebda_seg = EBDA_SEGMENT_START;
|
|
83
|
+
if (!CONFIG_MALLOC_UPPERMEMORY)
|
|
84
|
+
ebda_seg = FLATPTR_TO_SEG(ALIGN_DOWN(SYMBOL(final_varlow_start), 1024)
|
|
85
|
+
- EBDA_SIZE_START*1024);
|
|
86
|
+
SET_BDA(ebda_seg, ebda_seg);
|
|
87
|
+
|
|
88
|
+
SET_BDA(mem_size_kb, ebda_seg / (1024/16));
|
|
89
|
+
|
|
90
|
+
// Init ebda
|
|
91
|
+
struct extended_bios_data_area_s *ebda = get_ebda_ptr();
|
|
92
|
+
memset(ebda, 0, sizeof(*ebda));
|
|
93
|
+
ebda->size = esize;
|
|
94
|
+
|
|
95
|
+
e820_add((u32)ebda, BUILD_LOWRAM_END-(u32)ebda, E820_RESERVED);
|
|
96
|
+
|
|
97
|
+
// Init extra stack
|
|
98
|
+
StackPos = &ExtraStack[BUILD_EXTRA_STACK_SIZE] - SYMBOL(zonelow_base);
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
void
|
|
102
|
+
interface_init(void)
|
|
103
|
+
{
|
|
104
|
+
// Running at new code address - do code relocation fixups
|
|
105
|
+
malloc_init();
|
|
106
|
+
|
|
107
|
+
// Setup romfile items.
|
|
108
|
+
qemu_cfg_init();
|
|
109
|
+
coreboot_cbfs_init();
|
|
110
|
+
multiboot_init();
|
|
111
|
+
|
|
112
|
+
// Setup ivt/bda/ebda
|
|
113
|
+
ivt_init();
|
|
114
|
+
bda_init();
|
|
115
|
+
|
|
116
|
+
// Other interfaces
|
|
117
|
+
boot_init();
|
|
118
|
+
bios32_init();
|
|
119
|
+
pmm_init();
|
|
120
|
+
pnp_init();
|
|
121
|
+
kbd_init();
|
|
122
|
+
mouse_init();
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
// Initialize hardware devices
|
|
126
|
+
void
|
|
127
|
+
device_hardware_setup(void)
|
|
128
|
+
{
|
|
129
|
+
usb_setup();
|
|
130
|
+
ps2port_setup();
|
|
131
|
+
block_setup();
|
|
132
|
+
lpt_setup();
|
|
133
|
+
serial_setup();
|
|
134
|
+
cbfs_payload_setup();
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
static void
|
|
138
|
+
platform_hardware_setup(void)
|
|
139
|
+
{
|
|
140
|
+
// Make sure legacy DMA isn't running.
|
|
141
|
+
dma_setup();
|
|
142
|
+
|
|
143
|
+
// Init base pc hardware.
|
|
144
|
+
pic_setup();
|
|
145
|
+
thread_setup();
|
|
146
|
+
mathcp_setup();
|
|
147
|
+
|
|
148
|
+
// Platform specific setup
|
|
149
|
+
qemu_platform_setup();
|
|
150
|
+
coreboot_platform_setup();
|
|
151
|
+
|
|
152
|
+
// Setup timers and periodic clock interrupt
|
|
153
|
+
timer_setup();
|
|
154
|
+
clock_setup();
|
|
155
|
+
|
|
156
|
+
// Initialize TPM
|
|
157
|
+
tpm_setup();
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
void
|
|
161
|
+
prepareboot(void)
|
|
162
|
+
{
|
|
163
|
+
// Change TPM phys. presence state befor leaving BIOS
|
|
164
|
+
tpm_prepboot();
|
|
165
|
+
|
|
166
|
+
// Run BCVs
|
|
167
|
+
bcv_prepboot();
|
|
168
|
+
|
|
169
|
+
// Finalize data structures before boot
|
|
170
|
+
cdrom_prepboot();
|
|
171
|
+
pmm_prepboot();
|
|
172
|
+
malloc_prepboot();
|
|
173
|
+
e820_prepboot();
|
|
174
|
+
|
|
175
|
+
HaveRunPost = 2;
|
|
176
|
+
|
|
177
|
+
// Setup bios checksum.
|
|
178
|
+
BiosChecksum -= checksum((u8*)BUILD_BIOS_ADDR, BUILD_BIOS_SIZE);
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
// Begin the boot process by invoking an int0x19 in 16bit mode.
|
|
182
|
+
void VISIBLE32FLAT
|
|
183
|
+
startBoot(void)
|
|
184
|
+
{
|
|
185
|
+
// Clear low-memory allocations (required by PMM spec).
|
|
186
|
+
memset((void*)BUILD_STACK_ADDR, 0, BUILD_EBDA_MINIMUM - BUILD_STACK_ADDR);
|
|
187
|
+
|
|
188
|
+
dprintf(3, "Jump to int19\n");
|
|
189
|
+
struct bregs br;
|
|
190
|
+
memset(&br, 0, sizeof(br));
|
|
191
|
+
br.flags = F_IF;
|
|
192
|
+
call16_int(0x19, &br);
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
// Main setup code.
|
|
196
|
+
static void
|
|
197
|
+
maininit(void)
|
|
198
|
+
{
|
|
199
|
+
// Initialize internal interfaces.
|
|
200
|
+
interface_init();
|
|
201
|
+
|
|
202
|
+
// Setup platform devices.
|
|
203
|
+
platform_hardware_setup();
|
|
204
|
+
|
|
205
|
+
// Start hardware initialization (if threads allowed during optionroms)
|
|
206
|
+
if (threads_during_optionroms())
|
|
207
|
+
device_hardware_setup();
|
|
208
|
+
|
|
209
|
+
// Run vga option rom
|
|
210
|
+
vgarom_setup();
|
|
211
|
+
sercon_setup();
|
|
212
|
+
enable_vga_console();
|
|
213
|
+
|
|
214
|
+
// Do hardware initialization (if running synchronously)
|
|
215
|
+
if (!threads_during_optionroms()) {
|
|
216
|
+
device_hardware_setup();
|
|
217
|
+
wait_threads();
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
// Run option roms
|
|
221
|
+
optionrom_setup();
|
|
222
|
+
|
|
223
|
+
// Allow user to modify overall boot order.
|
|
224
|
+
interactive_bootmenu();
|
|
225
|
+
wait_threads();
|
|
226
|
+
|
|
227
|
+
// Prepare for boot.
|
|
228
|
+
prepareboot();
|
|
229
|
+
|
|
230
|
+
// Write protect bios memory.
|
|
231
|
+
make_bios_readonly();
|
|
232
|
+
|
|
233
|
+
// Invoke int 19 to start boot process.
|
|
234
|
+
startBoot();
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
|
|
238
|
+
/****************************************************************
|
|
239
|
+
* POST entry and code relocation
|
|
240
|
+
****************************************************************/
|
|
241
|
+
|
|
242
|
+
// Update given relocs for the code at 'dest' with a given 'delta'
|
|
243
|
+
static void
|
|
244
|
+
updateRelocs(void *dest, u32 *rstart, u32 *rend, u32 delta)
|
|
245
|
+
{
|
|
246
|
+
u32 *reloc;
|
|
247
|
+
for (reloc = rstart; reloc < rend; reloc++)
|
|
248
|
+
*((u32*)(dest + *reloc)) += delta;
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
// Relocate init code and then call a function at its new address.
|
|
252
|
+
// The passed function should be in the "init" section and must not
|
|
253
|
+
// return.
|
|
254
|
+
void __noreturn
|
|
255
|
+
reloc_preinit(void *f, void *arg)
|
|
256
|
+
{
|
|
257
|
+
void (*func)(void *) __noreturn = f;
|
|
258
|
+
if (!CONFIG_RELOCATE_INIT)
|
|
259
|
+
func(arg);
|
|
260
|
+
|
|
261
|
+
// Allocate space for init code.
|
|
262
|
+
u32 initsize = SYMBOL(code32init_end) - SYMBOL(code32init_start);
|
|
263
|
+
u32 codealign = SYMBOL(_reloc_min_align);
|
|
264
|
+
void *codedest = memalign_tmp(codealign, initsize);
|
|
265
|
+
void *codesrc = VSYMBOL(code32init_start);
|
|
266
|
+
if (!codedest)
|
|
267
|
+
panic("No space for init relocation.\n");
|
|
268
|
+
|
|
269
|
+
// Copy code and update relocs (init absolute, init relative, and runtime)
|
|
270
|
+
dprintf(1, "Relocating init from %p to %p (size %d)\n"
|
|
271
|
+
, codesrc, codedest, initsize);
|
|
272
|
+
s32 delta = codedest - codesrc;
|
|
273
|
+
memcpy(codedest, codesrc, initsize);
|
|
274
|
+
updateRelocs(codedest, VSYMBOL(_reloc_abs_start), VSYMBOL(_reloc_abs_end)
|
|
275
|
+
, delta);
|
|
276
|
+
updateRelocs(codedest, VSYMBOL(_reloc_rel_start), VSYMBOL(_reloc_rel_end)
|
|
277
|
+
, -delta);
|
|
278
|
+
updateRelocs(VSYMBOL(code32flat_start), VSYMBOL(_reloc_init_start)
|
|
279
|
+
, VSYMBOL(_reloc_init_end), delta);
|
|
280
|
+
if (f >= codesrc && f < VSYMBOL(code32init_end))
|
|
281
|
+
func = f + delta;
|
|
282
|
+
|
|
283
|
+
// Call function in relocated code.
|
|
284
|
+
barrier();
|
|
285
|
+
func(arg);
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
// Runs after all code is present and prior to any modifications
|
|
289
|
+
void
|
|
290
|
+
code_mutable_preinit(void)
|
|
291
|
+
{
|
|
292
|
+
if (HaveRunPost)
|
|
293
|
+
// Already run
|
|
294
|
+
return;
|
|
295
|
+
// Setup reset-vector entry point (controls legacy reboots).
|
|
296
|
+
rtc_write(CMOS_RESET_CODE, 0);
|
|
297
|
+
barrier();
|
|
298
|
+
HaveRunPost = 1;
|
|
299
|
+
barrier();
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
// Setup for code relocation and then relocate.
|
|
303
|
+
void VISIBLE32INIT
|
|
304
|
+
dopost(void)
|
|
305
|
+
{
|
|
306
|
+
code_mutable_preinit();
|
|
307
|
+
|
|
308
|
+
// Detect ram and setup internal malloc.
|
|
309
|
+
qemu_preinit();
|
|
310
|
+
coreboot_preinit();
|
|
311
|
+
malloc_preinit();
|
|
312
|
+
|
|
313
|
+
// Relocate initialization code and call maininit().
|
|
314
|
+
reloc_preinit(maininit, NULL);
|
|
315
|
+
}
|
|
316
|
+
|
|
317
|
+
// Entry point for Power On Self Test (POST) - the BIOS initilization
|
|
318
|
+
// phase. This function makes the memory at 0xc0000-0xfffff
|
|
319
|
+
// read/writable and then calls dopost().
|
|
320
|
+
void VISIBLE32FLAT
|
|
321
|
+
handle_post(void)
|
|
322
|
+
{
|
|
323
|
+
if (!CONFIG_QEMU && !CONFIG_COREBOOT)
|
|
324
|
+
return;
|
|
325
|
+
|
|
326
|
+
serial_debug_preinit();
|
|
327
|
+
debug_banner();
|
|
328
|
+
|
|
329
|
+
// Check if we are running under Xen.
|
|
330
|
+
xen_preinit();
|
|
331
|
+
|
|
332
|
+
// Allow writes to modify bios area (0xf0000)
|
|
333
|
+
make_bios_writable();
|
|
334
|
+
|
|
335
|
+
// Now that memory is read/writable - start post process.
|
|
336
|
+
dopost();
|
|
337
|
+
}
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
// Code for handling calls to "post" that are resume related.
|
|
2
|
+
//
|
|
3
|
+
// Copyright (C) 2008,2009 Kevin O'Connor <kevin@koconnor.net>
|
|
4
|
+
//
|
|
5
|
+
// This file may be distributed under the terms of the GNU LGPLv3 license.
|
|
6
|
+
|
|
7
|
+
#include "bregs.h" // struct bregs
|
|
8
|
+
#include "config.h" // CONFIG_*
|
|
9
|
+
#include "farptr.h" // FLATPTR_TO_SEGOFF
|
|
10
|
+
#include "hw/pci.h" // pci_reboot
|
|
11
|
+
#include "hw/pic.h" // pic_eoi2
|
|
12
|
+
#include "hw/ps2port.h" // i8042_reboot
|
|
13
|
+
#include "hw/rtc.h" // rtc_read
|
|
14
|
+
#include "output.h" // dprintf
|
|
15
|
+
#include "stacks.h" // farcall16big
|
|
16
|
+
#include "std/bda.h" // struct bios_data_area_s
|
|
17
|
+
#include "string.h" // memset
|
|
18
|
+
#include "util.h" // dma_setup
|
|
19
|
+
#include "tcgbios.h" // tpm_s3_resume
|
|
20
|
+
#include "fw/romfile_loader.h" // romfile_fw_cfg_resume
|
|
21
|
+
|
|
22
|
+
// Handler for post calls that look like a resume.
|
|
23
|
+
void VISIBLE16
|
|
24
|
+
handle_resume(void)
|
|
25
|
+
{
|
|
26
|
+
ASSERT16();
|
|
27
|
+
int status = rtc_read(CMOS_RESET_CODE);
|
|
28
|
+
rtc_write(CMOS_RESET_CODE, 0);
|
|
29
|
+
dprintf(1, "In resume (status=%d)\n", status);
|
|
30
|
+
|
|
31
|
+
dma_setup();
|
|
32
|
+
|
|
33
|
+
switch (status) {
|
|
34
|
+
case 0x01 ... 0x04:
|
|
35
|
+
case 0x06 ... 0x09:
|
|
36
|
+
panic("Unimplemented shutdown status: %02x\n", status);
|
|
37
|
+
|
|
38
|
+
case 0x05:
|
|
39
|
+
// flush keyboard (issue EOI) and jump via 40h:0067h
|
|
40
|
+
pic_eoi2();
|
|
41
|
+
// NO BREAK
|
|
42
|
+
case 0x0a:
|
|
43
|
+
#define BDA_JUMP (((struct bios_data_area_s *)0)->jump)
|
|
44
|
+
// resume execution by jump via 40h:0067h
|
|
45
|
+
asm volatile(
|
|
46
|
+
"movw %w1, %%ds\n"
|
|
47
|
+
"ljmpw *%0\n"
|
|
48
|
+
: : "m"(BDA_JUMP), "r"(SEG_BDA)
|
|
49
|
+
);
|
|
50
|
+
break;
|
|
51
|
+
|
|
52
|
+
case 0x0b:
|
|
53
|
+
// resume execution via IRET via 40h:0067h
|
|
54
|
+
asm volatile(
|
|
55
|
+
"movw %w1, %%ds\n"
|
|
56
|
+
"lssw %0, %%sp\n"
|
|
57
|
+
"iretw\n"
|
|
58
|
+
: : "m"(BDA_JUMP), "r"(SEG_BDA)
|
|
59
|
+
);
|
|
60
|
+
break;
|
|
61
|
+
|
|
62
|
+
case 0x0c:
|
|
63
|
+
// resume execution via RETF via 40h:0067h
|
|
64
|
+
asm volatile(
|
|
65
|
+
"movw %w1, %%ds\n"
|
|
66
|
+
"lssw %0, %%sp\n"
|
|
67
|
+
"lretw\n"
|
|
68
|
+
: : "m"(BDA_JUMP), "r"(SEG_BDA)
|
|
69
|
+
);
|
|
70
|
+
break;
|
|
71
|
+
|
|
72
|
+
default:
|
|
73
|
+
break;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// Not a 16bit resume - do remaining checks in 32bit mode
|
|
77
|
+
asm volatile(
|
|
78
|
+
"movw %w1, %%ss\n"
|
|
79
|
+
"movl %0, %%esp\n"
|
|
80
|
+
"movl $_cfunc32flat_handle_resume32, %%edx\n"
|
|
81
|
+
"jmp transition32\n"
|
|
82
|
+
: : "i"(BUILD_S3RESUME_STACK_ADDR), "r"(0), "a"(status)
|
|
83
|
+
);
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
// Handle an S3 resume event
|
|
87
|
+
static void
|
|
88
|
+
s3_resume(void)
|
|
89
|
+
{
|
|
90
|
+
if (!CONFIG_S3_RESUME)
|
|
91
|
+
return;
|
|
92
|
+
|
|
93
|
+
u32 s3_resume_vector = find_resume_vector();
|
|
94
|
+
if (!s3_resume_vector) {
|
|
95
|
+
dprintf(1, "No resume vector set!\n");
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
pic_setup();
|
|
100
|
+
smm_setup();
|
|
101
|
+
smp_resume();
|
|
102
|
+
|
|
103
|
+
pci_resume();
|
|
104
|
+
|
|
105
|
+
/* resume TPM before we may measure option roms */
|
|
106
|
+
tpm_s3_resume();
|
|
107
|
+
s3_resume_vga();
|
|
108
|
+
|
|
109
|
+
/* Replay any fw_cfg entries that go back to the host */
|
|
110
|
+
romfile_fw_cfg_resume();
|
|
111
|
+
|
|
112
|
+
make_bios_readonly();
|
|
113
|
+
|
|
114
|
+
// Invoke the resume vector.
|
|
115
|
+
struct bregs br;
|
|
116
|
+
memset(&br, 0, sizeof(br));
|
|
117
|
+
dprintf(1, "Jump to resume vector (%x)\n", s3_resume_vector);
|
|
118
|
+
br.code = FLATPTR_TO_SEGOFF((void*)s3_resume_vector);
|
|
119
|
+
farcall16big(&br);
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
// Attempt to invoke a hard-reboot.
|
|
123
|
+
static void
|
|
124
|
+
tryReboot(void)
|
|
125
|
+
{
|
|
126
|
+
dprintf(1, "Attempting a hard reboot\n");
|
|
127
|
+
|
|
128
|
+
// Use a QEMU specific reboot on QEMU
|
|
129
|
+
qemu_reboot();
|
|
130
|
+
|
|
131
|
+
// Reboot using ACPI RESET_REG
|
|
132
|
+
acpi_reboot();
|
|
133
|
+
|
|
134
|
+
// Try keyboard controller reboot.
|
|
135
|
+
i8042_reboot();
|
|
136
|
+
|
|
137
|
+
// Try PCI 0xcf9 reboot
|
|
138
|
+
pci_reboot();
|
|
139
|
+
|
|
140
|
+
// Try triple fault
|
|
141
|
+
asm volatile("int3");
|
|
142
|
+
|
|
143
|
+
panic("Could not reboot");
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
void VISIBLE32FLAT
|
|
147
|
+
handle_resume32(int status)
|
|
148
|
+
{
|
|
149
|
+
ASSERT32FLAT();
|
|
150
|
+
dprintf(1, "In 32bit resume\n");
|
|
151
|
+
|
|
152
|
+
if (status == 0xfe)
|
|
153
|
+
s3_resume();
|
|
154
|
+
|
|
155
|
+
// Must be a soft reboot - invoke a hard reboot.
|
|
156
|
+
tryReboot();
|
|
157
|
+
}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
// Access to pseudo "file" interface for configuration information.
|
|
2
|
+
//
|
|
3
|
+
// Copyright (C) 2012 Kevin O'Connor <kevin@koconnor.net>
|
|
4
|
+
//
|
|
5
|
+
// This file may be distributed under the terms of the GNU LGPLv3 license.
|
|
6
|
+
|
|
7
|
+
#include "config.h" // CONFIG_*
|
|
8
|
+
#include "malloc.h" // free
|
|
9
|
+
#include "output.h" // dprintf
|
|
10
|
+
#include "romfile.h" // struct romfile_s
|
|
11
|
+
#include "string.h" // memcmp
|
|
12
|
+
|
|
13
|
+
static struct romfile_s *RomfileRoot VARVERIFY32INIT;
|
|
14
|
+
|
|
15
|
+
void
|
|
16
|
+
romfile_add(struct romfile_s *file)
|
|
17
|
+
{
|
|
18
|
+
dprintf(3, "Add romfile: %s (size=%d)\n", file->name, file->size);
|
|
19
|
+
file->next = RomfileRoot;
|
|
20
|
+
RomfileRoot = file;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// Search for the specified file.
|
|
24
|
+
static struct romfile_s *
|
|
25
|
+
__romfile_findprefix(const char *prefix, int prefixlen, struct romfile_s *prev)
|
|
26
|
+
{
|
|
27
|
+
struct romfile_s *cur = RomfileRoot;
|
|
28
|
+
if (prev)
|
|
29
|
+
cur = prev->next;
|
|
30
|
+
while (cur) {
|
|
31
|
+
if (memcmp(prefix, cur->name, prefixlen) == 0)
|
|
32
|
+
return cur;
|
|
33
|
+
cur = cur->next;
|
|
34
|
+
}
|
|
35
|
+
return NULL;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
struct romfile_s *
|
|
39
|
+
romfile_findprefix(const char *prefix, struct romfile_s *prev)
|
|
40
|
+
{
|
|
41
|
+
return __romfile_findprefix(prefix, strlen(prefix), prev);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
struct romfile_s *
|
|
45
|
+
romfile_find(const char *name)
|
|
46
|
+
{
|
|
47
|
+
return __romfile_findprefix(name, strlen(name) + 1, NULL);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// Helper function to find, malloc_tmphigh, and copy a romfile. This
|
|
51
|
+
// function adds a trailing zero to the malloc'd copy.
|
|
52
|
+
void *
|
|
53
|
+
romfile_loadfile(const char *name, int *psize)
|
|
54
|
+
{
|
|
55
|
+
struct romfile_s *file = romfile_find(name);
|
|
56
|
+
if (!file)
|
|
57
|
+
return NULL;
|
|
58
|
+
|
|
59
|
+
int filesize = file->size;
|
|
60
|
+
if (!filesize)
|
|
61
|
+
return NULL;
|
|
62
|
+
|
|
63
|
+
char *data = malloc_tmphigh(filesize+1);
|
|
64
|
+
if (!data) {
|
|
65
|
+
warn_noalloc();
|
|
66
|
+
return NULL;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
dprintf(5, "Copying romfile '%s' (len %d)\n", name, filesize);
|
|
70
|
+
int ret = file->copy(file, data, filesize);
|
|
71
|
+
if (ret < 0) {
|
|
72
|
+
free(data);
|
|
73
|
+
return NULL;
|
|
74
|
+
}
|
|
75
|
+
if (psize)
|
|
76
|
+
*psize = filesize;
|
|
77
|
+
data[filesize] = '\0';
|
|
78
|
+
return data;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
// Attempt to load an integer from the given file - return 'defval'
|
|
82
|
+
// if unsuccessful.
|
|
83
|
+
u64
|
|
84
|
+
romfile_loadint(const char *name, u64 defval)
|
|
85
|
+
{
|
|
86
|
+
struct romfile_s *file = romfile_find(name);
|
|
87
|
+
if (!file)
|
|
88
|
+
return defval;
|
|
89
|
+
|
|
90
|
+
int filesize = file->size;
|
|
91
|
+
if (!filesize || filesize > sizeof(u64) || (filesize & (filesize-1)))
|
|
92
|
+
// Doesn't look like a valid integer.
|
|
93
|
+
return defval;
|
|
94
|
+
|
|
95
|
+
u64 val = 0;
|
|
96
|
+
int ret = file->copy(file, &val, sizeof(val));
|
|
97
|
+
if (ret < 0)
|
|
98
|
+
return defval;
|
|
99
|
+
return val;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
struct const_romfile_s {
|
|
103
|
+
struct romfile_s file;
|
|
104
|
+
void *data;
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
static int
|
|
108
|
+
const_read_file(struct romfile_s *file, void *dst, u32 maxlen)
|
|
109
|
+
{
|
|
110
|
+
if (file->size > maxlen)
|
|
111
|
+
return -1;
|
|
112
|
+
struct const_romfile_s *cfile;
|
|
113
|
+
cfile = container_of(file, struct const_romfile_s, file);
|
|
114
|
+
if (maxlen > file->size)
|
|
115
|
+
maxlen = file->size;
|
|
116
|
+
memcpy(dst, cfile->data, maxlen);
|
|
117
|
+
return file->size;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
static void
|
|
121
|
+
const_romfile_add(char *name, void *data, int size)
|
|
122
|
+
{
|
|
123
|
+
struct const_romfile_s *cfile = malloc_tmp(sizeof(*cfile));
|
|
124
|
+
if (!cfile) {
|
|
125
|
+
warn_noalloc();
|
|
126
|
+
return;
|
|
127
|
+
}
|
|
128
|
+
memset(cfile, 0, sizeof(*cfile));
|
|
129
|
+
strtcpy(cfile->file.name, name, sizeof(cfile->file.name));
|
|
130
|
+
cfile->file.size = size;
|
|
131
|
+
cfile->file.copy = const_read_file;
|
|
132
|
+
cfile->data = data;
|
|
133
|
+
romfile_add(&cfile->file);
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
void
|
|
137
|
+
const_romfile_add_int(char *name, u32 value)
|
|
138
|
+
{
|
|
139
|
+
u32 *data = malloc_tmp(sizeof(*data));
|
|
140
|
+
if (!data) {
|
|
141
|
+
warn_noalloc();
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
*data = value;
|
|
145
|
+
const_romfile_add(name, data, sizeof(*data));
|
|
146
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
#ifndef __ROMFILE_H
|
|
2
|
+
#define __ROMFILE_H
|
|
3
|
+
|
|
4
|
+
#include "types.h" // u32
|
|
5
|
+
|
|
6
|
+
// romfile.c
|
|
7
|
+
struct romfile_s {
|
|
8
|
+
struct romfile_s *next;
|
|
9
|
+
char name[128];
|
|
10
|
+
u32 size;
|
|
11
|
+
int (*copy)(struct romfile_s *file, void *dest, u32 maxlen);
|
|
12
|
+
};
|
|
13
|
+
void romfile_add(struct romfile_s *file);
|
|
14
|
+
struct romfile_s *romfile_findprefix(const char *prefix, struct romfile_s *prev);
|
|
15
|
+
struct romfile_s *romfile_find(const char *name);
|
|
16
|
+
void *romfile_loadfile(const char *name, int *psize);
|
|
17
|
+
u64 romfile_loadint(const char *name, u64 defval);
|
|
18
|
+
|
|
19
|
+
void const_romfile_add_int(char *name, u32 value);
|
|
20
|
+
|
|
21
|
+
#endif // romfile.h
|