v86 0.3.4 → 0.3.7

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.
Files changed (369) hide show
  1. package/Readme.md +4 -4
  2. package/bios/seabios/.config +113 -0
  3. package/bios/seabios/.config.old +114 -0
  4. package/bios/seabios/.gitignore +4 -0
  5. package/bios/seabios/COPYING +674 -0
  6. package/bios/seabios/COPYING.LESSER +165 -0
  7. package/bios/seabios/Makefile +286 -0
  8. package/bios/seabios/README +17 -0
  9. package/bios/seabios/docs/Build_overview.md +104 -0
  10. package/bios/seabios/docs/Contributing.md +20 -0
  11. package/bios/seabios/docs/Debugging.md +111 -0
  12. package/bios/seabios/docs/Developer_Documentation.md +25 -0
  13. package/bios/seabios/docs/Developer_links.md +86 -0
  14. package/bios/seabios/docs/Download.md +27 -0
  15. package/bios/seabios/docs/Execution_and_code_flow.md +178 -0
  16. package/bios/seabios/docs/Linking_overview.md +160 -0
  17. package/bios/seabios/docs/Mailinglist.md +8 -0
  18. package/bios/seabios/docs/Memory_Model.md +253 -0
  19. package/bios/seabios/docs/README +5 -0
  20. package/bios/seabios/docs/Releases.md +482 -0
  21. package/bios/seabios/docs/Runtime_config.md +193 -0
  22. package/bios/seabios/docs/SeaBIOS.md +17 -0
  23. package/bios/seabios/docs/SeaVGABIOS.md +39 -0
  24. package/bios/seabios/out/autoconf.h +117 -0
  25. package/bios/seabios/out/include/config/acpi/dsdt.h +0 -0
  26. package/bios/seabios/out/include/config/acpi.h +0 -0
  27. package/bios/seabios/out/include/config/ahci.h +0 -0
  28. package/bios/seabios/out/include/config/apmbios.h +0 -0
  29. package/bios/seabios/out/include/config/ata/dma.h +0 -0
  30. package/bios/seabios/out/include/config/ata/pio32.h +0 -0
  31. package/bios/seabios/out/include/config/ata.h +0 -0
  32. package/bios/seabios/out/include/config/auto.conf +69 -0
  33. package/bios/seabios/out/include/config/auto.conf.cmd +9 -0
  34. package/bios/seabios/out/include/config/boot.h +0 -0
  35. package/bios/seabios/out/include/config/bootorder.h +0 -0
  36. package/bios/seabios/out/include/config/build/vgabios.h +0 -0
  37. package/bios/seabios/out/include/config/call32/smm.h +0 -0
  38. package/bios/seabios/out/include/config/cdrom/boot.h +0 -0
  39. package/bios/seabios/out/include/config/cdrom/emu.h +0 -0
  40. package/bios/seabios/out/include/config/debug/level.h +0 -0
  41. package/bios/seabios/out/include/config/drives.h +0 -0
  42. package/bios/seabios/out/include/config/entry/extrastack.h +0 -0
  43. package/bios/seabios/out/include/config/esp/scsi.h +0 -0
  44. package/bios/seabios/out/include/config/flash/floppy.h +0 -0
  45. package/bios/seabios/out/include/config/floppy.h +0 -0
  46. package/bios/seabios/out/include/config/fw/romfile/load.h +0 -0
  47. package/bios/seabios/out/include/config/hardware/irq.h +0 -0
  48. package/bios/seabios/out/include/config/kbd/call/int15/4f.h +0 -0
  49. package/bios/seabios/out/include/config/keyboard.h +0 -0
  50. package/bios/seabios/out/include/config/lpt.h +0 -0
  51. package/bios/seabios/out/include/config/lsi/scsi.h +0 -0
  52. package/bios/seabios/out/include/config/malloc/uppermemory.h +0 -0
  53. package/bios/seabios/out/include/config/megasas.h +0 -0
  54. package/bios/seabios/out/include/config/mouse.h +0 -0
  55. package/bios/seabios/out/include/config/mpt/scsi.h +0 -0
  56. package/bios/seabios/out/include/config/mptable.h +0 -0
  57. package/bios/seabios/out/include/config/mtrr/init.h +0 -0
  58. package/bios/seabios/out/include/config/optionroms.h +0 -0
  59. package/bios/seabios/out/include/config/override/pci/id.h +0 -0
  60. package/bios/seabios/out/include/config/pcibios.h +0 -0
  61. package/bios/seabios/out/include/config/pirtable.h +0 -0
  62. package/bios/seabios/out/include/config/pmm.h +0 -0
  63. package/bios/seabios/out/include/config/pmtimer.h +0 -0
  64. package/bios/seabios/out/include/config/pnpbios.h +0 -0
  65. package/bios/seabios/out/include/config/ps2port.h +0 -0
  66. package/bios/seabios/out/include/config/pvscsi.h +0 -0
  67. package/bios/seabios/out/include/config/qemu/hardware.h +0 -0
  68. package/bios/seabios/out/include/config/qemu.h +0 -0
  69. package/bios/seabios/out/include/config/rom/size.h +0 -0
  70. package/bios/seabios/out/include/config/rtc/timer.h +0 -0
  71. package/bios/seabios/out/include/config/s3/resume.h +0 -0
  72. package/bios/seabios/out/include/config/sdcard.h +0 -0
  73. package/bios/seabios/out/include/config/serial.h +0 -0
  74. package/bios/seabios/out/include/config/tcgbios.h +0 -0
  75. package/bios/seabios/out/include/config/threads.h +0 -0
  76. package/bios/seabios/out/include/config/tristate.conf +4 -0
  77. package/bios/seabios/out/include/config/tsc/timer.h +0 -0
  78. package/bios/seabios/out/include/config/use/smm.h +0 -0
  79. package/bios/seabios/out/include/config/vga/allocate/extra/stack.h +0 -0
  80. package/bios/seabios/out/include/config/vga/bochs/stdvga.h +0 -0
  81. package/bios/seabios/out/include/config/vga/bochs.h +0 -0
  82. package/bios/seabios/out/include/config/vga/did.h +0 -0
  83. package/bios/seabios/out/include/config/vga/extra/stack/size.h +0 -0
  84. package/bios/seabios/out/include/config/vga/fixup/asm.h +0 -0
  85. package/bios/seabios/out/include/config/vga/pci.h +0 -0
  86. package/bios/seabios/out/include/config/vga/stdvga/ports.h +0 -0
  87. package/bios/seabios/out/include/config/vga/vbe.h +0 -0
  88. package/bios/seabios/out/include/config/vga/vid.h +0 -0
  89. package/bios/seabios/out/include/config/vgahooks.h +0 -0
  90. package/bios/seabios/out/include/config/virtio/blk.h +0 -0
  91. package/bios/seabios/out/include/config/virtio/scsi.h +0 -0
  92. package/bios/seabios/out/include/config/xen.h +0 -0
  93. package/bios/seabios/out/scripts/kconfig/conf +0 -0
  94. package/bios/seabios/out/scripts/kconfig/conf.o +0 -0
  95. package/bios/seabios/out/scripts/kconfig/zconf.hash.c +289 -0
  96. package/bios/seabios/out/scripts/kconfig/zconf.lex.c +2420 -0
  97. package/bios/seabios/out/scripts/kconfig/zconf.tab.c +2538 -0
  98. package/bios/seabios/out/scripts/kconfig/zconf.tab.o +0 -0
  99. package/bios/seabios/scripts/acpi_extract.py +366 -0
  100. package/bios/seabios/scripts/acpi_extract_preprocess.py +41 -0
  101. package/bios/seabios/scripts/buildrom.py +56 -0
  102. package/bios/seabios/scripts/buildversion.py +134 -0
  103. package/bios/seabios/scripts/checkrom.py +95 -0
  104. package/bios/seabios/scripts/checkstack.py +226 -0
  105. package/bios/seabios/scripts/checksum.py +16 -0
  106. package/bios/seabios/scripts/encodeint.py +21 -0
  107. package/bios/seabios/scripts/gen-offsets.sh +17 -0
  108. package/bios/seabios/scripts/kconfig/.gitignore +22 -0
  109. package/bios/seabios/scripts/kconfig/Makefile +331 -0
  110. package/bios/seabios/scripts/kconfig/POTFILES.in +12 -0
  111. package/bios/seabios/scripts/kconfig/check.sh +13 -0
  112. package/bios/seabios/scripts/kconfig/conf.c +718 -0
  113. package/bios/seabios/scripts/kconfig/confdata.c +1250 -0
  114. package/bios/seabios/scripts/kconfig/expr.c +1168 -0
  115. package/bios/seabios/scripts/kconfig/expr.h +241 -0
  116. package/bios/seabios/scripts/kconfig/gconf.c +1542 -0
  117. package/bios/seabios/scripts/kconfig/gconf.glade +661 -0
  118. package/bios/seabios/scripts/kconfig/images.c +326 -0
  119. package/bios/seabios/scripts/kconfig/kxgettext.c +235 -0
  120. package/bios/seabios/scripts/kconfig/lex.zconf.c +2430 -0
  121. package/bios/seabios/scripts/kconfig/list.h +131 -0
  122. package/bios/seabios/scripts/kconfig/lkc.h +200 -0
  123. package/bios/seabios/scripts/kconfig/lkc_proto.h +57 -0
  124. package/bios/seabios/scripts/kconfig/lxdialog/.gitignore +4 -0
  125. package/bios/seabios/scripts/kconfig/lxdialog/BIG.FAT.WARNING +4 -0
  126. package/bios/seabios/scripts/kconfig/lxdialog/check-lxdialog.sh +87 -0
  127. package/bios/seabios/scripts/kconfig/lxdialog/checklist.c +332 -0
  128. package/bios/seabios/scripts/kconfig/lxdialog/dialog.h +257 -0
  129. package/bios/seabios/scripts/kconfig/lxdialog/inputbox.c +301 -0
  130. package/bios/seabios/scripts/kconfig/lxdialog/menubox.c +437 -0
  131. package/bios/seabios/scripts/kconfig/lxdialog/textbox.c +408 -0
  132. package/bios/seabios/scripts/kconfig/lxdialog/util.c +713 -0
  133. package/bios/seabios/scripts/kconfig/lxdialog/yesno.c +114 -0
  134. package/bios/seabios/scripts/kconfig/mconf.c +1036 -0
  135. package/bios/seabios/scripts/kconfig/menu.c +697 -0
  136. package/bios/seabios/scripts/kconfig/merge_config.sh +150 -0
  137. package/bios/seabios/scripts/kconfig/nconf.c +1556 -0
  138. package/bios/seabios/scripts/kconfig/nconf.gui.c +656 -0
  139. package/bios/seabios/scripts/kconfig/nconf.h +96 -0
  140. package/bios/seabios/scripts/kconfig/qconf.cc +1795 -0
  141. package/bios/seabios/scripts/kconfig/qconf.h +338 -0
  142. package/bios/seabios/scripts/kconfig/streamline_config.pl +647 -0
  143. package/bios/seabios/scripts/kconfig/symbol.c +1373 -0
  144. package/bios/seabios/scripts/kconfig/util.c +157 -0
  145. package/bios/seabios/scripts/kconfig/zconf.gperf +48 -0
  146. package/bios/seabios/scripts/kconfig/zconf.hash.c_shipped +289 -0
  147. package/bios/seabios/scripts/kconfig/zconf.l +363 -0
  148. package/bios/seabios/scripts/kconfig/zconf.lex.c_shipped +2420 -0
  149. package/bios/seabios/scripts/kconfig/zconf.tab.c_shipped +2538 -0
  150. package/bios/seabios/scripts/kconfig/zconf.y +733 -0
  151. package/bios/seabios/scripts/layoutrom.py +705 -0
  152. package/bios/seabios/scripts/python23compat.py +14 -0
  153. package/bios/seabios/scripts/readserial.py +190 -0
  154. package/bios/seabios/scripts/tarball.sh +36 -0
  155. package/bios/seabios/scripts/test-build.sh +90 -0
  156. package/bios/seabios/scripts/transdump.py +53 -0
  157. package/bios/seabios/scripts/vgafixup.py +96 -0
  158. package/bios/seabios/src/Kconfig +579 -0
  159. package/bios/seabios/src/apm.c +215 -0
  160. package/bios/seabios/src/asm-offsets.c +23 -0
  161. package/bios/seabios/src/biosvar.h +130 -0
  162. package/bios/seabios/src/block.c +623 -0
  163. package/bios/seabios/src/block.h +121 -0
  164. package/bios/seabios/src/bmp.c +117 -0
  165. package/bios/seabios/src/boot.c +793 -0
  166. package/bios/seabios/src/bootsplash.c +255 -0
  167. package/bios/seabios/src/bregs.h +80 -0
  168. package/bios/seabios/src/byteorder.h +71 -0
  169. package/bios/seabios/src/cdrom.c +322 -0
  170. package/bios/seabios/src/clock.c +506 -0
  171. package/bios/seabios/src/code16gcc.s +1 -0
  172. package/bios/seabios/src/config.h +108 -0
  173. package/bios/seabios/src/cp437.c +275 -0
  174. package/bios/seabios/src/cp437.h +1 -0
  175. package/bios/seabios/src/disk.c +779 -0
  176. package/bios/seabios/src/e820map.c +152 -0
  177. package/bios/seabios/src/e820map.h +26 -0
  178. package/bios/seabios/src/entryfuncs.S +165 -0
  179. package/bios/seabios/src/farptr.h +208 -0
  180. package/bios/seabios/src/font.c +139 -0
  181. package/bios/seabios/src/fw/acpi-dsdt-cpu-hotplug.dsl +78 -0
  182. package/bios/seabios/src/fw/acpi-dsdt-dbug.dsl +26 -0
  183. package/bios/seabios/src/fw/acpi-dsdt-hpet.dsl +36 -0
  184. package/bios/seabios/src/fw/acpi-dsdt-isa.dsl +102 -0
  185. package/bios/seabios/src/fw/acpi-dsdt-pci-crs.dsl +90 -0
  186. package/bios/seabios/src/fw/acpi-dsdt.dsl +342 -0
  187. package/bios/seabios/src/fw/acpi-dsdt.hex +554 -0
  188. package/bios/seabios/src/fw/acpi.c +685 -0
  189. package/bios/seabios/src/fw/biostables.c +491 -0
  190. package/bios/seabios/src/fw/coreboot.c +569 -0
  191. package/bios/seabios/src/fw/csm.c +347 -0
  192. package/bios/seabios/src/fw/dev-pci.h +52 -0
  193. package/bios/seabios/src/fw/dev-piix.h +29 -0
  194. package/bios/seabios/src/fw/dev-q35.h +52 -0
  195. package/bios/seabios/src/fw/lzmadecode.c +398 -0
  196. package/bios/seabios/src/fw/lzmadecode.h +67 -0
  197. package/bios/seabios/src/fw/mptable.c +197 -0
  198. package/bios/seabios/src/fw/mtrr.c +105 -0
  199. package/bios/seabios/src/fw/multiboot.c +111 -0
  200. package/bios/seabios/src/fw/paravirt.c +624 -0
  201. package/bios/seabios/src/fw/paravirt.h +63 -0
  202. package/bios/seabios/src/fw/pciinit.c +1187 -0
  203. package/bios/seabios/src/fw/pirtable.c +103 -0
  204. package/bios/seabios/src/fw/q35-acpi-dsdt.dsl +450 -0
  205. package/bios/seabios/src/fw/romfile_loader.c +259 -0
  206. package/bios/seabios/src/fw/romfile_loader.h +91 -0
  207. package/bios/seabios/src/fw/shadow.c +208 -0
  208. package/bios/seabios/src/fw/smbios.c +585 -0
  209. package/bios/seabios/src/fw/smm.c +269 -0
  210. package/bios/seabios/src/fw/smp.c +194 -0
  211. package/bios/seabios/src/fw/ssdt-misc.dsl +104 -0
  212. package/bios/seabios/src/fw/ssdt-misc.hex +88 -0
  213. package/bios/seabios/src/fw/ssdt-pcihp.dsl +36 -0
  214. package/bios/seabios/src/fw/ssdt-pcihp.hex +38 -0
  215. package/bios/seabios/src/fw/ssdt-proc.dsl +48 -0
  216. package/bios/seabios/src/fw/ssdt-proc.hex +35 -0
  217. package/bios/seabios/src/fw/xen.c +149 -0
  218. package/bios/seabios/src/fw/xen.h +125 -0
  219. package/bios/seabios/src/gen-defs.h +19 -0
  220. package/bios/seabios/src/hw/ahci.c +697 -0
  221. package/bios/seabios/src/hw/ahci.h +201 -0
  222. package/bios/seabios/src/hw/ata.c +1046 -0
  223. package/bios/seabios/src/hw/ata.h +163 -0
  224. package/bios/seabios/src/hw/blockcmd.c +372 -0
  225. package/bios/seabios/src/hw/blockcmd.h +114 -0
  226. package/bios/seabios/src/hw/dma.c +67 -0
  227. package/bios/seabios/src/hw/esp-scsi.c +241 -0
  228. package/bios/seabios/src/hw/esp-scsi.h +8 -0
  229. package/bios/seabios/src/hw/floppy.c +741 -0
  230. package/bios/seabios/src/hw/lsi-scsi.c +221 -0
  231. package/bios/seabios/src/hw/lsi-scsi.h +8 -0
  232. package/bios/seabios/src/hw/megasas.c +405 -0
  233. package/bios/seabios/src/hw/megasas.h +8 -0
  234. package/bios/seabios/src/hw/mpt-scsi.c +319 -0
  235. package/bios/seabios/src/hw/mpt-scsi.h +8 -0
  236. package/bios/seabios/src/hw/nvme-int.h +199 -0
  237. package/bios/seabios/src/hw/nvme.c +708 -0
  238. package/bios/seabios/src/hw/nvme.h +17 -0
  239. package/bios/seabios/src/hw/pci.c +133 -0
  240. package/bios/seabios/src/hw/pci.h +47 -0
  241. package/bios/seabios/src/hw/pci_ids.h +2632 -0
  242. package/bios/seabios/src/hw/pci_regs.h +556 -0
  243. package/bios/seabios/src/hw/pcidevice.c +192 -0
  244. package/bios/seabios/src/hw/pcidevice.h +76 -0
  245. package/bios/seabios/src/hw/pic.c +115 -0
  246. package/bios/seabios/src/hw/pic.h +60 -0
  247. package/bios/seabios/src/hw/ps2port.c +543 -0
  248. package/bios/seabios/src/hw/ps2port.h +67 -0
  249. package/bios/seabios/src/hw/pvscsi.c +333 -0
  250. package/bios/seabios/src/hw/pvscsi.h +8 -0
  251. package/bios/seabios/src/hw/ramdisk.c +108 -0
  252. package/bios/seabios/src/hw/rtc.c +100 -0
  253. package/bios/seabios/src/hw/rtc.h +75 -0
  254. package/bios/seabios/src/hw/sdcard.c +572 -0
  255. package/bios/seabios/src/hw/serialio.c +113 -0
  256. package/bios/seabios/src/hw/serialio.h +29 -0
  257. package/bios/seabios/src/hw/timer.c +259 -0
  258. package/bios/seabios/src/hw/tpm_drivers.c +636 -0
  259. package/bios/seabios/src/hw/tpm_drivers.h +127 -0
  260. package/bios/seabios/src/hw/usb-ehci.c +650 -0
  261. package/bios/seabios/src/hw/usb-ehci.h +177 -0
  262. package/bios/seabios/src/hw/usb-hid.c +442 -0
  263. package/bios/seabios/src/hw/usb-hid.h +29 -0
  264. package/bios/seabios/src/hw/usb-hub.c +205 -0
  265. package/bios/seabios/src/hw/usb-hub.h +64 -0
  266. package/bios/seabios/src/hw/usb-msc.c +222 -0
  267. package/bios/seabios/src/hw/usb-msc.h +10 -0
  268. package/bios/seabios/src/hw/usb-ohci.c +568 -0
  269. package/bios/seabios/src/hw/usb-ohci.h +144 -0
  270. package/bios/seabios/src/hw/usb-uas.c +289 -0
  271. package/bios/seabios/src/hw/usb-uas.h +9 -0
  272. package/bios/seabios/src/hw/usb-uhci.c +571 -0
  273. package/bios/seabios/src/hw/usb-uhci.h +128 -0
  274. package/bios/seabios/src/hw/usb-xhci.c +1161 -0
  275. package/bios/seabios/src/hw/usb-xhci.h +133 -0
  276. package/bios/seabios/src/hw/usb.c +499 -0
  277. package/bios/seabios/src/hw/usb.h +254 -0
  278. package/bios/seabios/src/hw/virtio-blk.c +211 -0
  279. package/bios/seabios/src/hw/virtio-blk.h +43 -0
  280. package/bios/seabios/src/hw/virtio-pci.c +501 -0
  281. package/bios/seabios/src/hw/virtio-pci.h +151 -0
  282. package/bios/seabios/src/hw/virtio-ring.c +147 -0
  283. package/bios/seabios/src/hw/virtio-ring.h +121 -0
  284. package/bios/seabios/src/hw/virtio-scsi.c +220 -0
  285. package/bios/seabios/src/hw/virtio-scsi.h +47 -0
  286. package/bios/seabios/src/jpeg.c +1055 -0
  287. package/bios/seabios/src/kbd.c +599 -0
  288. package/bios/seabios/src/list.h +91 -0
  289. package/bios/seabios/src/malloc.c +561 -0
  290. package/bios/seabios/src/malloc.h +70 -0
  291. package/bios/seabios/src/memmap.h +21 -0
  292. package/bios/seabios/src/misc.c +195 -0
  293. package/bios/seabios/src/mouse.c +342 -0
  294. package/bios/seabios/src/optionroms.c +475 -0
  295. package/bios/seabios/src/output.c +584 -0
  296. package/bios/seabios/src/output.h +68 -0
  297. package/bios/seabios/src/pcibios.c +241 -0
  298. package/bios/seabios/src/pmm.c +176 -0
  299. package/bios/seabios/src/pnpbios.c +88 -0
  300. package/bios/seabios/src/post.c +337 -0
  301. package/bios/seabios/src/resume.c +157 -0
  302. package/bios/seabios/src/romfile.c +146 -0
  303. package/bios/seabios/src/romfile.h +21 -0
  304. package/bios/seabios/src/romlayout.S +698 -0
  305. package/bios/seabios/src/sercon.c +677 -0
  306. package/bios/seabios/src/serial.c +317 -0
  307. package/bios/seabios/src/sha1.c +147 -0
  308. package/bios/seabios/src/sha1.h +8 -0
  309. package/bios/seabios/src/stacks.c +771 -0
  310. package/bios/seabios/src/stacks.h +68 -0
  311. package/bios/seabios/src/std/LegacyBios.h +985 -0
  312. package/bios/seabios/src/std/acpi.h +323 -0
  313. package/bios/seabios/src/std/bda.h +174 -0
  314. package/bios/seabios/src/std/disk.h +175 -0
  315. package/bios/seabios/src/std/mptable.h +77 -0
  316. package/bios/seabios/src/std/multiboot.h +260 -0
  317. package/bios/seabios/src/std/optionrom.h +59 -0
  318. package/bios/seabios/src/std/pirtable.h +35 -0
  319. package/bios/seabios/src/std/pmm.h +19 -0
  320. package/bios/seabios/src/std/pnpbios.h +24 -0
  321. package/bios/seabios/src/std/smbios.h +167 -0
  322. package/bios/seabios/src/std/tcg.h +554 -0
  323. package/bios/seabios/src/std/vbe.h +156 -0
  324. package/bios/seabios/src/std/vga.h +63 -0
  325. package/bios/seabios/src/string.c +251 -0
  326. package/bios/seabios/src/string.h +31 -0
  327. package/bios/seabios/src/system.c +357 -0
  328. package/bios/seabios/src/tcgbios.c +2014 -0
  329. package/bios/seabios/src/tcgbios.h +19 -0
  330. package/bios/seabios/src/types.h +156 -0
  331. package/bios/seabios/src/util.h +251 -0
  332. package/bios/seabios/src/version.c +5 -0
  333. package/bios/seabios/src/vgahooks.c +355 -0
  334. package/bios/seabios/src/x86.c +23 -0
  335. package/bios/seabios/src/x86.h +277 -0
  336. package/bios/seabios/vgasrc/Kconfig +211 -0
  337. package/bios/seabios/vgasrc/bochsdisplay.c +59 -0
  338. package/bios/seabios/vgasrc/bochsvga.c +447 -0
  339. package/bios/seabios/vgasrc/bochsvga.h +57 -0
  340. package/bios/seabios/vgasrc/cbvga.c +337 -0
  341. package/bios/seabios/vgasrc/clext.c +627 -0
  342. package/bios/seabios/vgasrc/geodevga.c +434 -0
  343. package/bios/seabios/vgasrc/geodevga.h +89 -0
  344. package/bios/seabios/vgasrc/ramfb.c +163 -0
  345. package/bios/seabios/vgasrc/stdvga.c +485 -0
  346. package/bios/seabios/vgasrc/stdvga.h +81 -0
  347. package/bios/seabios/vgasrc/stdvgaio.c +186 -0
  348. package/bios/seabios/vgasrc/stdvgamodes.c +534 -0
  349. package/bios/seabios/vgasrc/swcursor.c +96 -0
  350. package/bios/seabios/vgasrc/vbe.c +432 -0
  351. package/bios/seabios/vgasrc/vgabios.c +1131 -0
  352. package/bios/seabios/vgasrc/vgabios.h +88 -0
  353. package/bios/seabios/vgasrc/vgaentry.S +161 -0
  354. package/bios/seabios/vgasrc/vgafb.c +661 -0
  355. package/bios/seabios/vgasrc/vgafb.h +42 -0
  356. package/bios/seabios/vgasrc/vgafonts.c +785 -0
  357. package/bios/seabios/vgasrc/vgahw.h +152 -0
  358. package/bios/seabios/vgasrc/vgainit.c +202 -0
  359. package/bios/seabios/vgasrc/vgalayout.lds.S +23 -0
  360. package/bios/seabios/vgasrc/vgautil.h +103 -0
  361. package/bios/seabios/vgasrc/vgaversion.c +6 -0
  362. package/build/binaries.js +1 -1
  363. package/build/index-debug.cjs +1 -1
  364. package/build/index-debug.js +1 -1
  365. package/build/index.cjs +1 -1
  366. package/build/index.js +1 -1
  367. package/build/v86-debug.wasm +0 -0
  368. package/build/v86.wasm +0 -0
  369. package/package.json +1 -1
