v86 0.4.0 → 0.5.10
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 +56 -111
- package/build/libv86-debug.js +12677 -0
- package/build/libv86-debug.mjs +732 -0
- package/build/libv86.js +710 -0
- package/build/libv86.mjs +636 -0
- package/build/v86-debug.wasm +0 -0
- package/build/v86-fallback.wasm +0 -0
- package/build/v86.wasm +0 -0
- package/package.json +12 -35
- package/bios/.gitignore +0 -1
- package/bios/COPYING.LESSER +0 -165
- package/bios/bochs-bios.bin +0 -0
- package/bios/bochs-vgabios.bin +0 -0
- package/bios/fetch-and-build-seabios.sh +0 -13
- package/bios/seabios/.config +0 -113
- package/bios/seabios/.config.old +0 -114
- package/bios/seabios/.gitignore +0 -4
- package/bios/seabios/COPYING +0 -674
- package/bios/seabios/COPYING.LESSER +0 -165
- package/bios/seabios/Makefile +0 -286
- package/bios/seabios/README +0 -17
- package/bios/seabios/docs/Build_overview.md +0 -104
- package/bios/seabios/docs/Contributing.md +0 -20
- package/bios/seabios/docs/Debugging.md +0 -111
- package/bios/seabios/docs/Developer_Documentation.md +0 -25
- package/bios/seabios/docs/Developer_links.md +0 -86
- package/bios/seabios/docs/Download.md +0 -27
- package/bios/seabios/docs/Execution_and_code_flow.md +0 -178
- package/bios/seabios/docs/Linking_overview.md +0 -160
- package/bios/seabios/docs/Mailinglist.md +0 -8
- package/bios/seabios/docs/Memory_Model.md +0 -253
- package/bios/seabios/docs/README +0 -5
- package/bios/seabios/docs/Releases.md +0 -482
- package/bios/seabios/docs/Runtime_config.md +0 -193
- package/bios/seabios/docs/SeaBIOS.md +0 -17
- package/bios/seabios/docs/SeaVGABIOS.md +0 -39
- package/bios/seabios/out/autoconf.h +0 -117
- 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 +0 -69
- package/bios/seabios/out/include/config/auto.conf.cmd +0 -9
- 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 +0 -4
- 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 +0 -289
- package/bios/seabios/out/scripts/kconfig/zconf.lex.c +0 -2420
- package/bios/seabios/out/scripts/kconfig/zconf.tab.c +0 -2538
- package/bios/seabios/out/scripts/kconfig/zconf.tab.o +0 -0
- package/bios/seabios/scripts/acpi_extract.py +0 -366
- package/bios/seabios/scripts/acpi_extract_preprocess.py +0 -41
- package/bios/seabios/scripts/buildrom.py +0 -56
- package/bios/seabios/scripts/buildversion.py +0 -134
- package/bios/seabios/scripts/checkrom.py +0 -95
- package/bios/seabios/scripts/checkstack.py +0 -226
- package/bios/seabios/scripts/checksum.py +0 -16
- package/bios/seabios/scripts/encodeint.py +0 -21
- package/bios/seabios/scripts/gen-offsets.sh +0 -17
- package/bios/seabios/scripts/kconfig/.gitignore +0 -22
- package/bios/seabios/scripts/kconfig/Makefile +0 -331
- package/bios/seabios/scripts/kconfig/POTFILES.in +0 -12
- package/bios/seabios/scripts/kconfig/check.sh +0 -13
- package/bios/seabios/scripts/kconfig/conf.c +0 -718
- package/bios/seabios/scripts/kconfig/confdata.c +0 -1250
- package/bios/seabios/scripts/kconfig/expr.c +0 -1168
- package/bios/seabios/scripts/kconfig/expr.h +0 -241
- package/bios/seabios/scripts/kconfig/gconf.c +0 -1542
- package/bios/seabios/scripts/kconfig/gconf.glade +0 -661
- package/bios/seabios/scripts/kconfig/images.c +0 -326
- package/bios/seabios/scripts/kconfig/kxgettext.c +0 -235
- package/bios/seabios/scripts/kconfig/lex.zconf.c +0 -2430
- package/bios/seabios/scripts/kconfig/list.h +0 -131
- package/bios/seabios/scripts/kconfig/lkc.h +0 -200
- package/bios/seabios/scripts/kconfig/lkc_proto.h +0 -57
- package/bios/seabios/scripts/kconfig/lxdialog/.gitignore +0 -4
- package/bios/seabios/scripts/kconfig/lxdialog/BIG.FAT.WARNING +0 -4
- package/bios/seabios/scripts/kconfig/lxdialog/check-lxdialog.sh +0 -87
- package/bios/seabios/scripts/kconfig/lxdialog/checklist.c +0 -332
- package/bios/seabios/scripts/kconfig/lxdialog/dialog.h +0 -257
- package/bios/seabios/scripts/kconfig/lxdialog/inputbox.c +0 -301
- package/bios/seabios/scripts/kconfig/lxdialog/menubox.c +0 -437
- package/bios/seabios/scripts/kconfig/lxdialog/textbox.c +0 -408
- package/bios/seabios/scripts/kconfig/lxdialog/util.c +0 -713
- package/bios/seabios/scripts/kconfig/lxdialog/yesno.c +0 -114
- package/bios/seabios/scripts/kconfig/mconf.c +0 -1036
- package/bios/seabios/scripts/kconfig/menu.c +0 -697
- package/bios/seabios/scripts/kconfig/merge_config.sh +0 -150
- package/bios/seabios/scripts/kconfig/nconf.c +0 -1556
- package/bios/seabios/scripts/kconfig/nconf.gui.c +0 -656
- package/bios/seabios/scripts/kconfig/nconf.h +0 -96
- package/bios/seabios/scripts/kconfig/qconf.cc +0 -1795
- package/bios/seabios/scripts/kconfig/qconf.h +0 -338
- package/bios/seabios/scripts/kconfig/streamline_config.pl +0 -647
- package/bios/seabios/scripts/kconfig/symbol.c +0 -1373
- package/bios/seabios/scripts/kconfig/util.c +0 -157
- package/bios/seabios/scripts/kconfig/zconf.gperf +0 -48
- package/bios/seabios/scripts/kconfig/zconf.hash.c_shipped +0 -289
- package/bios/seabios/scripts/kconfig/zconf.l +0 -363
- package/bios/seabios/scripts/kconfig/zconf.lex.c_shipped +0 -2420
- package/bios/seabios/scripts/kconfig/zconf.tab.c_shipped +0 -2538
- package/bios/seabios/scripts/kconfig/zconf.y +0 -733
- package/bios/seabios/scripts/layoutrom.py +0 -705
- package/bios/seabios/scripts/python23compat.py +0 -14
- package/bios/seabios/scripts/readserial.py +0 -190
- package/bios/seabios/scripts/tarball.sh +0 -36
- package/bios/seabios/scripts/test-build.sh +0 -90
- package/bios/seabios/scripts/transdump.py +0 -53
- package/bios/seabios/scripts/vgafixup.py +0 -96
- package/bios/seabios/src/Kconfig +0 -579
- package/bios/seabios/src/apm.c +0 -215
- package/bios/seabios/src/asm-offsets.c +0 -23
- package/bios/seabios/src/biosvar.h +0 -130
- package/bios/seabios/src/block.c +0 -623
- package/bios/seabios/src/block.h +0 -121
- package/bios/seabios/src/bmp.c +0 -117
- package/bios/seabios/src/boot.c +0 -793
- package/bios/seabios/src/bootsplash.c +0 -255
- package/bios/seabios/src/bregs.h +0 -80
- package/bios/seabios/src/byteorder.h +0 -71
- package/bios/seabios/src/cdrom.c +0 -322
- package/bios/seabios/src/clock.c +0 -506
- package/bios/seabios/src/code16gcc.s +0 -1
- package/bios/seabios/src/config.h +0 -108
- package/bios/seabios/src/cp437.c +0 -275
- package/bios/seabios/src/cp437.h +0 -1
- package/bios/seabios/src/disk.c +0 -779
- package/bios/seabios/src/e820map.c +0 -152
- package/bios/seabios/src/e820map.h +0 -26
- package/bios/seabios/src/entryfuncs.S +0 -165
- package/bios/seabios/src/farptr.h +0 -208
- package/bios/seabios/src/font.c +0 -139
- package/bios/seabios/src/fw/acpi-dsdt-cpu-hotplug.dsl +0 -78
- package/bios/seabios/src/fw/acpi-dsdt-dbug.dsl +0 -26
- package/bios/seabios/src/fw/acpi-dsdt-hpet.dsl +0 -36
- package/bios/seabios/src/fw/acpi-dsdt-isa.dsl +0 -102
- package/bios/seabios/src/fw/acpi-dsdt-pci-crs.dsl +0 -90
- package/bios/seabios/src/fw/acpi-dsdt.dsl +0 -342
- package/bios/seabios/src/fw/acpi-dsdt.hex +0 -554
- package/bios/seabios/src/fw/acpi.c +0 -685
- package/bios/seabios/src/fw/biostables.c +0 -491
- package/bios/seabios/src/fw/coreboot.c +0 -569
- package/bios/seabios/src/fw/csm.c +0 -347
- package/bios/seabios/src/fw/dev-pci.h +0 -52
- package/bios/seabios/src/fw/dev-piix.h +0 -29
- package/bios/seabios/src/fw/dev-q35.h +0 -52
- package/bios/seabios/src/fw/lzmadecode.c +0 -398
- package/bios/seabios/src/fw/lzmadecode.h +0 -67
- package/bios/seabios/src/fw/mptable.c +0 -197
- package/bios/seabios/src/fw/mtrr.c +0 -105
- package/bios/seabios/src/fw/multiboot.c +0 -111
- package/bios/seabios/src/fw/paravirt.c +0 -624
- package/bios/seabios/src/fw/paravirt.h +0 -63
- package/bios/seabios/src/fw/pciinit.c +0 -1187
- package/bios/seabios/src/fw/pirtable.c +0 -103
- package/bios/seabios/src/fw/q35-acpi-dsdt.dsl +0 -450
- package/bios/seabios/src/fw/romfile_loader.c +0 -259
- package/bios/seabios/src/fw/romfile_loader.h +0 -91
- package/bios/seabios/src/fw/shadow.c +0 -208
- package/bios/seabios/src/fw/smbios.c +0 -585
- package/bios/seabios/src/fw/smm.c +0 -269
- package/bios/seabios/src/fw/smp.c +0 -194
- package/bios/seabios/src/fw/ssdt-misc.dsl +0 -104
- package/bios/seabios/src/fw/ssdt-misc.hex +0 -88
- package/bios/seabios/src/fw/ssdt-pcihp.dsl +0 -36
- package/bios/seabios/src/fw/ssdt-pcihp.hex +0 -38
- package/bios/seabios/src/fw/ssdt-proc.dsl +0 -48
- package/bios/seabios/src/fw/ssdt-proc.hex +0 -35
- package/bios/seabios/src/fw/xen.c +0 -149
- package/bios/seabios/src/fw/xen.h +0 -125
- package/bios/seabios/src/gen-defs.h +0 -19
- package/bios/seabios/src/hw/ahci.c +0 -697
- package/bios/seabios/src/hw/ahci.h +0 -201
- package/bios/seabios/src/hw/ata.c +0 -1046
- package/bios/seabios/src/hw/ata.h +0 -163
- package/bios/seabios/src/hw/blockcmd.c +0 -372
- package/bios/seabios/src/hw/blockcmd.h +0 -114
- package/bios/seabios/src/hw/dma.c +0 -67
- package/bios/seabios/src/hw/esp-scsi.c +0 -241
- package/bios/seabios/src/hw/esp-scsi.h +0 -8
- package/bios/seabios/src/hw/floppy.c +0 -741
- package/bios/seabios/src/hw/lsi-scsi.c +0 -221
- package/bios/seabios/src/hw/lsi-scsi.h +0 -8
- package/bios/seabios/src/hw/megasas.c +0 -405
- package/bios/seabios/src/hw/megasas.h +0 -8
- package/bios/seabios/src/hw/mpt-scsi.c +0 -319
- package/bios/seabios/src/hw/mpt-scsi.h +0 -8
- package/bios/seabios/src/hw/nvme-int.h +0 -199
- package/bios/seabios/src/hw/nvme.c +0 -708
- package/bios/seabios/src/hw/nvme.h +0 -17
- package/bios/seabios/src/hw/pci.c +0 -133
- package/bios/seabios/src/hw/pci.h +0 -47
- package/bios/seabios/src/hw/pci_ids.h +0 -2632
- package/bios/seabios/src/hw/pci_regs.h +0 -556
- package/bios/seabios/src/hw/pcidevice.c +0 -192
- package/bios/seabios/src/hw/pcidevice.h +0 -76
- package/bios/seabios/src/hw/pic.c +0 -115
- package/bios/seabios/src/hw/pic.h +0 -60
- package/bios/seabios/src/hw/ps2port.c +0 -543
- package/bios/seabios/src/hw/ps2port.h +0 -67
- package/bios/seabios/src/hw/pvscsi.c +0 -333
- package/bios/seabios/src/hw/pvscsi.h +0 -8
- package/bios/seabios/src/hw/ramdisk.c +0 -108
- package/bios/seabios/src/hw/rtc.c +0 -100
- package/bios/seabios/src/hw/rtc.h +0 -75
- package/bios/seabios/src/hw/sdcard.c +0 -572
- package/bios/seabios/src/hw/serialio.c +0 -113
- package/bios/seabios/src/hw/serialio.h +0 -29
- package/bios/seabios/src/hw/timer.c +0 -259
- package/bios/seabios/src/hw/tpm_drivers.c +0 -636
- package/bios/seabios/src/hw/tpm_drivers.h +0 -127
- package/bios/seabios/src/hw/usb-ehci.c +0 -650
- package/bios/seabios/src/hw/usb-ehci.h +0 -177
- package/bios/seabios/src/hw/usb-hid.c +0 -442
- package/bios/seabios/src/hw/usb-hid.h +0 -29
- package/bios/seabios/src/hw/usb-hub.c +0 -205
- package/bios/seabios/src/hw/usb-hub.h +0 -64
- package/bios/seabios/src/hw/usb-msc.c +0 -222
- package/bios/seabios/src/hw/usb-msc.h +0 -10
- package/bios/seabios/src/hw/usb-ohci.c +0 -568
- package/bios/seabios/src/hw/usb-ohci.h +0 -144
- package/bios/seabios/src/hw/usb-uas.c +0 -289
- package/bios/seabios/src/hw/usb-uas.h +0 -9
- package/bios/seabios/src/hw/usb-uhci.c +0 -571
- package/bios/seabios/src/hw/usb-uhci.h +0 -128
- package/bios/seabios/src/hw/usb-xhci.c +0 -1161
- package/bios/seabios/src/hw/usb-xhci.h +0 -133
- package/bios/seabios/src/hw/usb.c +0 -499
- package/bios/seabios/src/hw/usb.h +0 -254
- package/bios/seabios/src/hw/virtio-blk.c +0 -211
- package/bios/seabios/src/hw/virtio-blk.h +0 -43
- package/bios/seabios/src/hw/virtio-pci.c +0 -501
- package/bios/seabios/src/hw/virtio-pci.h +0 -151
- package/bios/seabios/src/hw/virtio-ring.c +0 -147
- package/bios/seabios/src/hw/virtio-ring.h +0 -121
- package/bios/seabios/src/hw/virtio-scsi.c +0 -220
- package/bios/seabios/src/hw/virtio-scsi.h +0 -47
- package/bios/seabios/src/jpeg.c +0 -1055
- package/bios/seabios/src/kbd.c +0 -599
- package/bios/seabios/src/list.h +0 -91
- package/bios/seabios/src/malloc.c +0 -561
- package/bios/seabios/src/malloc.h +0 -70
- package/bios/seabios/src/memmap.h +0 -21
- package/bios/seabios/src/misc.c +0 -195
- package/bios/seabios/src/mouse.c +0 -342
- package/bios/seabios/src/optionroms.c +0 -475
- package/bios/seabios/src/output.c +0 -584
- package/bios/seabios/src/output.h +0 -68
- package/bios/seabios/src/pcibios.c +0 -241
- package/bios/seabios/src/pmm.c +0 -176
- package/bios/seabios/src/pnpbios.c +0 -88
- package/bios/seabios/src/post.c +0 -337
- package/bios/seabios/src/resume.c +0 -157
- package/bios/seabios/src/romfile.c +0 -146
- package/bios/seabios/src/romfile.h +0 -21
- package/bios/seabios/src/romlayout.S +0 -698
- package/bios/seabios/src/sercon.c +0 -677
- package/bios/seabios/src/serial.c +0 -317
- package/bios/seabios/src/sha1.c +0 -147
- package/bios/seabios/src/sha1.h +0 -8
- package/bios/seabios/src/stacks.c +0 -771
- package/bios/seabios/src/stacks.h +0 -68
- package/bios/seabios/src/std/LegacyBios.h +0 -985
- package/bios/seabios/src/std/acpi.h +0 -323
- package/bios/seabios/src/std/bda.h +0 -174
- package/bios/seabios/src/std/disk.h +0 -175
- package/bios/seabios/src/std/mptable.h +0 -77
- package/bios/seabios/src/std/multiboot.h +0 -260
- package/bios/seabios/src/std/optionrom.h +0 -59
- package/bios/seabios/src/std/pirtable.h +0 -35
- package/bios/seabios/src/std/pmm.h +0 -19
- package/bios/seabios/src/std/pnpbios.h +0 -24
- package/bios/seabios/src/std/smbios.h +0 -167
- package/bios/seabios/src/std/tcg.h +0 -554
- package/bios/seabios/src/std/vbe.h +0 -156
- package/bios/seabios/src/std/vga.h +0 -63
- package/bios/seabios/src/string.c +0 -251
- package/bios/seabios/src/string.h +0 -31
- package/bios/seabios/src/system.c +0 -357
- package/bios/seabios/src/tcgbios.c +0 -2014
- package/bios/seabios/src/tcgbios.h +0 -19
- package/bios/seabios/src/types.h +0 -156
- package/bios/seabios/src/util.h +0 -251
- package/bios/seabios/src/version.c +0 -5
- package/bios/seabios/src/vgahooks.c +0 -355
- package/bios/seabios/src/x86.c +0 -23
- package/bios/seabios/src/x86.h +0 -277
- package/bios/seabios/vgasrc/Kconfig +0 -211
- package/bios/seabios/vgasrc/bochsdisplay.c +0 -59
- package/bios/seabios/vgasrc/bochsvga.c +0 -447
- package/bios/seabios/vgasrc/bochsvga.h +0 -57
- package/bios/seabios/vgasrc/cbvga.c +0 -337
- package/bios/seabios/vgasrc/clext.c +0 -627
- package/bios/seabios/vgasrc/geodevga.c +0 -434
- package/bios/seabios/vgasrc/geodevga.h +0 -89
- package/bios/seabios/vgasrc/ramfb.c +0 -163
- package/bios/seabios/vgasrc/stdvga.c +0 -485
- package/bios/seabios/vgasrc/stdvga.h +0 -81
- package/bios/seabios/vgasrc/stdvgaio.c +0 -186
- package/bios/seabios/vgasrc/stdvgamodes.c +0 -534
- package/bios/seabios/vgasrc/swcursor.c +0 -96
- package/bios/seabios/vgasrc/vbe.c +0 -432
- package/bios/seabios/vgasrc/vgabios.c +0 -1131
- package/bios/seabios/vgasrc/vgabios.h +0 -88
- package/bios/seabios/vgasrc/vgaentry.S +0 -161
- package/bios/seabios/vgasrc/vgafb.c +0 -661
- package/bios/seabios/vgasrc/vgafb.h +0 -42
- package/bios/seabios/vgasrc/vgafonts.c +0 -785
- package/bios/seabios/vgasrc/vgahw.h +0 -152
- package/bios/seabios/vgasrc/vgainit.c +0 -202
- package/bios/seabios/vgasrc/vgalayout.lds.S +0 -23
- package/bios/seabios/vgasrc/vgautil.h +0 -103
- package/bios/seabios/vgasrc/vgaversion.c +0 -6
- package/bios/seabios-debug.bin +0 -0
- package/bios/seabios-debug.config +0 -117
- package/bios/seabios.bin +0 -0
- package/bios/seabios.config +0 -114
- package/bios/vgabios-debug.bin +0 -0
- package/bios/vgabios.bin +0 -0
- package/build/binaries.js +0 -1
- package/build/index-debug.cjs +0 -1
- package/build/index-debug.js +0 -1
- package/build/index.cjs +0 -1
- package/build/index.js +0 -1
- package/v86.css +0 -259
|
@@ -1,501 +0,0 @@
|
|
|
1
|
-
/* virtio-pci.c - pci interface for virtio interface
|
|
2
|
-
*
|
|
3
|
-
* (c) Copyright 2008 Bull S.A.S.
|
|
4
|
-
*
|
|
5
|
-
* Author: Laurent Vivier <Laurent.Vivier@bull.net>
|
|
6
|
-
*
|
|
7
|
-
* some parts from Linux Virtio PCI driver
|
|
8
|
-
*
|
|
9
|
-
* Copyright IBM Corp. 2007
|
|
10
|
-
* Authors: Anthony Liguori <aliguori@us.ibm.com>
|
|
11
|
-
*
|
|
12
|
-
* Adopted for Seabios: Gleb Natapov <gleb@redhat.com>
|
|
13
|
-
*
|
|
14
|
-
* This work is licensed under the terms of the GNU LGPLv3
|
|
15
|
-
* See the COPYING file in the top-level directory.
|
|
16
|
-
*/
|
|
17
|
-
|
|
18
|
-
#include "config.h" // CONFIG_DEBUG_LEVEL
|
|
19
|
-
#include "malloc.h" // free
|
|
20
|
-
#include "output.h" // dprintf
|
|
21
|
-
#include "pci.h" // pci_config_readl
|
|
22
|
-
#include "pcidevice.h" // struct pci_device
|
|
23
|
-
#include "pci_regs.h" // PCI_BASE_ADDRESS_0
|
|
24
|
-
#include "string.h" // memset
|
|
25
|
-
#include "virtio-pci.h"
|
|
26
|
-
#include "virtio-ring.h"
|
|
27
|
-
|
|
28
|
-
u64 _vp_read(struct vp_cap *cap, u32 offset, u8 size)
|
|
29
|
-
{
|
|
30
|
-
u64 var = 0;
|
|
31
|
-
|
|
32
|
-
switch (cap->mode) {
|
|
33
|
-
case VP_ACCESS_IO:
|
|
34
|
-
{
|
|
35
|
-
u32 addr = cap->ioaddr + offset;
|
|
36
|
-
switch (size) {
|
|
37
|
-
case 8:
|
|
38
|
-
var = inl(addr);
|
|
39
|
-
var |= (u64)inl(addr+4) << 32;
|
|
40
|
-
break;
|
|
41
|
-
case 4:
|
|
42
|
-
var = inl(addr);
|
|
43
|
-
break;
|
|
44
|
-
case 2:
|
|
45
|
-
var = inw(addr);
|
|
46
|
-
break;
|
|
47
|
-
case 1:
|
|
48
|
-
var = inb(addr);
|
|
49
|
-
break;
|
|
50
|
-
}
|
|
51
|
-
break;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
case VP_ACCESS_MMIO:
|
|
55
|
-
{
|
|
56
|
-
void *addr = cap->memaddr + offset;
|
|
57
|
-
switch (size) {
|
|
58
|
-
case 8:
|
|
59
|
-
var = readl(addr);
|
|
60
|
-
var |= (u64)readl(addr+4) << 32;
|
|
61
|
-
break;
|
|
62
|
-
case 4:
|
|
63
|
-
var = readl(addr);
|
|
64
|
-
break;
|
|
65
|
-
case 2:
|
|
66
|
-
var = readw(addr);
|
|
67
|
-
break;
|
|
68
|
-
case 1:
|
|
69
|
-
var = readb(addr);
|
|
70
|
-
break;
|
|
71
|
-
}
|
|
72
|
-
break;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
case VP_ACCESS_PCICFG:
|
|
76
|
-
{
|
|
77
|
-
u32 addr = cap->baroff + offset;
|
|
78
|
-
pci_config_writeb(cap->bdf, cap->cfg +
|
|
79
|
-
offsetof(struct virtio_pci_cfg_cap, cap.bar),
|
|
80
|
-
cap->bar);
|
|
81
|
-
pci_config_writel(cap->bdf, cap->cfg +
|
|
82
|
-
offsetof(struct virtio_pci_cfg_cap, cap.offset),
|
|
83
|
-
addr);
|
|
84
|
-
pci_config_writel(cap->bdf, cap->cfg +
|
|
85
|
-
offsetof(struct virtio_pci_cfg_cap, cap.length),
|
|
86
|
-
(size > 4) ? 4 : size);
|
|
87
|
-
switch (size) {
|
|
88
|
-
case 8:
|
|
89
|
-
var = pci_config_readl(cap->bdf, cap->cfg +
|
|
90
|
-
offsetof(struct virtio_pci_cfg_cap, pci_cfg_data));
|
|
91
|
-
pci_config_writel(cap->bdf, cap->cfg +
|
|
92
|
-
offsetof(struct virtio_pci_cfg_cap, cap.offset),
|
|
93
|
-
addr + 4);
|
|
94
|
-
var |= (u64)pci_config_readl(cap->bdf, cap->cfg +
|
|
95
|
-
offsetof(struct virtio_pci_cfg_cap, pci_cfg_data)) << 32;
|
|
96
|
-
break;
|
|
97
|
-
case 4:
|
|
98
|
-
var = pci_config_readl(cap->bdf, cap->cfg +
|
|
99
|
-
offsetof(struct virtio_pci_cfg_cap, pci_cfg_data));
|
|
100
|
-
break;
|
|
101
|
-
case 2:
|
|
102
|
-
var = pci_config_readw(cap->bdf, cap->cfg +
|
|
103
|
-
offsetof(struct virtio_pci_cfg_cap, pci_cfg_data));
|
|
104
|
-
break;
|
|
105
|
-
case 1:
|
|
106
|
-
var = pci_config_readb(cap->bdf, cap->cfg +
|
|
107
|
-
offsetof(struct virtio_pci_cfg_cap, pci_cfg_data));
|
|
108
|
-
break;
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
dprintf(9, "vp read %x (%d) -> 0x%llx\n", cap->ioaddr + offset, size, var);
|
|
113
|
-
return var;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
void _vp_write(struct vp_cap *cap, u32 offset, u8 size, u64 var)
|
|
117
|
-
{
|
|
118
|
-
dprintf(9, "vp write %x (%d) <- 0x%llx\n", cap->ioaddr + offset, size, var);
|
|
119
|
-
|
|
120
|
-
switch (cap->mode) {
|
|
121
|
-
case VP_ACCESS_IO:
|
|
122
|
-
{
|
|
123
|
-
u32 addr = cap->ioaddr + offset;
|
|
124
|
-
switch (size) {
|
|
125
|
-
case 4:
|
|
126
|
-
outl(var, addr);
|
|
127
|
-
break;
|
|
128
|
-
case 2:
|
|
129
|
-
outw(var, addr);
|
|
130
|
-
break;
|
|
131
|
-
case 1:
|
|
132
|
-
outb(var, addr);
|
|
133
|
-
break;
|
|
134
|
-
}
|
|
135
|
-
break;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
case VP_ACCESS_MMIO:
|
|
139
|
-
{
|
|
140
|
-
void *addr = cap->memaddr + offset;
|
|
141
|
-
switch (size) {
|
|
142
|
-
case 4:
|
|
143
|
-
writel(addr, var);
|
|
144
|
-
break;
|
|
145
|
-
case 2:
|
|
146
|
-
writew(addr, var);
|
|
147
|
-
break;
|
|
148
|
-
case 1:
|
|
149
|
-
writeb(addr, var);
|
|
150
|
-
break;
|
|
151
|
-
}
|
|
152
|
-
break;
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
case VP_ACCESS_PCICFG:
|
|
156
|
-
{
|
|
157
|
-
u32 addr = cap->baroff + offset;
|
|
158
|
-
pci_config_writeb(cap->bdf, cap->cfg +
|
|
159
|
-
offsetof(struct virtio_pci_cfg_cap, cap.bar),
|
|
160
|
-
cap->bar);
|
|
161
|
-
pci_config_writel(cap->bdf, cap->cfg +
|
|
162
|
-
offsetof(struct virtio_pci_cfg_cap, cap.offset),
|
|
163
|
-
addr);
|
|
164
|
-
pci_config_writel(cap->bdf, cap->cfg +
|
|
165
|
-
offsetof(struct virtio_pci_cfg_cap, cap.length),
|
|
166
|
-
size);
|
|
167
|
-
switch (size) {
|
|
168
|
-
case 4:
|
|
169
|
-
pci_config_writel(cap->bdf, cap->cfg +
|
|
170
|
-
offsetof(struct virtio_pci_cfg_cap, pci_cfg_data),
|
|
171
|
-
var);
|
|
172
|
-
break;
|
|
173
|
-
case 2:
|
|
174
|
-
pci_config_writew(cap->bdf, cap->cfg +
|
|
175
|
-
offsetof(struct virtio_pci_cfg_cap, pci_cfg_data),
|
|
176
|
-
var);
|
|
177
|
-
break;
|
|
178
|
-
case 1:
|
|
179
|
-
pci_config_writeb(cap->bdf, cap->cfg +
|
|
180
|
-
offsetof(struct virtio_pci_cfg_cap, pci_cfg_data),
|
|
181
|
-
var);
|
|
182
|
-
break;
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
u64 vp_get_features(struct vp_device *vp)
|
|
189
|
-
{
|
|
190
|
-
u32 f0, f1;
|
|
191
|
-
|
|
192
|
-
if (vp->use_modern) {
|
|
193
|
-
vp_write(&vp->common, virtio_pci_common_cfg, device_feature_select, 0);
|
|
194
|
-
f0 = vp_read(&vp->common, virtio_pci_common_cfg, device_feature);
|
|
195
|
-
vp_write(&vp->common, virtio_pci_common_cfg, device_feature_select, 1);
|
|
196
|
-
f1 = vp_read(&vp->common, virtio_pci_common_cfg, device_feature);
|
|
197
|
-
} else {
|
|
198
|
-
f0 = vp_read(&vp->legacy, virtio_pci_legacy, host_features);
|
|
199
|
-
f1 = 0;
|
|
200
|
-
}
|
|
201
|
-
return ((u64)f1 << 32) | f0;
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
void vp_set_features(struct vp_device *vp, u64 features)
|
|
205
|
-
{
|
|
206
|
-
u32 f0, f1;
|
|
207
|
-
|
|
208
|
-
f0 = features;
|
|
209
|
-
f1 = features >> 32;
|
|
210
|
-
|
|
211
|
-
if (vp->use_modern) {
|
|
212
|
-
vp_write(&vp->common, virtio_pci_common_cfg, guest_feature_select, 0);
|
|
213
|
-
vp_write(&vp->common, virtio_pci_common_cfg, guest_feature, f0);
|
|
214
|
-
vp_write(&vp->common, virtio_pci_common_cfg, guest_feature_select, 1);
|
|
215
|
-
vp_write(&vp->common, virtio_pci_common_cfg, guest_feature, f1);
|
|
216
|
-
} else {
|
|
217
|
-
vp_write(&vp->legacy, virtio_pci_legacy, guest_features, f0);
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
u8 vp_get_status(struct vp_device *vp)
|
|
222
|
-
{
|
|
223
|
-
if (vp->use_modern) {
|
|
224
|
-
return vp_read(&vp->common, virtio_pci_common_cfg, device_status);
|
|
225
|
-
} else {
|
|
226
|
-
return vp_read(&vp->legacy, virtio_pci_legacy, status);
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
void vp_set_status(struct vp_device *vp, u8 status)
|
|
231
|
-
{
|
|
232
|
-
if (status == 0) /* reset */
|
|
233
|
-
return;
|
|
234
|
-
if (vp->use_modern) {
|
|
235
|
-
vp_write(&vp->common, virtio_pci_common_cfg, device_status, status);
|
|
236
|
-
} else {
|
|
237
|
-
vp_write(&vp->legacy, virtio_pci_legacy, status, status);
|
|
238
|
-
}
|
|
239
|
-
}
|
|
240
|
-
|
|
241
|
-
u8 vp_get_isr(struct vp_device *vp)
|
|
242
|
-
{
|
|
243
|
-
if (vp->use_modern) {
|
|
244
|
-
return vp_read(&vp->isr, virtio_pci_isr, isr);
|
|
245
|
-
} else {
|
|
246
|
-
return vp_read(&vp->legacy, virtio_pci_legacy, isr);
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
void vp_reset(struct vp_device *vp)
|
|
251
|
-
{
|
|
252
|
-
if (vp->use_modern) {
|
|
253
|
-
vp_write(&vp->common, virtio_pci_common_cfg, device_status, 0);
|
|
254
|
-
vp_read(&vp->isr, virtio_pci_isr, isr);
|
|
255
|
-
} else {
|
|
256
|
-
vp_write(&vp->legacy, virtio_pci_legacy, status, 0);
|
|
257
|
-
vp_read(&vp->legacy, virtio_pci_legacy, isr);
|
|
258
|
-
}
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
void vp_notify(struct vp_device *vp, struct vring_virtqueue *vq)
|
|
262
|
-
{
|
|
263
|
-
if (vp->use_modern) {
|
|
264
|
-
u32 offset = vq->queue_notify_off * vp->notify_off_multiplier;
|
|
265
|
-
switch (vp->notify.mode) {
|
|
266
|
-
case VP_ACCESS_IO:
|
|
267
|
-
outw(vq->queue_index, vp->notify.ioaddr + offset);
|
|
268
|
-
break;
|
|
269
|
-
case VP_ACCESS_MMIO:
|
|
270
|
-
writew(vp->notify.memaddr + offset, vq->queue_index);
|
|
271
|
-
break;
|
|
272
|
-
case VP_ACCESS_PCICFG:
|
|
273
|
-
pci_config_writeb(vp->notify.bdf, vp->notify.cfg +
|
|
274
|
-
offsetof(struct virtio_pci_cfg_cap, cap.bar),
|
|
275
|
-
vp->notify.bar);
|
|
276
|
-
pci_config_writel(vp->notify.bdf, vp->notify.cfg +
|
|
277
|
-
offsetof(struct virtio_pci_cfg_cap, cap.offset),
|
|
278
|
-
vp->notify.baroff + offset);
|
|
279
|
-
pci_config_writel(vp->notify.bdf, vp->notify.cfg +
|
|
280
|
-
offsetof(struct virtio_pci_cfg_cap, cap.length),
|
|
281
|
-
2);
|
|
282
|
-
pci_config_writew(vp->notify.bdf, vp->notify.cfg +
|
|
283
|
-
offsetof(struct virtio_pci_cfg_cap, pci_cfg_data),
|
|
284
|
-
vq->queue_index);
|
|
285
|
-
}
|
|
286
|
-
dprintf(9, "vp notify %x (%d) -- 0x%x\n",
|
|
287
|
-
vp->notify.ioaddr, 2, vq->queue_index);
|
|
288
|
-
} else {
|
|
289
|
-
vp_write(&vp->legacy, virtio_pci_legacy, queue_notify, vq->queue_index);
|
|
290
|
-
}
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
int vp_find_vq(struct vp_device *vp, int queue_index,
|
|
294
|
-
struct vring_virtqueue **p_vq)
|
|
295
|
-
{
|
|
296
|
-
u16 num;
|
|
297
|
-
|
|
298
|
-
ASSERT32FLAT();
|
|
299
|
-
struct vring_virtqueue *vq = *p_vq = memalign_high(PAGE_SIZE, sizeof(*vq));
|
|
300
|
-
if (!vq) {
|
|
301
|
-
warn_noalloc();
|
|
302
|
-
goto fail;
|
|
303
|
-
}
|
|
304
|
-
memset(vq, 0, sizeof(*vq));
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
/* select the queue */
|
|
308
|
-
if (vp->use_modern) {
|
|
309
|
-
vp_write(&vp->common, virtio_pci_common_cfg, queue_select, queue_index);
|
|
310
|
-
} else {
|
|
311
|
-
vp_write(&vp->legacy, virtio_pci_legacy, queue_sel, queue_index);
|
|
312
|
-
}
|
|
313
|
-
|
|
314
|
-
/* check if the queue is available */
|
|
315
|
-
if (vp->use_modern) {
|
|
316
|
-
num = vp_read(&vp->common, virtio_pci_common_cfg, queue_size);
|
|
317
|
-
if (num > MAX_QUEUE_NUM) {
|
|
318
|
-
vp_write(&vp->common, virtio_pci_common_cfg, queue_size,
|
|
319
|
-
MAX_QUEUE_NUM);
|
|
320
|
-
num = vp_read(&vp->common, virtio_pci_common_cfg, queue_size);
|
|
321
|
-
}
|
|
322
|
-
} else {
|
|
323
|
-
num = vp_read(&vp->legacy, virtio_pci_legacy, queue_num);
|
|
324
|
-
}
|
|
325
|
-
if (!num) {
|
|
326
|
-
dprintf(1, "ERROR: queue size is 0\n");
|
|
327
|
-
goto fail;
|
|
328
|
-
}
|
|
329
|
-
if (num > MAX_QUEUE_NUM) {
|
|
330
|
-
dprintf(1, "ERROR: queue size %d > %d\n", num, MAX_QUEUE_NUM);
|
|
331
|
-
goto fail;
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
/* check if the queue is already active */
|
|
335
|
-
if (vp->use_modern) {
|
|
336
|
-
if (vp_read(&vp->common, virtio_pci_common_cfg, queue_enable)) {
|
|
337
|
-
dprintf(1, "ERROR: queue already active\n");
|
|
338
|
-
goto fail;
|
|
339
|
-
}
|
|
340
|
-
} else {
|
|
341
|
-
if (vp_read(&vp->legacy, virtio_pci_legacy, queue_pfn)) {
|
|
342
|
-
dprintf(1, "ERROR: queue already active\n");
|
|
343
|
-
goto fail;
|
|
344
|
-
}
|
|
345
|
-
}
|
|
346
|
-
vq->queue_index = queue_index;
|
|
347
|
-
|
|
348
|
-
/* initialize the queue */
|
|
349
|
-
struct vring * vr = &vq->vring;
|
|
350
|
-
vring_init(vr, num, (unsigned char*)&vq->queue);
|
|
351
|
-
|
|
352
|
-
/* activate the queue
|
|
353
|
-
*
|
|
354
|
-
* NOTE: vr->desc is initialized by vring_init()
|
|
355
|
-
*/
|
|
356
|
-
|
|
357
|
-
if (vp->use_modern) {
|
|
358
|
-
vp_write(&vp->common, virtio_pci_common_cfg, queue_desc_lo,
|
|
359
|
-
(unsigned long)virt_to_phys(vr->desc));
|
|
360
|
-
vp_write(&vp->common, virtio_pci_common_cfg, queue_desc_hi, 0);
|
|
361
|
-
vp_write(&vp->common, virtio_pci_common_cfg, queue_avail_lo,
|
|
362
|
-
(unsigned long)virt_to_phys(vr->avail));
|
|
363
|
-
vp_write(&vp->common, virtio_pci_common_cfg, queue_avail_hi, 0);
|
|
364
|
-
vp_write(&vp->common, virtio_pci_common_cfg, queue_used_lo,
|
|
365
|
-
(unsigned long)virt_to_phys(vr->used));
|
|
366
|
-
vp_write(&vp->common, virtio_pci_common_cfg, queue_used_hi, 0);
|
|
367
|
-
vp_write(&vp->common, virtio_pci_common_cfg, queue_enable, 1);
|
|
368
|
-
vq->queue_notify_off = vp_read(&vp->common, virtio_pci_common_cfg,
|
|
369
|
-
queue_notify_off);
|
|
370
|
-
} else {
|
|
371
|
-
vp_write(&vp->legacy, virtio_pci_legacy, queue_pfn,
|
|
372
|
-
(unsigned long)virt_to_phys(vr->desc) >> PAGE_SHIFT);
|
|
373
|
-
}
|
|
374
|
-
return num;
|
|
375
|
-
|
|
376
|
-
fail:
|
|
377
|
-
free(vq);
|
|
378
|
-
*p_vq = NULL;
|
|
379
|
-
return -1;
|
|
380
|
-
}
|
|
381
|
-
|
|
382
|
-
void vp_init_simple(struct vp_device *vp, struct pci_device *pci)
|
|
383
|
-
{
|
|
384
|
-
u8 cap = pci_find_capability(pci->bdf, PCI_CAP_ID_VNDR, 0);
|
|
385
|
-
struct vp_cap *vp_cap;
|
|
386
|
-
const char *mode;
|
|
387
|
-
u32 offset, base, mul;
|
|
388
|
-
u64 addr;
|
|
389
|
-
u8 type;
|
|
390
|
-
|
|
391
|
-
memset(vp, 0, sizeof(*vp));
|
|
392
|
-
while (cap != 0) {
|
|
393
|
-
type = pci_config_readb(pci->bdf, cap +
|
|
394
|
-
offsetof(struct virtio_pci_cap, cfg_type));
|
|
395
|
-
switch (type) {
|
|
396
|
-
case VIRTIO_PCI_CAP_COMMON_CFG:
|
|
397
|
-
vp_cap = &vp->common;
|
|
398
|
-
break;
|
|
399
|
-
case VIRTIO_PCI_CAP_NOTIFY_CFG:
|
|
400
|
-
vp_cap = &vp->notify;
|
|
401
|
-
mul = offsetof(struct virtio_pci_notify_cap, notify_off_multiplier);
|
|
402
|
-
vp->notify_off_multiplier = pci_config_readl(pci->bdf, cap + mul);
|
|
403
|
-
break;
|
|
404
|
-
case VIRTIO_PCI_CAP_ISR_CFG:
|
|
405
|
-
vp_cap = &vp->isr;
|
|
406
|
-
break;
|
|
407
|
-
case VIRTIO_PCI_CAP_DEVICE_CFG:
|
|
408
|
-
vp_cap = &vp->device;
|
|
409
|
-
break;
|
|
410
|
-
case VIRTIO_PCI_CAP_PCI_CFG:
|
|
411
|
-
vp->common.cfg = cap;
|
|
412
|
-
vp->common.bdf = pci->bdf;
|
|
413
|
-
vp->notify.cfg = cap;
|
|
414
|
-
vp->notify.bdf = pci->bdf;
|
|
415
|
-
vp->isr.cfg = cap;
|
|
416
|
-
vp->isr.bdf = pci->bdf;
|
|
417
|
-
vp->device.cfg = cap;
|
|
418
|
-
vp->device.bdf = pci->bdf;
|
|
419
|
-
vp_cap = NULL;
|
|
420
|
-
dprintf(1, "pci dev %x:%x virtio cap at 0x%x type %d [pci cfg access]\n",
|
|
421
|
-
pci_bdf_to_bus(pci->bdf), pci_bdf_to_dev(pci->bdf),
|
|
422
|
-
cap, type);
|
|
423
|
-
break;
|
|
424
|
-
default:
|
|
425
|
-
vp_cap = NULL;
|
|
426
|
-
break;
|
|
427
|
-
}
|
|
428
|
-
if (vp_cap && !vp_cap->cap) {
|
|
429
|
-
vp_cap->cap = cap;
|
|
430
|
-
vp_cap->bar = pci_config_readb(pci->bdf, cap +
|
|
431
|
-
offsetof(struct virtio_pci_cap, bar));
|
|
432
|
-
offset = pci_config_readl(pci->bdf, cap +
|
|
433
|
-
offsetof(struct virtio_pci_cap, offset));
|
|
434
|
-
base = PCI_BASE_ADDRESS_0 + 4 * vp_cap->bar;
|
|
435
|
-
addr = pci_config_readl(pci->bdf, base);
|
|
436
|
-
if (addr & PCI_BASE_ADDRESS_SPACE_IO) {
|
|
437
|
-
addr &= PCI_BASE_ADDRESS_IO_MASK;
|
|
438
|
-
vp_cap->mode = VP_ACCESS_IO;
|
|
439
|
-
} else if ((addr & PCI_BASE_ADDRESS_MEM_TYPE_MASK) ==
|
|
440
|
-
PCI_BASE_ADDRESS_MEM_TYPE_64) {
|
|
441
|
-
addr &= PCI_BASE_ADDRESS_MEM_MASK;
|
|
442
|
-
addr |= (u64)pci_config_readl(pci->bdf, base + 4) << 32;
|
|
443
|
-
vp_cap->mode = (addr > 0xffffffffll) ?
|
|
444
|
-
VP_ACCESS_PCICFG : VP_ACCESS_MMIO;
|
|
445
|
-
} else {
|
|
446
|
-
addr &= PCI_BASE_ADDRESS_MEM_MASK;
|
|
447
|
-
vp_cap->mode = VP_ACCESS_MMIO;
|
|
448
|
-
}
|
|
449
|
-
switch (vp_cap->mode) {
|
|
450
|
-
case VP_ACCESS_IO:
|
|
451
|
-
{
|
|
452
|
-
u32 addr = pci_enable_iobar(pci, base);
|
|
453
|
-
if (!addr)
|
|
454
|
-
return;
|
|
455
|
-
vp_cap->ioaddr = addr + offset;
|
|
456
|
-
mode = "io";
|
|
457
|
-
break;
|
|
458
|
-
}
|
|
459
|
-
case VP_ACCESS_MMIO:
|
|
460
|
-
{
|
|
461
|
-
void *addr = pci_enable_membar(pci, base);
|
|
462
|
-
if (!addr)
|
|
463
|
-
return;
|
|
464
|
-
vp_cap->memaddr = addr + offset;
|
|
465
|
-
mode = "mmio";
|
|
466
|
-
break;
|
|
467
|
-
}
|
|
468
|
-
case VP_ACCESS_PCICFG:
|
|
469
|
-
mode = "pcicfg";
|
|
470
|
-
vp_cap->baroff = offset;
|
|
471
|
-
break;
|
|
472
|
-
default:
|
|
473
|
-
mode = "Huh?";
|
|
474
|
-
break;
|
|
475
|
-
}
|
|
476
|
-
dprintf(1, "pci dev %x:%x virtio cap at 0x%x type %d "
|
|
477
|
-
"bar %d at 0x%08llx off +0x%04x [%s]\n",
|
|
478
|
-
pci_bdf_to_bus(pci->bdf), pci_bdf_to_dev(pci->bdf),
|
|
479
|
-
vp_cap->cap, type, vp_cap->bar, addr, offset, mode);
|
|
480
|
-
}
|
|
481
|
-
|
|
482
|
-
cap = pci_find_capability(pci->bdf, PCI_CAP_ID_VNDR, cap);
|
|
483
|
-
}
|
|
484
|
-
|
|
485
|
-
if (vp->common.cap && vp->notify.cap && vp->isr.cap && vp->device.cap) {
|
|
486
|
-
dprintf(1, "pci dev %pP using modern (1.0) virtio mode\n", pci);
|
|
487
|
-
vp->use_modern = 1;
|
|
488
|
-
} else {
|
|
489
|
-
dprintf(1, "pci dev %pP using legacy (0.9.5) virtio mode\n", pci);
|
|
490
|
-
vp->legacy.bar = 0;
|
|
491
|
-
vp->legacy.ioaddr = pci_enable_iobar(pci, PCI_BASE_ADDRESS_0);
|
|
492
|
-
if (!vp->legacy.ioaddr)
|
|
493
|
-
return;
|
|
494
|
-
vp->legacy.mode = VP_ACCESS_IO;
|
|
495
|
-
}
|
|
496
|
-
|
|
497
|
-
vp_reset(vp);
|
|
498
|
-
pci_enable_busmaster(pci);
|
|
499
|
-
vp_set_status(vp, VIRTIO_CONFIG_S_ACKNOWLEDGE |
|
|
500
|
-
VIRTIO_CONFIG_S_DRIVER );
|
|
501
|
-
}
|
|
@@ -1,151 +0,0 @@
|
|
|
1
|
-
#ifndef _VIRTIO_PCI_H
|
|
2
|
-
#define _VIRTIO_PCI_H
|
|
3
|
-
|
|
4
|
-
#include "x86.h" // inl
|
|
5
|
-
#include "biosvar.h" // GET_LOWFLAT
|
|
6
|
-
|
|
7
|
-
/* The bit of the ISR which indicates a device configuration change. */
|
|
8
|
-
#define VIRTIO_PCI_ISR_CONFIG 0x2
|
|
9
|
-
|
|
10
|
-
/* Virtio ABI version, this must match exactly */
|
|
11
|
-
#define VIRTIO_PCI_ABI_VERSION 0
|
|
12
|
-
|
|
13
|
-
/* --- virtio 0.9.5 (legacy) struct --------------------------------- */
|
|
14
|
-
|
|
15
|
-
typedef struct virtio_pci_legacy {
|
|
16
|
-
u32 host_features;
|
|
17
|
-
u32 guest_features;
|
|
18
|
-
u32 queue_pfn;
|
|
19
|
-
u16 queue_num;
|
|
20
|
-
u16 queue_sel;
|
|
21
|
-
u16 queue_notify;
|
|
22
|
-
u8 status;
|
|
23
|
-
u8 isr;
|
|
24
|
-
u8 device[];
|
|
25
|
-
} virtio_pci_legacy;
|
|
26
|
-
|
|
27
|
-
/* --- virtio 1.0 (modern) structs ---------------------------------- */
|
|
28
|
-
|
|
29
|
-
/* Common configuration */
|
|
30
|
-
#define VIRTIO_PCI_CAP_COMMON_CFG 1
|
|
31
|
-
/* Notifications */
|
|
32
|
-
#define VIRTIO_PCI_CAP_NOTIFY_CFG 2
|
|
33
|
-
/* ISR access */
|
|
34
|
-
#define VIRTIO_PCI_CAP_ISR_CFG 3
|
|
35
|
-
/* Device specific configuration */
|
|
36
|
-
#define VIRTIO_PCI_CAP_DEVICE_CFG 4
|
|
37
|
-
/* PCI configuration access */
|
|
38
|
-
#define VIRTIO_PCI_CAP_PCI_CFG 5
|
|
39
|
-
|
|
40
|
-
/* This is the PCI capability header: */
|
|
41
|
-
struct virtio_pci_cap {
|
|
42
|
-
u8 cap_vndr; /* Generic PCI field: PCI_CAP_ID_VNDR */
|
|
43
|
-
u8 cap_next; /* Generic PCI field: next ptr. */
|
|
44
|
-
u8 cap_len; /* Generic PCI field: capability length */
|
|
45
|
-
u8 cfg_type; /* Identifies the structure. */
|
|
46
|
-
u8 bar; /* Where to find it. */
|
|
47
|
-
u8 padding[3]; /* Pad to full dword. */
|
|
48
|
-
u32 offset; /* Offset within bar. */
|
|
49
|
-
u32 length; /* Length of the structure, in bytes. */
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
struct virtio_pci_notify_cap {
|
|
53
|
-
struct virtio_pci_cap cap;
|
|
54
|
-
u32 notify_off_multiplier; /* Multiplier for queue_notify_off. */
|
|
55
|
-
};
|
|
56
|
-
|
|
57
|
-
struct virtio_pci_cfg_cap {
|
|
58
|
-
struct virtio_pci_cap cap;
|
|
59
|
-
u8 pci_cfg_data[4]; /* Data for BAR access. */
|
|
60
|
-
};
|
|
61
|
-
|
|
62
|
-
typedef struct virtio_pci_common_cfg {
|
|
63
|
-
/* About the whole device. */
|
|
64
|
-
u32 device_feature_select; /* read-write */
|
|
65
|
-
u32 device_feature; /* read-only */
|
|
66
|
-
u32 guest_feature_select; /* read-write */
|
|
67
|
-
u32 guest_feature; /* read-write */
|
|
68
|
-
u16 msix_config; /* read-write */
|
|
69
|
-
u16 num_queues; /* read-only */
|
|
70
|
-
u8 device_status; /* read-write */
|
|
71
|
-
u8 config_generation; /* read-only */
|
|
72
|
-
|
|
73
|
-
/* About a specific virtqueue. */
|
|
74
|
-
u16 queue_select; /* read-write */
|
|
75
|
-
u16 queue_size; /* read-write, power of 2. */
|
|
76
|
-
u16 queue_msix_vector; /* read-write */
|
|
77
|
-
u16 queue_enable; /* read-write */
|
|
78
|
-
u16 queue_notify_off; /* read-only */
|
|
79
|
-
u32 queue_desc_lo; /* read-write */
|
|
80
|
-
u32 queue_desc_hi; /* read-write */
|
|
81
|
-
u32 queue_avail_lo; /* read-write */
|
|
82
|
-
u32 queue_avail_hi; /* read-write */
|
|
83
|
-
u32 queue_used_lo; /* read-write */
|
|
84
|
-
u32 queue_used_hi; /* read-write */
|
|
85
|
-
} virtio_pci_common_cfg;
|
|
86
|
-
|
|
87
|
-
typedef struct virtio_pci_isr {
|
|
88
|
-
u8 isr;
|
|
89
|
-
} virtio_pci_isr;
|
|
90
|
-
|
|
91
|
-
/* --- driver structs ----------------------------------------------- */
|
|
92
|
-
|
|
93
|
-
#define VP_ACCESS_IO 1
|
|
94
|
-
#define VP_ACCESS_MMIO 2
|
|
95
|
-
#define VP_ACCESS_PCICFG 3
|
|
96
|
-
|
|
97
|
-
struct vp_cap {
|
|
98
|
-
union {
|
|
99
|
-
void *memaddr;
|
|
100
|
-
u32 ioaddr;
|
|
101
|
-
u32 baroff;
|
|
102
|
-
};
|
|
103
|
-
u16 bdf;
|
|
104
|
-
u8 cap;
|
|
105
|
-
u8 cfg;
|
|
106
|
-
u8 bar;
|
|
107
|
-
u8 mode;
|
|
108
|
-
};
|
|
109
|
-
|
|
110
|
-
struct vp_device {
|
|
111
|
-
struct vp_cap common, notify, isr, device, legacy;
|
|
112
|
-
u32 notify_off_multiplier;
|
|
113
|
-
u8 use_modern;
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
u64 _vp_read(struct vp_cap *cap, u32 offset, u8 size);
|
|
117
|
-
void _vp_write(struct vp_cap *cap, u32 offset, u8 size, u64 var);
|
|
118
|
-
|
|
119
|
-
#define vp_read(_cap, _struct, _field) \
|
|
120
|
-
_vp_read(_cap, offsetof(_struct, _field), \
|
|
121
|
-
sizeof(((_struct *)0)->_field))
|
|
122
|
-
|
|
123
|
-
#define vp_write(_cap, _struct, _field, _var) \
|
|
124
|
-
_vp_write(_cap, offsetof(_struct, _field), \
|
|
125
|
-
sizeof(((_struct *)0)->_field), _var)
|
|
126
|
-
|
|
127
|
-
u64 vp_get_features(struct vp_device *vp);
|
|
128
|
-
void vp_set_features(struct vp_device *vp, u64 features);
|
|
129
|
-
|
|
130
|
-
static inline void vp_get_legacy(struct vp_device *vp, unsigned offset,
|
|
131
|
-
void *buf, unsigned len)
|
|
132
|
-
{
|
|
133
|
-
u8 *ptr = buf;
|
|
134
|
-
unsigned i;
|
|
135
|
-
|
|
136
|
-
for (i = 0; i < len; i++)
|
|
137
|
-
ptr[i] = vp_read(&vp->legacy, virtio_pci_legacy, device[i]);
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
u8 vp_get_status(struct vp_device *vp);
|
|
141
|
-
void vp_set_status(struct vp_device *vp, u8 status);
|
|
142
|
-
u8 vp_get_isr(struct vp_device *vp);
|
|
143
|
-
void vp_reset(struct vp_device *vp);
|
|
144
|
-
|
|
145
|
-
struct pci_device;
|
|
146
|
-
struct vring_virtqueue;
|
|
147
|
-
void vp_init_simple(struct vp_device *vp, struct pci_device *pci);
|
|
148
|
-
void vp_notify(struct vp_device *vp, struct vring_virtqueue *vq);
|
|
149
|
-
int vp_find_vq(struct vp_device *vp, int queue_index,
|
|
150
|
-
struct vring_virtqueue **p_vq);
|
|
151
|
-
#endif /* _VIRTIO_PCI_H_ */
|