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,584 +0,0 @@
|
|
|
1
|
-
// Raw screen writing and debug output code.
|
|
2
|
-
//
|
|
3
|
-
// Copyright (C) 2008-2013 Kevin O'Connor <kevin@koconnor.net>
|
|
4
|
-
//
|
|
5
|
-
// This file may be distributed under the terms of the GNU LGPLv3 license.
|
|
6
|
-
|
|
7
|
-
#include <stdarg.h> // va_list
|
|
8
|
-
|
|
9
|
-
#include "farptr.h" // GET_VAR
|
|
10
|
-
#include "bregs.h" // struct bregs
|
|
11
|
-
#include "config.h" // CONFIG_*
|
|
12
|
-
#include "biosvar.h" // GET_GLOBAL
|
|
13
|
-
#include "hw/pci.h" // pci_bdf_to_bus
|
|
14
|
-
#include "hw/pcidevice.h" // pci_device
|
|
15
|
-
#include "hw/serialio.h" // serial_debug_putc
|
|
16
|
-
#include "malloc.h" // malloc_tmp
|
|
17
|
-
#include "output.h" // dprintf
|
|
18
|
-
#include "stacks.h" // call16_int
|
|
19
|
-
#include "string.h" // memset
|
|
20
|
-
#include "util.h" // ScreenAndDebug
|
|
21
|
-
|
|
22
|
-
struct putcinfo {
|
|
23
|
-
void (*func)(struct putcinfo *info, char c);
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
/****************************************************************
|
|
28
|
-
* Debug output
|
|
29
|
-
****************************************************************/
|
|
30
|
-
|
|
31
|
-
void
|
|
32
|
-
debug_banner(void)
|
|
33
|
-
{
|
|
34
|
-
dprintf(1, "SeaBIOS (version %s)\n", VERSION);
|
|
35
|
-
dprintf(1, "BUILD: %s\n", BUILDINFO);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
// Write a character to debug port(s).
|
|
39
|
-
static void
|
|
40
|
-
debug_putc(struct putcinfo *action, char c)
|
|
41
|
-
{
|
|
42
|
-
if (! CONFIG_DEBUG_LEVEL)
|
|
43
|
-
return;
|
|
44
|
-
qemu_debug_putc(c);
|
|
45
|
-
if (!MODESEGMENT)
|
|
46
|
-
coreboot_debug_putc(c);
|
|
47
|
-
serial_debug_putc(c);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
// Flush any pending output to debug port(s).
|
|
51
|
-
static void
|
|
52
|
-
debug_flush(void)
|
|
53
|
-
{
|
|
54
|
-
serial_debug_flush();
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
// In segmented mode just need a dummy variable (debug_putc is always
|
|
58
|
-
// used anyway), and in 32bit flat mode need a pointer to the 32bit
|
|
59
|
-
// instance of debug_putc().
|
|
60
|
-
#if MODE16
|
|
61
|
-
static struct putcinfo debuginfo VAR16;
|
|
62
|
-
#elif MODESEGMENT
|
|
63
|
-
static struct putcinfo debuginfo VAR32SEG;
|
|
64
|
-
#else
|
|
65
|
-
static struct putcinfo debuginfo = { debug_putc };
|
|
66
|
-
#endif
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
/****************************************************************
|
|
70
|
-
* Screen writing
|
|
71
|
-
****************************************************************/
|
|
72
|
-
|
|
73
|
-
// Show a character on the screen.
|
|
74
|
-
static void
|
|
75
|
-
screenc(char c)
|
|
76
|
-
{
|
|
77
|
-
struct bregs br;
|
|
78
|
-
memset(&br, 0, sizeof(br));
|
|
79
|
-
br.flags = F_IF;
|
|
80
|
-
br.ah = 0x0e;
|
|
81
|
-
br.al = c;
|
|
82
|
-
br.bl = 0x07;
|
|
83
|
-
call16_int(0x10, &br);
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
// Handle a character from a printf request.
|
|
87
|
-
static void
|
|
88
|
-
screen_putc(struct putcinfo *action, char c)
|
|
89
|
-
{
|
|
90
|
-
if (ScreenAndDebug)
|
|
91
|
-
debug_putc(&debuginfo, c);
|
|
92
|
-
if (c == '\n')
|
|
93
|
-
screenc('\r');
|
|
94
|
-
screenc(c);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
static struct putcinfo screeninfo = { screen_putc };
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
/****************************************************************
|
|
101
|
-
* Xprintf code
|
|
102
|
-
****************************************************************/
|
|
103
|
-
|
|
104
|
-
// Output a character.
|
|
105
|
-
static void
|
|
106
|
-
putc(struct putcinfo *action, char c)
|
|
107
|
-
{
|
|
108
|
-
if (MODESEGMENT) {
|
|
109
|
-
// Only debugging output supported in segmented mode.
|
|
110
|
-
debug_putc(action, c);
|
|
111
|
-
return;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
void (*func)(struct putcinfo *info, char c) = GET_GLOBAL(action->func);
|
|
115
|
-
func(action, c);
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
// Ouptut a string.
|
|
119
|
-
static void
|
|
120
|
-
puts(struct putcinfo *action, const char *s)
|
|
121
|
-
{
|
|
122
|
-
if (!MODESEGMENT && !s)
|
|
123
|
-
s = "(NULL)";
|
|
124
|
-
for (; *s; s++)
|
|
125
|
-
putc(action, *s);
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
// Output a string that is in the CS segment.
|
|
129
|
-
static void
|
|
130
|
-
puts_cs(struct putcinfo *action, const char *s)
|
|
131
|
-
{
|
|
132
|
-
char *vs = (char*)s;
|
|
133
|
-
for (;; vs++) {
|
|
134
|
-
char c = GET_GLOBAL(*vs);
|
|
135
|
-
if (!c)
|
|
136
|
-
break;
|
|
137
|
-
putc(action, c);
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
// Output an unsigned integer.
|
|
142
|
-
static void
|
|
143
|
-
putuint(struct putcinfo *action, u32 val)
|
|
144
|
-
{
|
|
145
|
-
char buf[12];
|
|
146
|
-
char *d = &buf[sizeof(buf) - 1];
|
|
147
|
-
*d-- = '\0';
|
|
148
|
-
for (;;) {
|
|
149
|
-
*d = (val % 10) + '0';
|
|
150
|
-
val /= 10;
|
|
151
|
-
if (!val)
|
|
152
|
-
break;
|
|
153
|
-
d--;
|
|
154
|
-
}
|
|
155
|
-
puts(action, d);
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
// Output a single digit hex character.
|
|
159
|
-
static inline void
|
|
160
|
-
putsinglehex(struct putcinfo *action, u32 val)
|
|
161
|
-
{
|
|
162
|
-
if (val <= 9)
|
|
163
|
-
val = '0' + val;
|
|
164
|
-
else
|
|
165
|
-
val = 'a' + val - 10;
|
|
166
|
-
putc(action, val);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
// Output an integer in hexadecimal with a specified width.
|
|
170
|
-
static void
|
|
171
|
-
puthex(struct putcinfo *action, u32 val, int width)
|
|
172
|
-
{
|
|
173
|
-
switch (width) {
|
|
174
|
-
default: putsinglehex(action, (val >> 28) & 0xf);
|
|
175
|
-
case 7: putsinglehex(action, (val >> 24) & 0xf);
|
|
176
|
-
case 6: putsinglehex(action, (val >> 20) & 0xf);
|
|
177
|
-
case 5: putsinglehex(action, (val >> 16) & 0xf);
|
|
178
|
-
case 4: putsinglehex(action, (val >> 12) & 0xf);
|
|
179
|
-
case 3: putsinglehex(action, (val >> 8) & 0xf);
|
|
180
|
-
case 2: putsinglehex(action, (val >> 4) & 0xf);
|
|
181
|
-
case 1: putsinglehex(action, (val >> 0) & 0xf);
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
|
|
185
|
-
// Output an integer in hexadecimal with a minimum width.
|
|
186
|
-
static void
|
|
187
|
-
putprettyhex(struct putcinfo *action, u32 val, int width, char padchar)
|
|
188
|
-
{
|
|
189
|
-
u32 tmp = val;
|
|
190
|
-
int count = 1;
|
|
191
|
-
while (tmp >>= 4)
|
|
192
|
-
count++;
|
|
193
|
-
width -= count;
|
|
194
|
-
while (width-- > 0)
|
|
195
|
-
putc(action, padchar);
|
|
196
|
-
puthex(action, val, count);
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
// Output 'struct pci_device' BDF as %02x:%02x.%x
|
|
200
|
-
static void
|
|
201
|
-
put_pci_device(struct putcinfo *action, struct pci_device *pci)
|
|
202
|
-
{
|
|
203
|
-
puthex(action, pci_bdf_to_bus(pci->bdf), 2);
|
|
204
|
-
putc(action, ':');
|
|
205
|
-
puthex(action, pci_bdf_to_dev(pci->bdf), 2);
|
|
206
|
-
putc(action, '.');
|
|
207
|
-
puthex(action, pci_bdf_to_fn(pci->bdf), 1);
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
static inline int
|
|
211
|
-
isdigit(u8 c)
|
|
212
|
-
{
|
|
213
|
-
return ((u8)(c - '0')) < 10;
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
static void
|
|
217
|
-
bvprintf(struct putcinfo *action, const char *fmt, va_list args)
|
|
218
|
-
{
|
|
219
|
-
const char *s = fmt;
|
|
220
|
-
for (;; s++) {
|
|
221
|
-
char c = GET_GLOBAL(*(u8*)s);
|
|
222
|
-
if (!c)
|
|
223
|
-
break;
|
|
224
|
-
if (c != '%') {
|
|
225
|
-
putc(action, c);
|
|
226
|
-
continue;
|
|
227
|
-
}
|
|
228
|
-
const char *n = s+1;
|
|
229
|
-
int field_width = 0;
|
|
230
|
-
char padchar = ' ';
|
|
231
|
-
u8 is64 = 0;
|
|
232
|
-
for (;;) {
|
|
233
|
-
c = GET_GLOBAL(*(u8*)n);
|
|
234
|
-
if (!isdigit(c))
|
|
235
|
-
break;
|
|
236
|
-
if (!field_width && (c == '0'))
|
|
237
|
-
padchar = '0';
|
|
238
|
-
else
|
|
239
|
-
field_width = field_width * 10 + c - '0';
|
|
240
|
-
n++;
|
|
241
|
-
}
|
|
242
|
-
if (c == 'l') {
|
|
243
|
-
// Ignore long format indicator
|
|
244
|
-
n++;
|
|
245
|
-
c = GET_GLOBAL(*(u8*)n);
|
|
246
|
-
}
|
|
247
|
-
if (c == 'l') {
|
|
248
|
-
is64 = 1;
|
|
249
|
-
n++;
|
|
250
|
-
c = GET_GLOBAL(*(u8*)n);
|
|
251
|
-
}
|
|
252
|
-
s32 val;
|
|
253
|
-
const char *sarg;
|
|
254
|
-
switch (c) {
|
|
255
|
-
case '%':
|
|
256
|
-
putc(action, '%');
|
|
257
|
-
break;
|
|
258
|
-
case 'd':
|
|
259
|
-
val = va_arg(args, s32);
|
|
260
|
-
if (is64)
|
|
261
|
-
va_arg(args, s32);
|
|
262
|
-
if (val < 0) {
|
|
263
|
-
putc(action, '-');
|
|
264
|
-
val = -val;
|
|
265
|
-
}
|
|
266
|
-
putuint(action, val);
|
|
267
|
-
break;
|
|
268
|
-
case 'u':
|
|
269
|
-
val = va_arg(args, s32);
|
|
270
|
-
if (is64)
|
|
271
|
-
va_arg(args, s32);
|
|
272
|
-
putuint(action, val);
|
|
273
|
-
break;
|
|
274
|
-
case 'p':
|
|
275
|
-
val = va_arg(args, s32);
|
|
276
|
-
if (!MODESEGMENT && GET_GLOBAL(*(u8*)(n+1)) == 'P') {
|
|
277
|
-
// %pP is 'struct pci_device' printer
|
|
278
|
-
put_pci_device(action, (void*)val);
|
|
279
|
-
n++;
|
|
280
|
-
break;
|
|
281
|
-
}
|
|
282
|
-
putc(action, '0');
|
|
283
|
-
putc(action, 'x');
|
|
284
|
-
puthex(action, val, 8);
|
|
285
|
-
break;
|
|
286
|
-
case 'x':
|
|
287
|
-
val = va_arg(args, s32);
|
|
288
|
-
if (is64) {
|
|
289
|
-
u32 upper = va_arg(args, s32);
|
|
290
|
-
if (upper) {
|
|
291
|
-
putprettyhex(action, upper, field_width - 8, padchar);
|
|
292
|
-
puthex(action, val, 8);
|
|
293
|
-
break;
|
|
294
|
-
}
|
|
295
|
-
}
|
|
296
|
-
putprettyhex(action, val, field_width, padchar);
|
|
297
|
-
break;
|
|
298
|
-
case 'c':
|
|
299
|
-
val = va_arg(args, int);
|
|
300
|
-
putc(action, val);
|
|
301
|
-
break;
|
|
302
|
-
case '.':
|
|
303
|
-
// Hack to support "%.s" - meaning string on stack.
|
|
304
|
-
if (GET_GLOBAL(*(u8*)(n+1)) != 's')
|
|
305
|
-
break;
|
|
306
|
-
n++;
|
|
307
|
-
sarg = va_arg(args, const char *);
|
|
308
|
-
puts(action, sarg);
|
|
309
|
-
break;
|
|
310
|
-
case 's':
|
|
311
|
-
sarg = va_arg(args, const char *);
|
|
312
|
-
puts_cs(action, sarg);
|
|
313
|
-
break;
|
|
314
|
-
default:
|
|
315
|
-
putc(action, '%');
|
|
316
|
-
n = s;
|
|
317
|
-
}
|
|
318
|
-
s = n;
|
|
319
|
-
}
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
void
|
|
323
|
-
panic(const char *fmt, ...)
|
|
324
|
-
{
|
|
325
|
-
if (CONFIG_DEBUG_LEVEL) {
|
|
326
|
-
va_list args;
|
|
327
|
-
va_start(args, fmt);
|
|
328
|
-
bvprintf(&debuginfo, fmt, args);
|
|
329
|
-
va_end(args);
|
|
330
|
-
debug_flush();
|
|
331
|
-
}
|
|
332
|
-
|
|
333
|
-
// XXX - use PANIC PORT.
|
|
334
|
-
irq_disable();
|
|
335
|
-
for (;;)
|
|
336
|
-
hlt();
|
|
337
|
-
}
|
|
338
|
-
|
|
339
|
-
void
|
|
340
|
-
__dprintf(const char *fmt, ...)
|
|
341
|
-
{
|
|
342
|
-
if (!MODESEGMENT && CONFIG_THREADS && CONFIG_DEBUG_LEVEL >= DEBUG_thread
|
|
343
|
-
&& *fmt != '\\' && *fmt != '/') {
|
|
344
|
-
struct thread_info *cur = getCurThread();
|
|
345
|
-
if (cur != &MainThread) {
|
|
346
|
-
// Show "thread id" for this debug message.
|
|
347
|
-
debug_putc(&debuginfo, '|');
|
|
348
|
-
puthex(&debuginfo, (u32)cur, 8);
|
|
349
|
-
debug_putc(&debuginfo, '|');
|
|
350
|
-
debug_putc(&debuginfo, ' ');
|
|
351
|
-
}
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
va_list args;
|
|
355
|
-
va_start(args, fmt);
|
|
356
|
-
bvprintf(&debuginfo, fmt, args);
|
|
357
|
-
va_end(args);
|
|
358
|
-
debug_flush();
|
|
359
|
-
}
|
|
360
|
-
|
|
361
|
-
void
|
|
362
|
-
printf(const char *fmt, ...)
|
|
363
|
-
{
|
|
364
|
-
ASSERT32FLAT();
|
|
365
|
-
va_list args;
|
|
366
|
-
va_start(args, fmt);
|
|
367
|
-
bvprintf(&screeninfo, fmt, args);
|
|
368
|
-
va_end(args);
|
|
369
|
-
if (ScreenAndDebug)
|
|
370
|
-
debug_flush();
|
|
371
|
-
}
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
/****************************************************************
|
|
375
|
-
* snprintf
|
|
376
|
-
****************************************************************/
|
|
377
|
-
|
|
378
|
-
struct snprintfinfo {
|
|
379
|
-
struct putcinfo info;
|
|
380
|
-
char *str, *end;
|
|
381
|
-
};
|
|
382
|
-
|
|
383
|
-
static void
|
|
384
|
-
putc_str(struct putcinfo *info, char c)
|
|
385
|
-
{
|
|
386
|
-
struct snprintfinfo *sinfo = container_of(info, struct snprintfinfo, info);
|
|
387
|
-
if (sinfo->str >= sinfo->end)
|
|
388
|
-
return;
|
|
389
|
-
*sinfo->str = c;
|
|
390
|
-
sinfo->str++;
|
|
391
|
-
}
|
|
392
|
-
|
|
393
|
-
// Build a formatted string. Note, this function returns the actual
|
|
394
|
-
// number of bytes used (not including null) even in the overflow
|
|
395
|
-
// case.
|
|
396
|
-
int
|
|
397
|
-
snprintf(char *str, size_t size, const char *fmt, ...)
|
|
398
|
-
{
|
|
399
|
-
ASSERT32FLAT();
|
|
400
|
-
if (!size)
|
|
401
|
-
return 0;
|
|
402
|
-
struct snprintfinfo sinfo = { { putc_str }, str, str + size };
|
|
403
|
-
va_list args;
|
|
404
|
-
va_start(args, fmt);
|
|
405
|
-
bvprintf(&sinfo.info, fmt, args);
|
|
406
|
-
va_end(args);
|
|
407
|
-
char *end = sinfo.str;
|
|
408
|
-
if (end >= sinfo.end)
|
|
409
|
-
end = sinfo.end - 1;
|
|
410
|
-
*end = '\0';
|
|
411
|
-
return end - str;
|
|
412
|
-
}
|
|
413
|
-
|
|
414
|
-
// Build a formatted string - malloc'ing the memory.
|
|
415
|
-
char *
|
|
416
|
-
znprintf(size_t size, const char *fmt, ...)
|
|
417
|
-
{
|
|
418
|
-
ASSERT32FLAT();
|
|
419
|
-
if (!size)
|
|
420
|
-
return NULL;
|
|
421
|
-
char *str = malloc_tmp(size);
|
|
422
|
-
if (!str) {
|
|
423
|
-
warn_noalloc();
|
|
424
|
-
return NULL;
|
|
425
|
-
}
|
|
426
|
-
struct snprintfinfo sinfo = { { putc_str }, str, str + size };
|
|
427
|
-
va_list args;
|
|
428
|
-
va_start(args, fmt);
|
|
429
|
-
bvprintf(&sinfo.info, fmt, args);
|
|
430
|
-
va_end(args);
|
|
431
|
-
char *end = sinfo.str;
|
|
432
|
-
if (end >= sinfo.end)
|
|
433
|
-
end = sinfo.end - 1;
|
|
434
|
-
*end = '\0';
|
|
435
|
-
return str;
|
|
436
|
-
}
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
/****************************************************************
|
|
440
|
-
* Misc helpers
|
|
441
|
-
****************************************************************/
|
|
442
|
-
|
|
443
|
-
void
|
|
444
|
-
hexdump(const void *d, int len)
|
|
445
|
-
{
|
|
446
|
-
int count=0;
|
|
447
|
-
while (len > 0) {
|
|
448
|
-
if (count % 8 == 0) {
|
|
449
|
-
putc(&debuginfo, '\n');
|
|
450
|
-
puthex(&debuginfo, count*4, 8);
|
|
451
|
-
putc(&debuginfo, ':');
|
|
452
|
-
} else {
|
|
453
|
-
putc(&debuginfo, ' ');
|
|
454
|
-
}
|
|
455
|
-
puthex(&debuginfo, *(u32*)d, 8);
|
|
456
|
-
count++;
|
|
457
|
-
len-=4;
|
|
458
|
-
d+=4;
|
|
459
|
-
}
|
|
460
|
-
putc(&debuginfo, '\n');
|
|
461
|
-
debug_flush();
|
|
462
|
-
}
|
|
463
|
-
|
|
464
|
-
static void
|
|
465
|
-
dump_regs(struct bregs *regs)
|
|
466
|
-
{
|
|
467
|
-
if (!regs) {
|
|
468
|
-
dprintf(1, " NULL\n");
|
|
469
|
-
return;
|
|
470
|
-
}
|
|
471
|
-
dprintf(1, " a=%08x b=%08x c=%08x d=%08x ds=%04x es=%04x ss=%04x\n"
|
|
472
|
-
, regs->eax, regs->ebx, regs->ecx, regs->edx
|
|
473
|
-
, regs->ds, regs->es, GET_SEG(SS));
|
|
474
|
-
dprintf(1, " si=%08x di=%08x bp=%08x sp=%08x cs=%04x ip=%04x f=%04x\n"
|
|
475
|
-
, regs->esi, regs->edi, regs->ebp, (u32)®s[1]
|
|
476
|
-
, regs->code.seg, regs->code.offset, regs->flags);
|
|
477
|
-
}
|
|
478
|
-
|
|
479
|
-
// Report entry to an Interrupt Service Routine (ISR).
|
|
480
|
-
void
|
|
481
|
-
__debug_isr(const char *fname)
|
|
482
|
-
{
|
|
483
|
-
puts_cs(&debuginfo, fname);
|
|
484
|
-
putc(&debuginfo, '\n');
|
|
485
|
-
debug_flush();
|
|
486
|
-
}
|
|
487
|
-
|
|
488
|
-
// Function called on handler startup.
|
|
489
|
-
void
|
|
490
|
-
__debug_enter(struct bregs *regs, const char *fname)
|
|
491
|
-
{
|
|
492
|
-
dprintf(1, "enter %s:\n", fname);
|
|
493
|
-
dump_regs(regs);
|
|
494
|
-
}
|
|
495
|
-
|
|
496
|
-
// Send debugging output info.
|
|
497
|
-
void
|
|
498
|
-
__debug_stub(struct bregs *regs, int lineno, const char *fname)
|
|
499
|
-
{
|
|
500
|
-
dprintf(1, "stub %s:%d:\n", fname, lineno);
|
|
501
|
-
dump_regs(regs);
|
|
502
|
-
}
|
|
503
|
-
|
|
504
|
-
// Report on an invalid parameter.
|
|
505
|
-
void
|
|
506
|
-
__warn_invalid(struct bregs *regs, int lineno, const char *fname)
|
|
507
|
-
{
|
|
508
|
-
if (CONFIG_DEBUG_LEVEL >= DEBUG_invalid) {
|
|
509
|
-
dprintf(1, "invalid %s:%d:\n", fname, lineno);
|
|
510
|
-
dump_regs(regs);
|
|
511
|
-
}
|
|
512
|
-
}
|
|
513
|
-
|
|
514
|
-
// Report on an unimplemented feature.
|
|
515
|
-
void
|
|
516
|
-
__warn_unimplemented(struct bregs *regs, int lineno, const char *fname)
|
|
517
|
-
{
|
|
518
|
-
if (CONFIG_DEBUG_LEVEL >= DEBUG_unimplemented) {
|
|
519
|
-
dprintf(1, "unimplemented %s:%d:\n", fname, lineno);
|
|
520
|
-
dump_regs(regs);
|
|
521
|
-
}
|
|
522
|
-
}
|
|
523
|
-
|
|
524
|
-
// Report a detected internal inconsistency.
|
|
525
|
-
void
|
|
526
|
-
__warn_internalerror(int lineno, const char *fname)
|
|
527
|
-
{
|
|
528
|
-
dprintf(1, "WARNING - internal error detected at %s:%d!\n"
|
|
529
|
-
, fname, lineno);
|
|
530
|
-
}
|
|
531
|
-
|
|
532
|
-
// Report on an allocation failure.
|
|
533
|
-
void
|
|
534
|
-
__warn_noalloc(int lineno, const char *fname)
|
|
535
|
-
{
|
|
536
|
-
dprintf(1, "WARNING - Unable to allocate resource at %s:%d!\n"
|
|
537
|
-
, fname, lineno);
|
|
538
|
-
}
|
|
539
|
-
|
|
540
|
-
// Report on a timeout exceeded.
|
|
541
|
-
void
|
|
542
|
-
__warn_timeout(int lineno, const char *fname)
|
|
543
|
-
{
|
|
544
|
-
dprintf(1, "WARNING - Timeout at %s:%d!\n", fname, lineno);
|
|
545
|
-
}
|
|
546
|
-
|
|
547
|
-
// Report a handler reporting an invalid parameter to the caller.
|
|
548
|
-
void
|
|
549
|
-
__set_invalid(struct bregs *regs, int lineno, const char *fname)
|
|
550
|
-
{
|
|
551
|
-
__warn_invalid(regs, lineno, fname);
|
|
552
|
-
set_invalid_silent(regs);
|
|
553
|
-
}
|
|
554
|
-
|
|
555
|
-
// Report a call of an unimplemented function.
|
|
556
|
-
void
|
|
557
|
-
__set_unimplemented(struct bregs *regs, int lineno, const char *fname)
|
|
558
|
-
{
|
|
559
|
-
__warn_unimplemented(regs, lineno, fname);
|
|
560
|
-
set_invalid_silent(regs);
|
|
561
|
-
}
|
|
562
|
-
|
|
563
|
-
// Report a handler reporting an invalid parameter code to the
|
|
564
|
-
// caller. Note, the lineno and return code are encoded in the same
|
|
565
|
-
// parameter as gcc does a better job of scheduling function calls
|
|
566
|
-
// when there are 3 or less parameters.
|
|
567
|
-
void
|
|
568
|
-
__set_code_invalid(struct bregs *regs, u32 linecode, const char *fname)
|
|
569
|
-
{
|
|
570
|
-
u8 code = linecode;
|
|
571
|
-
u32 lineno = linecode >> 8;
|
|
572
|
-
__warn_invalid(regs, lineno, fname);
|
|
573
|
-
set_code_invalid_silent(regs, code);
|
|
574
|
-
}
|
|
575
|
-
|
|
576
|
-
// Report a call of an unimplemented function.
|
|
577
|
-
void
|
|
578
|
-
__set_code_unimplemented(struct bregs *regs, u32 linecode, const char *fname)
|
|
579
|
-
{
|
|
580
|
-
u8 code = linecode;
|
|
581
|
-
u32 lineno = linecode >> 8;
|
|
582
|
-
__warn_unimplemented(regs, lineno, fname);
|
|
583
|
-
set_code_invalid_silent(regs, code);
|
|
584
|
-
}
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
#ifndef __OUTPUT_H
|
|
2
|
-
#define __OUTPUT_H
|
|
3
|
-
|
|
4
|
-
#include "config.h" // CONFIG_DEBUG_LEVEL
|
|
5
|
-
#include "types.h" // u32
|
|
6
|
-
|
|
7
|
-
// output.c
|
|
8
|
-
void debug_banner(void);
|
|
9
|
-
void panic(const char *fmt, ...)
|
|
10
|
-
__attribute__ ((format (printf, 1, 2))) __noreturn;
|
|
11
|
-
void printf(const char *fmt, ...)
|
|
12
|
-
__attribute__ ((format (printf, 1, 2)));
|
|
13
|
-
int snprintf(char *str, size_t size, const char *fmt, ...)
|
|
14
|
-
__attribute__ ((format (printf, 3, 4)));
|
|
15
|
-
char * znprintf(size_t size, const char *fmt, ...)
|
|
16
|
-
__attribute__ ((format (printf, 2, 3)));
|
|
17
|
-
void __dprintf(const char *fmt, ...)
|
|
18
|
-
__attribute__ ((format (printf, 1, 2)));
|
|
19
|
-
struct bregs;
|
|
20
|
-
void __debug_enter(struct bregs *regs, const char *fname);
|
|
21
|
-
void __debug_isr(const char *fname);
|
|
22
|
-
void __debug_stub(struct bregs *regs, int lineno, const char *fname);
|
|
23
|
-
void __warn_invalid(struct bregs *regs, int lineno, const char *fname);
|
|
24
|
-
void __warn_unimplemented(struct bregs *regs, int lineno, const char *fname);
|
|
25
|
-
void __warn_internalerror(int lineno, const char *fname);
|
|
26
|
-
void __warn_noalloc(int lineno, const char *fname);
|
|
27
|
-
void __warn_timeout(int lineno, const char *fname);
|
|
28
|
-
void __set_invalid(struct bregs *regs, int lineno, const char *fname);
|
|
29
|
-
void __set_unimplemented(struct bregs *regs, int lineno, const char *fname);
|
|
30
|
-
void __set_code_invalid(struct bregs *regs, u32 linecode, const char *fname);
|
|
31
|
-
void __set_code_unimplemented(struct bregs *regs, u32 linecode
|
|
32
|
-
, const char *fname);
|
|
33
|
-
void hexdump(const void *d, int len);
|
|
34
|
-
|
|
35
|
-
#define dprintf(lvl, fmt, args...) do { \
|
|
36
|
-
if (CONFIG_DEBUG_LEVEL && (lvl) <= CONFIG_DEBUG_LEVEL) \
|
|
37
|
-
__dprintf((fmt) , ##args ); \
|
|
38
|
-
} while (0)
|
|
39
|
-
#define debug_enter(regs, lvl) do { \
|
|
40
|
-
if ((lvl) && (lvl) <= CONFIG_DEBUG_LEVEL) \
|
|
41
|
-
__debug_enter((regs), __func__); \
|
|
42
|
-
} while (0)
|
|
43
|
-
#define debug_isr(lvl) do { \
|
|
44
|
-
if ((lvl) && (lvl) <= CONFIG_DEBUG_LEVEL) \
|
|
45
|
-
__debug_isr(__func__); \
|
|
46
|
-
} while (0)
|
|
47
|
-
#define debug_stub(regs) \
|
|
48
|
-
__debug_stub((regs), __LINE__, __func__)
|
|
49
|
-
#define warn_invalid(regs) \
|
|
50
|
-
__warn_invalid((regs), __LINE__, __func__)
|
|
51
|
-
#define warn_unimplemented(regs) \
|
|
52
|
-
__warn_unimplemented((regs), __LINE__, __func__)
|
|
53
|
-
#define warn_internalerror() \
|
|
54
|
-
__warn_internalerror(__LINE__, __func__)
|
|
55
|
-
#define warn_noalloc() \
|
|
56
|
-
__warn_noalloc(__LINE__, __func__)
|
|
57
|
-
#define warn_timeout() \
|
|
58
|
-
__warn_timeout(__LINE__, __func__)
|
|
59
|
-
#define set_invalid(regs) \
|
|
60
|
-
__set_invalid((regs), __LINE__, __func__)
|
|
61
|
-
#define set_code_invalid(regs, code) \
|
|
62
|
-
__set_code_invalid((regs), (code) | (__LINE__ << 8), __func__)
|
|
63
|
-
#define set_unimplemented(regs) \
|
|
64
|
-
__set_unimplemented((regs), __LINE__, __func__)
|
|
65
|
-
#define set_code_unimplemented(regs, code) \
|
|
66
|
-
__set_code_unimplemented((regs), (code) | (__LINE__ << 8), __func__)
|
|
67
|
-
|
|
68
|
-
#endif // output.h
|