@@ -0,0 +1,254 @@
1
+ // USB functions and data.
2
+ #ifndef __USB_H
3
+ #define __USB_H
4
+
5
+ #include "stacks.h" // struct mutex_s
6
+
7
+ // Information on a USB end point.
8
+ struct usb_pipe {
9
+ union {
10
+ struct usb_s *cntl;
11
+ struct usb_pipe *freenext;
12
+ };
13
+ u8 type;
14
+ u8 ep;
15
+ u8 devaddr;
16
+ u8 speed;
17
+ u16 maxpacket;
18
+ u8 eptype;
19
+ };
20
+
21
+ // Common information for usb devices.
22
+ struct usbdevice_s {
23
+ struct usbhub_s *hub;
24
+ struct usb_pipe *defpipe;
25
+ u32 port;
26
+ struct usb_config_descriptor *config;
27
+ struct usb_interface_descriptor *iface;
28
+ int imax;
29
+ u8 speed;
30
+ u8 devaddr;
31
+ };
32
+
33
+ // Common information for usb controllers.
34
+ struct usb_s {
35
+ struct usb_pipe *freelist;
36
+ struct mutex_s resetlock;
37
+ struct pci_device *pci;
38
+ u8 type;
39
+ u8 maxaddr;
40
+ };
41
+
42
+ // Information for enumerating USB hubs
43
+ struct usbhub_s {
44
+ struct usbhub_op_s *op;
45
+ struct usbdevice_s *usbdev;
46
+ struct usb_s *cntl;
47
+ struct mutex_s lock;
48
+ u32 detectend;
49
+ u32 port;
50
+ u32 threads;
51
+ u32 portcount;
52
+ u32 devcount;
53
+ };
54
+
55
+ // Hub callback (32bit) info
56
+ struct usbhub_op_s {
57
+ int (*detect)(struct usbhub_s *hub, u32 port);
58
+ int (*reset)(struct usbhub_s *hub, u32 port);
59
+ int (*portmap)(struct usbhub_s *hub, u32 port);
60
+ void (*disconnect)(struct usbhub_s *hub, u32 port);
61
+ };
62
+
63
+ #define USB_TYPE_UHCI 1
64
+ #define USB_TYPE_OHCI 2
65
+ #define USB_TYPE_EHCI 3
66
+ #define USB_TYPE_XHCI 4
67
+
68
+ #define USB_FULLSPEED 0
69
+ #define USB_LOWSPEED 1
70
+ #define USB_HIGHSPEED 2
71
+ #define USB_SUPERSPEED 3
72
+
73
+ #define USB_MAXADDR 127
74
+
75
+
76
+ /****************************************************************
77
+ * usb structs and flags
78
+ ****************************************************************/
79
+
80
+ // USB mandated timings (in ms)
81
+ #define USB_TIME_SIGATT 100
82
+ #define USB_TIME_ATTDB 100
83
+ #define USB_TIME_DRST 10
84
+ #define USB_TIME_DRSTR 50
85
+ #define USB_TIME_RSTRCY 10
86
+
87
+ #define USB_TIME_STATUS 50
88
+ #define USB_TIME_DATAIN 500
89
+ #define USB_TIME_COMMAND 5000
90
+
91
+ #define USB_TIME_SETADDR_RECOVERY 2
92
+
93
+ #define USB_PID_OUT 0xe1
94
+ #define USB_PID_IN 0x69
95
+ #define USB_PID_SETUP 0x2d
96
+
97
+ #define USB_DIR_OUT 0 /* to device */
98
+ #define USB_DIR_IN 0x80 /* to host */
99
+
100
+ #define USB_TYPE_MASK (0x03 << 5)
101
+ #define USB_TYPE_STANDARD (0x00 << 5)
102
+ #define USB_TYPE_CLASS (0x01 << 5)
103
+ #define USB_TYPE_VENDOR (0x02 << 5)
104
+ #define USB_TYPE_RESERVED (0x03 << 5)
105
+
106
+ #define USB_RECIP_MASK 0x1f
107
+ #define USB_RECIP_DEVICE 0x00
108
+ #define USB_RECIP_INTERFACE 0x01
109
+ #define USB_RECIP_ENDPOINT 0x02
110
+ #define USB_RECIP_OTHER 0x03
111
+
112
+ #define USB_REQ_GET_STATUS 0x00
113
+ #define USB_REQ_CLEAR_FEATURE 0x01
114
+ #define USB_REQ_SET_FEATURE 0x03
115
+ #define USB_REQ_SET_ADDRESS 0x05
116
+ #define USB_REQ_GET_DESCRIPTOR 0x06
117
+ #define USB_REQ_SET_DESCRIPTOR 0x07
118
+ #define USB_REQ_GET_CONFIGURATION 0x08
119
+ #define USB_REQ_SET_CONFIGURATION 0x09
120
+ #define USB_REQ_GET_INTERFACE 0x0A
121
+ #define USB_REQ_SET_INTERFACE 0x0B
122
+ #define USB_REQ_SYNCH_FRAME 0x0C
123
+
124
+ struct usb_ctrlrequest {
125
+ u8 bRequestType;
126
+ u8 bRequest;
127
+ u16 wValue;
128
+ u16 wIndex;
129
+ u16 wLength;
130
+ } PACKED;
131
+
132
+ #define USB_DT_DEVICE 0x01
133
+ #define USB_DT_CONFIG 0x02
134
+ #define USB_DT_STRING 0x03
135
+ #define USB_DT_INTERFACE 0x04
136
+ #define USB_DT_ENDPOINT 0x05
137
+ #define USB_DT_DEVICE_QUALIFIER 0x06
138
+ #define USB_DT_OTHER_SPEED_CONFIG 0x07
139
+ #define USB_DT_ENDPOINT_COMPANION 0x30
140
+
141
+ struct usb_device_descriptor {
142
+ u8 bLength;
143
+ u8 bDescriptorType;
144
+
145
+ u16 bcdUSB;
146
+ u8 bDeviceClass;
147
+ u8 bDeviceSubClass;
148
+ u8 bDeviceProtocol;
149
+ u8 bMaxPacketSize0;
150
+ u16 idVendor;
151
+ u16 idProduct;
152
+ u16 bcdDevice;
153
+ u8 iManufacturer;
154
+ u8 iProduct;
155
+ u8 iSerialNumber;
156
+ u8 bNumConfigurations;
157
+ } PACKED;
158
+
159
+ #define USB_CLASS_PER_INTERFACE 0 /* for DeviceClass */
160
+ #define USB_CLASS_AUDIO 1
161
+ #define USB_CLASS_COMM 2
162
+ #define USB_CLASS_HID 3
163
+ #define USB_CLASS_PHYSICAL 5
164
+ #define USB_CLASS_STILL_IMAGE 6
165
+ #define USB_CLASS_PRINTER 7
166
+ #define USB_CLASS_MASS_STORAGE 8
167
+ #define USB_CLASS_HUB 9
168
+
169
+ struct usb_config_descriptor {
170
+ u8 bLength;
171
+ u8 bDescriptorType;
172
+
173
+ u16 wTotalLength;
174
+ u8 bNumInterfaces;
175
+ u8 bConfigurationValue;
176
+ u8 iConfiguration;
177
+ u8 bmAttributes;
178
+ u8 bMaxPower;
179
+ } PACKED;
180
+
181
+ struct usb_interface_descriptor {
182
+ u8 bLength;
183
+ u8 bDescriptorType;
184
+
185
+ u8 bInterfaceNumber;
186
+ u8 bAlternateSetting;
187
+ u8 bNumEndpoints;
188
+ u8 bInterfaceClass;
189
+ u8 bInterfaceSubClass;
190
+ u8 bInterfaceProtocol;
191
+ u8 iInterface;
192
+ } PACKED;
193
+
194
+ struct usb_endpoint_descriptor {
195
+ u8 bLength;
196
+ u8 bDescriptorType;
197
+
198
+ u8 bEndpointAddress;
199
+ u8 bmAttributes;
200
+ u16 wMaxPacketSize;
201
+ u8 bInterval;
202
+ } PACKED;
203
+
204
+ #define USB_ENDPOINT_NUMBER_MASK 0x0f /* in bEndpointAddress */
205
+ #define USB_ENDPOINT_DIR_MASK 0x80
206
+
207
+ #define USB_ENDPOINT_XFERTYPE_MASK 0x03 /* in bmAttributes */
208
+ #define USB_ENDPOINT_XFER_CONTROL 0
209
+ #define USB_ENDPOINT_XFER_ISOC 1
210
+ #define USB_ENDPOINT_XFER_BULK 2
211
+ #define USB_ENDPOINT_XFER_INT 3
212
+ #define USB_ENDPOINT_MAX_ADJUSTABLE 0x80
213
+
214
+ #define USB_CONTROL_SETUP_SIZE 8
215
+
216
+
217
+ /****************************************************************
218
+ * usb mass storage flags
219
+ ****************************************************************/
220
+
221
+ #define US_SC_ATAPI_8020 0x02
222
+ #define US_SC_ATAPI_8070 0x05
223
+ #define US_SC_SCSI 0x06
224
+
225
+ #define US_PR_BULK 0x50 /* bulk-only transport */
226
+ #define US_PR_UAS 0x62 /* usb attached scsi */
227
+
228
+ /****************************************************************
229
+ * function defs
230
+ ****************************************************************/
231
+
232
+ // usb.c
233
+ int usb_send_bulk(struct usb_pipe *pipe, int dir, void *data, int datasize);
234
+ int usb_poll_intr(struct usb_pipe *pipe, void *data);
235
+ int usb_32bit_pipe(struct usb_pipe *pipe_fl);
236
+ struct usb_pipe *usb_alloc_pipe(struct usbdevice_s *usbdev
237
+ , struct usb_endpoint_descriptor *epdesc);
238
+ void usb_free_pipe(struct usbdevice_s *usbdev, struct usb_pipe *pipe);
239
+ int usb_send_default_control(struct usb_pipe *pipe
240
+ , const struct usb_ctrlrequest *req, void *data);
241
+ int usb_is_freelist(struct usb_s *cntl, struct usb_pipe *pipe);
242
+ void usb_add_freelist(struct usb_pipe *pipe);
243
+ struct usb_pipe *usb_get_freelist(struct usb_s *cntl, u8 eptype);
244
+ void usb_desc2pipe(struct usb_pipe *pipe, struct usbdevice_s *usbdev
245
+ , struct usb_endpoint_descriptor *epdesc);
246
+ int usb_get_period(struct usbdevice_s *usbdev
247
+ , struct usb_endpoint_descriptor *epdesc);
248
+ int usb_xfer_time(struct usb_pipe *pipe, int datalen);
249
+ struct usb_endpoint_descriptor *usb_find_desc(struct usbdevice_s *usbdev
250
+ , int type, int dir);
251
+ void usb_enumerate(struct usbhub_s *hub);
252
+ void usb_setup(void);
253
+
254
+ #endif // usb.h
@@ -0,0 +1,211 @@
1
+ // Virtio block boot support.
2
+ //
3
+ // Copyright (C) 2010 Red Hat Inc.
4
+ //
5
+ // Authors:
6
+ // Gleb Natapov <gnatapov@redhat.com>
7
+ //
8
+ // This file may be distributed under the terms of the GNU LGPLv3 license.
9
+
10
+ #include "biosvar.h" // GET_GLOBALFLAT
11
+ #include "config.h" // CONFIG_*
12
+ #include "block.h" // struct drive_s
13
+ #include "malloc.h" // free
14
+ #include "output.h" // dprintf
15
+ #include "pcidevice.h" // foreachpci
16
+ #include "pci_ids.h" // PCI_DEVICE_ID_VIRTIO_BLK
17
+ #include "pci_regs.h" // PCI_VENDOR_ID
18
+ #include "stacks.h" // run_thread
19
+ #include "std/disk.h" // DISK_RET_SUCCESS
20
+ #include "string.h" // memset
21
+ #include "util.h" // usleep
22
+ #include "virtio-pci.h"
23
+ #include "virtio-ring.h"
24
+ #include "virtio-blk.h"
25
+
26
+ struct virtiodrive_s {
27
+ struct drive_s drive;
28
+ struct vring_virtqueue *vq;
29
+ struct vp_device vp;
30
+ };
31
+
32
+ static int
33
+ virtio_blk_op(struct disk_op_s *op, int write)
34
+ {
35
+ struct virtiodrive_s *vdrive =
36
+ container_of(op->drive_fl, struct virtiodrive_s, drive);
37
+ struct vring_virtqueue *vq = vdrive->vq;
38
+ struct virtio_blk_outhdr hdr = {
39
+ .type = write ? VIRTIO_BLK_T_OUT : VIRTIO_BLK_T_IN,
40
+ .ioprio = 0,
41
+ .sector = op->lba,
42
+ };
43
+ u8 status = VIRTIO_BLK_S_UNSUPP;
44
+ struct vring_list sg[] = {
45
+ {
46
+ .addr = (void*)(&hdr),
47
+ .length = sizeof(hdr),
48
+ },
49
+ {
50
+ .addr = op->buf_fl,
51
+ .length = vdrive->drive.blksize * op->count,
52
+ },
53
+ {
54
+ .addr = (void*)(&status),
55
+ .length = sizeof(status),
56
+ },
57
+ };
58
+
59
+ /* Add to virtqueue and kick host */
60
+ if (write)
61
+ vring_add_buf(vq, sg, 2, 1, 0, 0);
62
+ else
63
+ vring_add_buf(vq, sg, 1, 2, 0, 0);
64
+ vring_kick(&vdrive->vp, vq, 1);
65
+
66
+ /* Wait for reply */
67
+ while (!vring_more_used(vq))
68
+ usleep(5);
69
+
70
+ /* Reclaim virtqueue element */
71
+ vring_get_buf(vq, NULL);
72
+
73
+ /* Clear interrupt status register. Avoid leaving interrupts stuck if
74
+ * VRING_AVAIL_F_NO_INTERRUPT was ignored and interrupts were raised.
75
+ */
76
+ vp_get_isr(&vdrive->vp);
77
+
78
+ return status == VIRTIO_BLK_S_OK ? DISK_RET_SUCCESS : DISK_RET_EBADTRACK;
79
+ }
80
+
81
+ int
82
+ virtio_blk_process_op(struct disk_op_s *op)
83
+ {
84
+ if (! CONFIG_VIRTIO_BLK)
85
+ return 0;
86
+ switch (op->command) {
87
+ case CMD_READ:
88
+ return virtio_blk_op(op, 0);
89
+ case CMD_WRITE:
90
+ return virtio_blk_op(op, 1);
91
+ default:
92
+ return default_process_op(op);
93
+ }
94
+ }
95
+
96
+ static void
97
+ init_virtio_blk(void *data)
98
+ {
99
+ struct pci_device *pci = data;
100
+ u8 status = VIRTIO_CONFIG_S_ACKNOWLEDGE | VIRTIO_CONFIG_S_DRIVER;
101
+ dprintf(1, "found virtio-blk at %pP\n", pci);
102
+ struct virtiodrive_s *vdrive = malloc_low(sizeof(*vdrive));
103
+ if (!vdrive) {
104
+ warn_noalloc();
105
+ return;
106
+ }
107
+ memset(vdrive, 0, sizeof(*vdrive));
108
+ vdrive->drive.type = DTYPE_VIRTIO_BLK;
109
+ vdrive->drive.cntl_id = pci->bdf;
110
+
111
+ vp_init_simple(&vdrive->vp, pci);
112
+ if (vp_find_vq(&vdrive->vp, 0, &vdrive->vq) < 0 ) {
113
+ dprintf(1, "fail to find vq for virtio-blk %pP\n", pci);
114
+ goto fail;
115
+ }
116
+
117
+ if (vdrive->vp.use_modern) {
118
+ struct vp_device *vp = &vdrive->vp;
119
+ u64 features = vp_get_features(vp);
120
+ u64 version1 = 1ull << VIRTIO_F_VERSION_1;
121
+ u64 iommu_platform = 1ull << VIRTIO_F_IOMMU_PLATFORM;
122
+ u64 blk_size = 1ull << VIRTIO_BLK_F_BLK_SIZE;
123
+ if (!(features & version1)) {
124
+ dprintf(1, "modern device without virtio_1 feature bit: %pP\n", pci);
125
+ goto fail;
126
+ }
127
+
128
+ features = features & (version1 | iommu_platform | blk_size);
129
+ vp_set_features(vp, features);
130
+ status |= VIRTIO_CONFIG_S_FEATURES_OK;
131
+ vp_set_status(vp, status);
132
+ if (!(vp_get_status(vp) & VIRTIO_CONFIG_S_FEATURES_OK)) {
133
+ dprintf(1, "device didn't accept features: %pP\n", pci);
134
+ goto fail;
135
+ }
136
+
137
+ vdrive->drive.sectors =
138
+ vp_read(&vp->device, struct virtio_blk_config, capacity);
139
+ if (features & blk_size) {
140
+ vdrive->drive.blksize =
141
+ vp_read(&vp->device, struct virtio_blk_config, blk_size);
142
+ } else {
143
+ vdrive->drive.blksize = DISK_SECTOR_SIZE;
144
+ }
145
+ if (vdrive->drive.blksize != DISK_SECTOR_SIZE) {
146
+ dprintf(1, "virtio-blk %pP block size %d is unsupported\n",
147
+ pci, vdrive->drive.blksize);
148
+ goto fail;
149
+ }
150
+ dprintf(3, "virtio-blk %pP blksize=%d sectors=%u\n",
151
+ pci, vdrive->drive.blksize, (u32)vdrive->drive.sectors);
152
+
153
+ vdrive->drive.pchs.cylinder =
154
+ vp_read(&vp->device, struct virtio_blk_config, cylinders);
155
+ vdrive->drive.pchs.head =
156
+ vp_read(&vp->device, struct virtio_blk_config, heads);
157
+ vdrive->drive.pchs.sector =
158
+ vp_read(&vp->device, struct virtio_blk_config, sectors);
159
+ } else {
160
+ struct virtio_blk_config cfg;
161
+ vp_get_legacy(&vdrive->vp, 0, &cfg, sizeof(cfg));
162
+
163
+ u64 f = vp_get_features(&vdrive->vp);
164
+ vdrive->drive.blksize = (f & (1 << VIRTIO_BLK_F_BLK_SIZE)) ?
165
+ cfg.blk_size : DISK_SECTOR_SIZE;
166
+
167
+ vdrive->drive.sectors = cfg.capacity;
168
+ dprintf(3, "virtio-blk %pP blksize=%d sectors=%u\n",
169
+ pci, vdrive->drive.blksize, (u32)vdrive->drive.sectors);
170
+
171
+ if (vdrive->drive.blksize != DISK_SECTOR_SIZE) {
172
+ dprintf(1, "virtio-blk %pP block size %d is unsupported\n",
173
+ pci, vdrive->drive.blksize);
174
+ goto fail;
175
+ }
176
+ vdrive->drive.pchs.cylinder = cfg.cylinders;
177
+ vdrive->drive.pchs.head = cfg.heads;
178
+ vdrive->drive.pchs.sector = cfg.sectors;
179
+ }
180
+
181
+ char *desc = znprintf(MAXDESCSIZE, "Virtio disk PCI:%pP", pci);
182
+ boot_add_hd(&vdrive->drive, desc, bootprio_find_pci_device(pci));
183
+
184
+ status |= VIRTIO_CONFIG_S_DRIVER_OK;
185
+ vp_set_status(&vdrive->vp, status);
186
+ return;
187
+
188
+ fail:
189
+ vp_reset(&vdrive->vp);
190
+ free(vdrive->vq);
191
+ free(vdrive);
192
+ }
193
+
194
+ void
195
+ virtio_blk_setup(void)
196
+ {
197
+ ASSERT32FLAT();
198
+ if (! CONFIG_VIRTIO_BLK)
199
+ return;
200
+
201
+ dprintf(3, "init virtio-blk\n");
202
+
203
+ struct pci_device *pci;
204
+ foreachpci(pci) {
205
+ if (pci->vendor != PCI_VENDOR_ID_REDHAT_QUMRANET ||
206
+ (pci->device != PCI_DEVICE_ID_VIRTIO_BLK_09 &&
207
+ pci->device != PCI_DEVICE_ID_VIRTIO_BLK_10))
208
+ continue;
209
+ run_thread(init_virtio_blk, pci);
210
+ }
211
+ }
@@ -0,0 +1,43 @@
1
+ #ifndef _VIRTIO_BLK_H
2
+ #define _VIRTIO_BLK_H
3
+
4
+ struct virtio_blk_config
5
+ {
6
+ u64 capacity;
7
+ u32 size_max;
8
+ u32 seg_max;
9
+ u16 cylinders;
10
+ u8 heads;
11
+ u8 sectors;
12
+ u32 blk_size;
13
+ u8 physical_block_exp;
14
+ u8 alignment_offset;
15
+ u16 min_io_size;
16
+ u32 opt_io_size;
17
+ } __attribute__((packed));
18
+
19
+ #define VIRTIO_BLK_F_BLK_SIZE 6
20
+
21
+ /* These two define direction. */
22
+ #define VIRTIO_BLK_T_IN 0
23
+ #define VIRTIO_BLK_T_OUT 1
24
+
25
+ /* This is the first element of the read scatter-gather list. */
26
+ struct virtio_blk_outhdr {
27
+ /* VIRTIO_BLK_T* */
28
+ u32 type;
29
+ /* io priority. */
30
+ u32 ioprio;
31
+ /* Sector (ie. 512 byte offset) */
32
+ u64 sector;
33
+ };
34
+
35
+ #define VIRTIO_BLK_S_OK 0
36
+ #define VIRTIO_BLK_S_IOERR 1
37
+ #define VIRTIO_BLK_S_UNSUPP 2
38
+
39
+ struct disk_op_s;
40
+ int virtio_blk_process_op(struct disk_op_s *op);
41
+ void virtio_blk_setup(void);
42
+
43
+ #endif /* _VIRTIO_BLK_H */