v86 0.4.0 → 0.5.11
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 +12680 -0
- package/build/libv86-debug.mjs +732 -0
- package/build/libv86.js +710 -0
- package/build/libv86.mjs +637 -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,14 +0,0 @@
|
|
|
1
|
-
# Helper code for compatibility of the code with both Python 2 and Python 3
|
|
2
|
-
#
|
|
3
|
-
# Copyright (C) 2014 Johannes Krampf <johannes.krampf@googlemail.com>
|
|
4
|
-
#
|
|
5
|
-
# This file may be distributed under the terms of the GNU GPLv3 license.
|
|
6
|
-
|
|
7
|
-
import sys
|
|
8
|
-
|
|
9
|
-
if (sys.version_info > (3, 0)):
|
|
10
|
-
def as_bytes(str):
|
|
11
|
-
return bytes(str, "ASCII")
|
|
12
|
-
else:
|
|
13
|
-
def as_bytes(str):
|
|
14
|
-
return str
|
|
@@ -1,190 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python
|
|
2
|
-
# Script that can read from a serial device and show timestamps.
|
|
3
|
-
#
|
|
4
|
-
# Copyright (C) 2009 Kevin O'Connor <kevin@koconnor.net>
|
|
5
|
-
#
|
|
6
|
-
# This file may be distributed under the terms of the GNU GPLv3 license.
|
|
7
|
-
|
|
8
|
-
# Usage:
|
|
9
|
-
# scripts/readserial.py /dev/ttyUSB0 115200
|
|
10
|
-
|
|
11
|
-
import sys, os, time, select, optparse
|
|
12
|
-
|
|
13
|
-
from python23compat import as_bytes
|
|
14
|
-
|
|
15
|
-
# Reset time counter after this much idle time.
|
|
16
|
-
RESTARTINTERVAL = 60
|
|
17
|
-
# Number of bits in a transmitted byte - 8N1 is 1 start bit + 8 data
|
|
18
|
-
# bits + 1 stop bit.
|
|
19
|
-
BITSPERBYTE = 10
|
|
20
|
-
|
|
21
|
-
def calibrateserialwrite(outfile, byteadjust):
|
|
22
|
-
# Build 4000 bytes of dummy data.
|
|
23
|
-
data = "0123456789" * 4 + "012345678" + "\n"
|
|
24
|
-
data = data * 80
|
|
25
|
-
while 1:
|
|
26
|
-
st = time.time()
|
|
27
|
-
outfile.write(as_bytes(data))
|
|
28
|
-
outfile.flush()
|
|
29
|
-
et = time.time()
|
|
30
|
-
sys.stdout.write(
|
|
31
|
-
"Wrote %d - %.1fus per char (theory states %.1fus)\n" % (
|
|
32
|
-
len(data), (et-st) / len(data) * 1000000, byteadjust * 1000000))
|
|
33
|
-
sys.stdout.flush()
|
|
34
|
-
time.sleep(3)
|
|
35
|
-
|
|
36
|
-
def calibrateserialread(infile, byteadjust):
|
|
37
|
-
starttime = lasttime = 0
|
|
38
|
-
totalchars = 0
|
|
39
|
-
while 1:
|
|
40
|
-
select.select([infile], [], [])
|
|
41
|
-
d = infile.read(4096)
|
|
42
|
-
curtime = time.time()
|
|
43
|
-
if curtime - lasttime > 1.0:
|
|
44
|
-
if starttime and totalchars:
|
|
45
|
-
sys.stdout.write(
|
|
46
|
-
"Calibrating on %d bytes - %.1fus per char"
|
|
47
|
-
" (theory states %.1fus)\n" % (
|
|
48
|
-
totalchars,
|
|
49
|
-
float(lasttime - starttime) * 1000000 / totalchars,
|
|
50
|
-
byteadjust * 1000000))
|
|
51
|
-
totalchars = 0
|
|
52
|
-
starttime = curtime
|
|
53
|
-
else:
|
|
54
|
-
totalchars += len(d)
|
|
55
|
-
lasttime = curtime
|
|
56
|
-
|
|
57
|
-
def readserial(infile, logfile, byteadjust):
|
|
58
|
-
lasttime = 0
|
|
59
|
-
while 1:
|
|
60
|
-
# Read data
|
|
61
|
-
try:
|
|
62
|
-
res = select.select([infile, sys.stdin], [], [])
|
|
63
|
-
except KeyboardInterrupt:
|
|
64
|
-
sys.stdout.write("\n")
|
|
65
|
-
return -1
|
|
66
|
-
if sys.stdin in res[0]:
|
|
67
|
-
# Got keyboard input - force reset on next serial input
|
|
68
|
-
sys.stdin.read(1)
|
|
69
|
-
lasttime = 0
|
|
70
|
-
if len(res[0]) == 1:
|
|
71
|
-
continue
|
|
72
|
-
d = infile.read(4096)
|
|
73
|
-
if not d:
|
|
74
|
-
return 0
|
|
75
|
-
datatime = time.time()
|
|
76
|
-
|
|
77
|
-
datatime -= len(d) * byteadjust
|
|
78
|
-
|
|
79
|
-
# Reset start time if no data for some time
|
|
80
|
-
if datatime - lasttime > RESTARTINTERVAL:
|
|
81
|
-
starttime = datatime
|
|
82
|
-
charcount = 0
|
|
83
|
-
isnewline = 1
|
|
84
|
-
msg = "\n\n======= %s (adjust=%.1fus)\n" % (
|
|
85
|
-
time.asctime(time.localtime(datatime)), byteadjust * 1000000)
|
|
86
|
-
sys.stdout.write(msg)
|
|
87
|
-
logfile.write(as_bytes(msg))
|
|
88
|
-
lasttime = datatime
|
|
89
|
-
|
|
90
|
-
# Translate unprintable chars; add timestamps
|
|
91
|
-
out = as_bytes("")
|
|
92
|
-
for c in d:
|
|
93
|
-
if isnewline:
|
|
94
|
-
delta = datatime - starttime - (charcount * byteadjust)
|
|
95
|
-
out += "%06.3f: " % delta
|
|
96
|
-
isnewline = 0
|
|
97
|
-
oc = ord(c)
|
|
98
|
-
charcount += 1
|
|
99
|
-
datatime += byteadjust
|
|
100
|
-
if oc == 0x0d:
|
|
101
|
-
continue
|
|
102
|
-
if oc == 0x00:
|
|
103
|
-
out += "<00>\n"
|
|
104
|
-
isnewline = 1
|
|
105
|
-
continue
|
|
106
|
-
if oc == 0x0a:
|
|
107
|
-
out += "\n"
|
|
108
|
-
isnewline = 1
|
|
109
|
-
continue
|
|
110
|
-
if oc < 0x20 or oc >= 0x7f and oc != 0x09:
|
|
111
|
-
out += "<%02x>" % oc
|
|
112
|
-
continue
|
|
113
|
-
out += c
|
|
114
|
-
|
|
115
|
-
if (sys.version_info > (3, 0)):
|
|
116
|
-
sys.stdout.buffer.write(out)
|
|
117
|
-
else:
|
|
118
|
-
sys.stdout.write(out)
|
|
119
|
-
sys.stdout.flush()
|
|
120
|
-
logfile.write(out)
|
|
121
|
-
logfile.flush()
|
|
122
|
-
|
|
123
|
-
def main():
|
|
124
|
-
usage = "%prog [options] [<serialdevice> [<baud>]]"
|
|
125
|
-
opts = optparse.OptionParser(usage)
|
|
126
|
-
opts.add_option("-f", "--file",
|
|
127
|
-
action="store_false", dest="serial", default=True,
|
|
128
|
-
help="read from unix named pipe instead of serialdevice")
|
|
129
|
-
opts.add_option("-n", "--no-adjust",
|
|
130
|
-
action="store_false", dest="adjustbaud", default=True,
|
|
131
|
-
help="don't adjust times by serial rate")
|
|
132
|
-
opts.add_option("-c", "--calibrate-read",
|
|
133
|
-
action="store_true", dest="calibrate_read", default=False,
|
|
134
|
-
help="read from serial port to calibrate it")
|
|
135
|
-
opts.add_option("-C", "--calibrate-write",
|
|
136
|
-
action="store_true", dest="calibrate_write", default=False,
|
|
137
|
-
help="write to serial port to calibrate it")
|
|
138
|
-
opts.add_option("-t", "--time",
|
|
139
|
-
type="float", dest="time", default=None,
|
|
140
|
-
help="time to write one byte on serial port (in us)")
|
|
141
|
-
options, args = opts.parse_args()
|
|
142
|
-
serialport = 0
|
|
143
|
-
baud = 115200
|
|
144
|
-
if len(args) > 2:
|
|
145
|
-
opts.error("Too many arguments")
|
|
146
|
-
if len(args) > 0:
|
|
147
|
-
serialport = args[0]
|
|
148
|
-
if len(args) > 1:
|
|
149
|
-
baud = int(args[1])
|
|
150
|
-
byteadjust = float(BITSPERBYTE) / baud
|
|
151
|
-
if options.time is not None:
|
|
152
|
-
byteadjust = options.time / 1000000.0
|
|
153
|
-
if not options.adjustbaud:
|
|
154
|
-
byteadjust = 0.0
|
|
155
|
-
|
|
156
|
-
if options.serial:
|
|
157
|
-
# Read from serial port
|
|
158
|
-
try:
|
|
159
|
-
import serial
|
|
160
|
-
except ImportError:
|
|
161
|
-
print("""
|
|
162
|
-
Unable to find pyserial package ( http://pyserial.sourceforge.net/ ).
|
|
163
|
-
On Linux machines try: yum install pyserial
|
|
164
|
-
Or: apt-get install python-serial
|
|
165
|
-
""")
|
|
166
|
-
sys.exit(1)
|
|
167
|
-
ser = serial.Serial(serialport, baud, timeout=0)
|
|
168
|
-
|
|
169
|
-
if options.calibrate_read:
|
|
170
|
-
calibrateserialread(ser, byteadjust)
|
|
171
|
-
return
|
|
172
|
-
if options.calibrate_write:
|
|
173
|
-
calibrateserialwrite(ser, byteadjust)
|
|
174
|
-
return
|
|
175
|
-
|
|
176
|
-
logname = time.strftime("seriallog-%Y%m%d_%H%M%S.log")
|
|
177
|
-
f = open(logname, 'wb')
|
|
178
|
-
if options.serial:
|
|
179
|
-
readserial(ser, f, byteadjust)
|
|
180
|
-
else:
|
|
181
|
-
# Read from a pipe
|
|
182
|
-
while 1:
|
|
183
|
-
ser = os.fdopen(os.open(serialport, os.O_RDONLY|os.O_NONBLOCK), 'rb')
|
|
184
|
-
res = readserial(ser, f, byteadjust)
|
|
185
|
-
ser.close()
|
|
186
|
-
if res < 0:
|
|
187
|
-
break
|
|
188
|
-
|
|
189
|
-
if __name__ == '__main__':
|
|
190
|
-
main()
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
#!/bin/sh
|
|
2
|
-
#
|
|
3
|
-
# Script to create seabios release and snapshot tarballs.
|
|
4
|
-
# Accepts conmmit (hash, tag, branch, ...) as first argument,
|
|
5
|
-
# uses HEAD if unspecified.
|
|
6
|
-
#
|
|
7
|
-
|
|
8
|
-
commit="${1-HEAD}"
|
|
9
|
-
|
|
10
|
-
# figure name for the tarball
|
|
11
|
-
reltag="$(git describe --tags --match 'rel-*' --exact $commit 2>/dev/null)"
|
|
12
|
-
if test "$reltag" != ""; then
|
|
13
|
-
# release
|
|
14
|
-
name="${reltag#rel-}"
|
|
15
|
-
else
|
|
16
|
-
# snapshot
|
|
17
|
-
reltag="$(git describe --tags --match 'rel-*' $commit 2>/dev/null)"
|
|
18
|
-
name="snap-${reltag#rel-}"
|
|
19
|
-
fi
|
|
20
|
-
|
|
21
|
-
# export tarball archive from git
|
|
22
|
-
prefix="seabios-${name}/"
|
|
23
|
-
output="seabios-${name}.tar"
|
|
24
|
-
echo "# commit $commit -> tarball: ${output}.gz"
|
|
25
|
-
rm -f "$output" "${output}.gz"
|
|
26
|
-
git archive --format=tar --prefix="$prefix" "$commit" > "$output"
|
|
27
|
-
|
|
28
|
-
# add .version file to tarball
|
|
29
|
-
dotver="$(mktemp dotver.XXXXXX)"
|
|
30
|
-
echo "$name" > "$dotver"
|
|
31
|
-
tar --append --file="$output" --owner=root --group=root --mode=0664 \
|
|
32
|
-
--transform "s:${dotver}:${prefix}.version:" "$dotver"
|
|
33
|
-
rm -f "$dotver"
|
|
34
|
-
|
|
35
|
-
# finally compress it
|
|
36
|
-
gzip "$output"
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
#!/bin/sh
|
|
2
|
-
# Script to test if the build works properly.
|
|
3
|
-
|
|
4
|
-
mkdir -p ${OUT}
|
|
5
|
-
TMPFILE1=${OUT}/tmp_testcompile1.c
|
|
6
|
-
TMPFILE1o=${OUT}/tmp_testcompile1.o
|
|
7
|
-
TMPFILE1_ld=${OUT}/tmp_testcompile1.lds
|
|
8
|
-
TMPFILE2=${OUT}/tmp_testcompile2.c
|
|
9
|
-
TMPFILE2o=${OUT}/tmp_testcompile2.o
|
|
10
|
-
TMPFILE3o=${OUT}/tmp_testcompile3.o
|
|
11
|
-
|
|
12
|
-
# Test if ld's alignment handling is correct. This is a known problem
|
|
13
|
-
# with the linker that ships with Ubuntu 11.04.
|
|
14
|
-
cat - > $TMPFILE1 <<EOF
|
|
15
|
-
const char v1[] __attribute__((section(".text.v1"))) = "0123456789";
|
|
16
|
-
const char v2[] __attribute__((section(".text.v2"))) = "0123456789";
|
|
17
|
-
EOF
|
|
18
|
-
cat - > $TMPFILE1_ld <<EOF
|
|
19
|
-
SECTIONS
|
|
20
|
-
{
|
|
21
|
-
.mysection 0x88f0 : {
|
|
22
|
-
. = 0x10 ;
|
|
23
|
-
*(.text.v1)
|
|
24
|
-
. = 0x20 ;
|
|
25
|
-
*(.text.v2)
|
|
26
|
-
. = 0x30 ;
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
EOF
|
|
30
|
-
$CC -O -g -c $TMPFILE1 -o $TMPFILE1o > /dev/null 2>&1
|
|
31
|
-
if [ $? -ne 0 ]; then
|
|
32
|
-
echo "Unable to execute the C compiler ($CC)." >&2
|
|
33
|
-
echo "" >&2
|
|
34
|
-
echo "Please install a working compiler and retry." >&2
|
|
35
|
-
echo -1
|
|
36
|
-
exit 0
|
|
37
|
-
fi
|
|
38
|
-
$LD -T $TMPFILE1_ld $TMPFILE1o -o $TMPFILE2o > /dev/null 2>&1
|
|
39
|
-
if [ $? -ne 0 ]; then
|
|
40
|
-
echo "The version of LD on this system ($LD) does not properly handle" >&2
|
|
41
|
-
echo "alignments. As a result, this project can not be built." >&2
|
|
42
|
-
echo "" >&2
|
|
43
|
-
echo "The problem may be the result of this LD bug report:" >&2
|
|
44
|
-
echo " http://sourceware.org/bugzilla/show_bug.cgi?id=12726" >&2
|
|
45
|
-
echo "" >&2
|
|
46
|
-
echo "Please update to a working version of binutils and retry." >&2
|
|
47
|
-
echo -1
|
|
48
|
-
exit 0
|
|
49
|
-
fi
|
|
50
|
-
|
|
51
|
-
# Test for "-fwhole-program". Older versions of gcc (pre v4.1) don't
|
|
52
|
-
# support the whole-program optimization - detect that.
|
|
53
|
-
$CC -fwhole-program -S -o /dev/null -xc /dev/null > /dev/null 2>&1
|
|
54
|
-
if [ $? -ne 0 ]; then
|
|
55
|
-
echo " Working around no -fwhole-program" >&2
|
|
56
|
-
echo 2
|
|
57
|
-
exit 0
|
|
58
|
-
fi
|
|
59
|
-
|
|
60
|
-
# Test if "visible" variables and functions are marked global. On
|
|
61
|
-
# OpenSuse 10.3 "visible" variables declared with "extern" first
|
|
62
|
-
# aren't marked as global in the resulting assembler. On Ubuntu 7.10
|
|
63
|
-
# "visible" functions aren't marked as global in the resulting
|
|
64
|
-
# assembler.
|
|
65
|
-
cat - > $TMPFILE1 <<EOF
|
|
66
|
-
void __attribute__((externally_visible)) t1() { }
|
|
67
|
-
extern unsigned char v1;
|
|
68
|
-
unsigned char v1 __attribute__((section(".data16.foo.19"))) __attribute__((externally_visible));
|
|
69
|
-
EOF
|
|
70
|
-
$CC -Os -c -fwhole-program $TMPFILE1 -o $TMPFILE1o > /dev/null 2>&1
|
|
71
|
-
cat - > $TMPFILE2 <<EOF
|
|
72
|
-
void t1();
|
|
73
|
-
extern unsigned char v1;
|
|
74
|
-
int __attribute__((externally_visible)) main() { t1(); return v1; }
|
|
75
|
-
EOF
|
|
76
|
-
$CC -Os -c -fwhole-program $TMPFILE2 -o $TMPFILE2o > /dev/null 2>&1
|
|
77
|
-
$CC -nostdlib -Os $TMPFILE1o $TMPFILE2o -o $TMPFILE3o > /dev/null 2>&1
|
|
78
|
-
if [ $? -ne 0 ]; then
|
|
79
|
-
echo " Working around non-functional -fwhole-program" >&2
|
|
80
|
-
echo 2
|
|
81
|
-
exit 0
|
|
82
|
-
fi
|
|
83
|
-
|
|
84
|
-
echo 0
|
|
85
|
-
|
|
86
|
-
# Also, the Ubuntu 8.04 compiler has a bug causing corruption when the
|
|
87
|
-
# "ebp" register is clobberred in an "asm" statement. The code has
|
|
88
|
-
# been modified to not clobber "ebp" - no test is available yet.
|
|
89
|
-
|
|
90
|
-
rm -f $TMPFILE1 $TMPFILE1o $TMPFILE1_ld $TMPFILE2 $TMPFILE2o $TMPFILE3o
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python
|
|
2
|
-
|
|
3
|
-
# This script is useful for taking the output of memdump() and
|
|
4
|
-
# converting it back into binary output. This can be useful, for
|
|
5
|
-
# example, when one wants to push that data into other tools like
|
|
6
|
-
# objdump or hexdump.
|
|
7
|
-
#
|
|
8
|
-
# (C) Copyright 2010 Kevin O'Connor <kevin@koconnor.net>
|
|
9
|
-
#
|
|
10
|
-
# This file may be distributed under the terms of the GNU GPLv3 license.
|
|
11
|
-
|
|
12
|
-
import sys
|
|
13
|
-
import struct
|
|
14
|
-
|
|
15
|
-
def unhex(str):
|
|
16
|
-
return int(str, 16)
|
|
17
|
-
|
|
18
|
-
def parseMem(filehdl):
|
|
19
|
-
mem = []
|
|
20
|
-
for line in filehdl:
|
|
21
|
-
parts = line.split(':')
|
|
22
|
-
if len(parts) < 2:
|
|
23
|
-
continue
|
|
24
|
-
try:
|
|
25
|
-
vaddr = unhex(parts[0])
|
|
26
|
-
parts = parts[1].split()
|
|
27
|
-
mem.extend([unhex(v) for v in parts])
|
|
28
|
-
except ValueError:
|
|
29
|
-
continue
|
|
30
|
-
return mem
|
|
31
|
-
|
|
32
|
-
def printUsage():
|
|
33
|
-
sys.stderr.write("Usage:\n %s <file | ->\n"
|
|
34
|
-
% (sys.argv[0],))
|
|
35
|
-
sys.exit(1)
|
|
36
|
-
|
|
37
|
-
def main():
|
|
38
|
-
if len(sys.argv) != 2:
|
|
39
|
-
printUsage()
|
|
40
|
-
filename = sys.argv[1]
|
|
41
|
-
if filename == '-':
|
|
42
|
-
filehdl = sys.stdin
|
|
43
|
-
else:
|
|
44
|
-
filehdl = open(filename, 'r')
|
|
45
|
-
mem = parseMem(filehdl)
|
|
46
|
-
for i in mem:
|
|
47
|
-
if (sys.version_info > (3, 0)):
|
|
48
|
-
sys.stdout.buffer.write(struct.pack("<I", i))
|
|
49
|
-
else:
|
|
50
|
-
sys.stdout.write(struct.pack("<I", i))
|
|
51
|
-
|
|
52
|
-
if __name__ == '__main__':
|
|
53
|
-
main()
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env python
|
|
2
|
-
# Work around x86emu bugs by replacing problematic instructions.
|
|
3
|
-
#
|
|
4
|
-
# Copyright (C) 2012 Kevin O'Connor <kevin@koconnor.net>
|
|
5
|
-
#
|
|
6
|
-
# This file may be distributed under the terms of the GNU GPLv3 license.
|
|
7
|
-
|
|
8
|
-
# The x86emu code widely used in Linux distributions when running Xorg
|
|
9
|
-
# in vesamode is known to have issues with "retl", "leavel", "entryl",
|
|
10
|
-
# "leal", and some variants of "calll". This code modifies those
|
|
11
|
-
# instructions that are known to be generated by gcc to avoid
|
|
12
|
-
# triggering the x86emu bugs.
|
|
13
|
-
|
|
14
|
-
# It is also known that the Windows vgabios emulator has issues with
|
|
15
|
-
# addressing negative offsets to the %esp register. That has been
|
|
16
|
-
# worked around by not using the gcc parameter "-fomit-frame-pointer"
|
|
17
|
-
# when compiling.
|
|
18
|
-
|
|
19
|
-
import sys, re
|
|
20
|
-
|
|
21
|
-
# leal parameter regex - example string: -3(%edx,%eax,8), %eax
|
|
22
|
-
re_leal = re.compile(
|
|
23
|
-
r'^\s*(?P<offset>[^(]*?)\s*'
|
|
24
|
-
r'\(\s*(?P<base>[^,)]*?)\s*(?:,\s*(?P<index>[^,)]*?)\s*)?'
|
|
25
|
-
r'(?:,\s*(?P<scale>[^,)]*?)\s*)?\)\s*'
|
|
26
|
-
r',\s*(?P<dest>.*?)\s*$')
|
|
27
|
-
|
|
28
|
-
# Find an alternate set of instructions for a given "leal" instruction
|
|
29
|
-
def handle_leal(sline):
|
|
30
|
-
m = re_leal.match(sline[5:])
|
|
31
|
-
if m is None or m.group('index') == '%esp':
|
|
32
|
-
print("Unable to fixup leal instruction: %s" % (sline,))
|
|
33
|
-
sys.exit(-1)
|
|
34
|
-
offset, base, index, scale, dest = m.group(
|
|
35
|
-
'offset', 'base', 'index', 'scale', 'dest')
|
|
36
|
-
if dest == '%esp':
|
|
37
|
-
# If destination is %esp then just use 16bit leaw instead
|
|
38
|
-
return 'leaw %s\n' % (sline[5:].replace('%e', '%'),)
|
|
39
|
-
if not scale:
|
|
40
|
-
scale = '1'
|
|
41
|
-
scale = {1: 0, 2: 1, 4: 2, 8: 3}[int(scale, 0)]
|
|
42
|
-
# Try to rearrange arguments to simplify 'base' (to improve code gen)
|
|
43
|
-
if not scale and base == index:
|
|
44
|
-
base, index, scale = '', index, 1
|
|
45
|
-
elif not index or (not scale and base in (dest, '%esp') and index != dest):
|
|
46
|
-
base, index, scale = index, base, 0
|
|
47
|
-
# Produce instructions to calculate "leal"
|
|
48
|
-
insns = ['pushfw']
|
|
49
|
-
if base != dest:
|
|
50
|
-
# Calculate "leal" directly in dest register
|
|
51
|
-
if index != dest:
|
|
52
|
-
insns.insert(0, 'movl %s, %s' % (index, dest))
|
|
53
|
-
if scale:
|
|
54
|
-
insns.append('shll $%d, %s' % (scale, dest))
|
|
55
|
-
if base:
|
|
56
|
-
if base == '%esp':
|
|
57
|
-
offset += '+2'
|
|
58
|
-
insns.append('addl %s, %s' % (base, dest))
|
|
59
|
-
elif base == index:
|
|
60
|
-
# Use "imull" method
|
|
61
|
-
insns.append('imull $%d, %s' % ((1<<scale)+1, dest))
|
|
62
|
-
else:
|
|
63
|
-
# Backup/restore index register and do scaling in index register
|
|
64
|
-
insns.append('pushl %s' % (index,))
|
|
65
|
-
insns.append('shll $%d, %s' % (scale, index))
|
|
66
|
-
insns.append('addl %s, %s' % (index, dest))
|
|
67
|
-
insns.append('popl %s' % (index,))
|
|
68
|
-
if offset and offset != '0':
|
|
69
|
-
insns.append('addl $%s, %s' % (offset, dest))
|
|
70
|
-
insns.append('popfw\n')
|
|
71
|
-
return ' ; '.join(insns)
|
|
72
|
-
|
|
73
|
-
def main():
|
|
74
|
-
infilename, outfilename = sys.argv[1:]
|
|
75
|
-
infile = open(infilename, 'r')
|
|
76
|
-
out = []
|
|
77
|
-
for line in infile:
|
|
78
|
-
sline = line.strip()
|
|
79
|
-
if sline == 'ret':
|
|
80
|
-
out.append('retw $2\n')
|
|
81
|
-
elif sline == 'leave':
|
|
82
|
-
out.append('movl %ebp, %esp ; popl %ebp\n')
|
|
83
|
-
elif sline.startswith('call'):
|
|
84
|
-
out.append('pushw %ax ; callw' + sline[4:] + '\n')
|
|
85
|
-
elif sline.startswith('leal'):
|
|
86
|
-
out.append(handle_leal(sline))
|
|
87
|
-
#print("-> %s\n %s" % (sline, out[-1].strip()))
|
|
88
|
-
else:
|
|
89
|
-
out.append(line)
|
|
90
|
-
infile.close()
|
|
91
|
-
outfile = open(outfilename, 'w')
|
|
92
|
-
outfile.write(''.join(out))
|
|
93
|
-
outfile.close()
|
|
94
|
-
|
|
95
|
-
if __name__ == '__main__':
|
|
96
|
-
main()
|