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,205 @@
1
+ // Code for handling standard USB hubs.
2
+ //
3
+ // Copyright (C) 2010 Kevin O'Connor <kevin@koconnor.net>
4
+ //
5
+ // This file may be distributed under the terms of the GNU LGPLv3 license.
6
+
7
+ #include "config.h" // CONFIG_USB_HUB
8
+ #include "output.h" // dprintf
9
+ #include "string.h" // memset
10
+ #include "usb.h" // struct usb_s
11
+ #include "usb-hub.h" // struct usb_hub_descriptor
12
+ #include "util.h" // timer_calc
13
+
14
+ static int
15
+ get_hub_desc(struct usb_pipe *pipe, struct usb_hub_descriptor *desc)
16
+ {
17
+ struct usb_ctrlrequest req;
18
+ req.bRequestType = USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_DEVICE;
19
+ req.bRequest = USB_REQ_GET_DESCRIPTOR;
20
+ if (pipe->speed == USB_SUPERSPEED)
21
+ req.wValue = USB_DT_HUB3<<8;
22
+ else
23
+ req.wValue = USB_DT_HUB<<8;
24
+ req.wIndex = 0;
25
+ req.wLength = sizeof(*desc);
26
+ return usb_send_default_control(pipe, &req, desc);
27
+ }
28
+
29
+ static int
30
+ set_hub_depth(struct usb_pipe *pipe, u16 depth)
31
+ {
32
+ struct usb_ctrlrequest req;
33
+ req.bRequestType = USB_DIR_OUT | USB_TYPE_CLASS | USB_RECIP_DEVICE;
34
+ req.bRequest = HUB_REQ_SET_HUB_DEPTH;
35
+ req.wValue = depth;
36
+ req.wIndex = 0;
37
+ req.wLength = 0;
38
+ return usb_send_default_control(pipe, &req, NULL);
39
+ }
40
+
41
+ static int
42
+ set_port_feature(struct usbhub_s *hub, int port, int feature)
43
+ {
44
+ struct usb_ctrlrequest req;
45
+ req.bRequestType = USB_DIR_OUT | USB_TYPE_CLASS | USB_RECIP_OTHER;
46
+ req.bRequest = USB_REQ_SET_FEATURE;
47
+ req.wValue = feature;
48
+ req.wIndex = port + 1;
49
+ req.wLength = 0;
50
+ mutex_lock(&hub->lock);
51
+ int ret = usb_send_default_control(hub->usbdev->defpipe, &req, NULL);
52
+ mutex_unlock(&hub->lock);
53
+ return ret;
54
+ }
55
+
56
+ static int
57
+ clear_port_feature(struct usbhub_s *hub, int port, int feature)
58
+ {
59
+ struct usb_ctrlrequest req;
60
+ req.bRequestType = USB_DIR_OUT | USB_TYPE_CLASS | USB_RECIP_OTHER;
61
+ req.bRequest = USB_REQ_CLEAR_FEATURE;
62
+ req.wValue = feature;
63
+ req.wIndex = port + 1;
64
+ req.wLength = 0;
65
+ mutex_lock(&hub->lock);
66
+ int ret = usb_send_default_control(hub->usbdev->defpipe, &req, NULL);
67
+ mutex_unlock(&hub->lock);
68
+ return ret;
69
+ }
70
+
71
+ static int
72
+ get_port_status(struct usbhub_s *hub, int port, struct usb_port_status *sts)
73
+ {
74
+ struct usb_ctrlrequest req;
75
+ req.bRequestType = USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_OTHER;
76
+ req.bRequest = USB_REQ_GET_STATUS;
77
+ req.wValue = 0;
78
+ req.wIndex = port + 1;
79
+ req.wLength = sizeof(*sts);
80
+ mutex_lock(&hub->lock);
81
+ int ret = usb_send_default_control(hub->usbdev->defpipe, &req, sts);
82
+ mutex_unlock(&hub->lock);
83
+ return ret;
84
+ }
85
+
86
+ // Check if device attached to port
87
+ static int
88
+ usb_hub_detect(struct usbhub_s *hub, u32 port)
89
+ {
90
+ struct usb_port_status sts;
91
+ int ret = get_port_status(hub, port, &sts);
92
+ if (ret) {
93
+ dprintf(1, "Failure on hub port %d detect\n", port);
94
+ return -1;
95
+ }
96
+ return (sts.wPortStatus & USB_PORT_STAT_CONNECTION) ? 1 : 0;
97
+ }
98
+
99
+ // Disable port
100
+ static void
101
+ usb_hub_disconnect(struct usbhub_s *hub, u32 port)
102
+ {
103
+ int ret = clear_port_feature(hub, port, USB_PORT_FEAT_ENABLE);
104
+ if (ret)
105
+ dprintf(1, "Failure on hub port %d disconnect\n", port);
106
+ }
107
+
108
+ // Reset device on port
109
+ static int
110
+ usb_hub_reset(struct usbhub_s *hub, u32 port)
111
+ {
112
+ int ret = set_port_feature(hub, port, USB_PORT_FEAT_RESET);
113
+ if (ret)
114
+ goto fail;
115
+
116
+ // Wait for reset to complete.
117
+ struct usb_port_status sts;
118
+ u32 end = timer_calc(USB_TIME_DRST * 2);
119
+ for (;;) {
120
+ ret = get_port_status(hub, port, &sts);
121
+ if (ret)
122
+ goto fail;
123
+ if (!(sts.wPortStatus & USB_PORT_STAT_RESET)
124
+ && (hub->usbdev->speed != USB_SUPERSPEED
125
+ || !(sts.wPortStatus & USB_PORT_STAT_LINK_MASK)))
126
+ break;
127
+ if (timer_check(end)) {
128
+ warn_timeout();
129
+ goto fail;
130
+ }
131
+ msleep(5);
132
+ }
133
+
134
+ // Reset complete.
135
+ if (!(sts.wPortStatus & USB_PORT_STAT_CONNECTION))
136
+ // Device no longer present
137
+ return -1;
138
+
139
+ if (hub->usbdev->speed == USB_SUPERSPEED)
140
+ return USB_SUPERSPEED;
141
+ return ((sts.wPortStatus & USB_PORT_STAT_SPEED_MASK)
142
+ >> USB_PORT_STAT_SPEED_SHIFT);
143
+
144
+ fail:
145
+ dprintf(1, "Failure on hub port %d reset\n", port);
146
+ usb_hub_disconnect(hub, port);
147
+ return -1;
148
+ }
149
+
150
+ static struct usbhub_op_s HubOp = {
151
+ .detect = usb_hub_detect,
152
+ .reset = usb_hub_reset,
153
+ .disconnect = usb_hub_disconnect,
154
+ };
155
+
156
+ // Configure a usb hub and then find devices connected to it.
157
+ int
158
+ usb_hub_setup(struct usbdevice_s *usbdev)
159
+ {
160
+ ASSERT32FLAT();
161
+ if (!CONFIG_USB_HUB)
162
+ return -1;
163
+
164
+ struct usb_hub_descriptor desc;
165
+ int ret = get_hub_desc(usbdev->defpipe, &desc);
166
+ if (ret)
167
+ return ret;
168
+
169
+ struct usbhub_s hub;
170
+ memset(&hub, 0, sizeof(hub));
171
+ hub.usbdev = usbdev;
172
+ hub.cntl = usbdev->defpipe->cntl;
173
+ hub.portcount = desc.bNbrPorts;
174
+ hub.op = &HubOp;
175
+
176
+ if (usbdev->speed == USB_SUPERSPEED) {
177
+ int depth = 0;
178
+ struct usbdevice_s *parent = usbdev->hub->usbdev;
179
+ while (parent) {
180
+ depth++;
181
+ parent = parent->hub->usbdev;
182
+ }
183
+
184
+ ret = set_hub_depth(usbdev->defpipe, depth);
185
+ if (ret)
186
+ return ret;
187
+ }
188
+
189
+ // Turn on power to ports.
190
+ int port;
191
+ for (port=0; port<desc.bNbrPorts; port++) {
192
+ ret = set_port_feature(&hub, port, USB_PORT_FEAT_POWER);
193
+ if (ret)
194
+ return ret;
195
+ }
196
+ // Wait for port power to stabilize.
197
+ msleep(desc.bPwrOn2PwrGood * 2);
198
+
199
+ usb_enumerate(&hub);
200
+
201
+ dprintf(1, "Initialized USB HUB (%d ports used)\n", hub.devcount);
202
+ if (hub.devcount)
203
+ return 0;
204
+ return -1;
205
+ }
@@ -0,0 +1,64 @@
1
+ #ifndef __USB_HUB_H
2
+ #define __USB_HUB_H
3
+
4
+ // usb-hub.c
5
+ struct usbdevice_s;
6
+ int usb_hub_setup(struct usbdevice_s *usbdev);
7
+
8
+
9
+ /****************************************************************
10
+ * hub flags
11
+ ****************************************************************/
12
+
13
+ #define USB_DT_HUB (USB_TYPE_CLASS | 0x09)
14
+ #define USB_DT_HUB3 (USB_TYPE_CLASS | 0x0a)
15
+
16
+ #define HUB_REQ_SET_HUB_DEPTH 0x0C
17
+
18
+ struct usb_hub_descriptor {
19
+ u8 bDescLength;
20
+ u8 bDescriptorType;
21
+ u8 bNbrPorts;
22
+ u16 wHubCharacteristics;
23
+ u8 bPwrOn2PwrGood;
24
+ u8 bHubContrCurrent;
25
+ // Variable length fields for DeviceRemovable[], PortPwrCtrlMask[] follow.
26
+ } PACKED;
27
+
28
+ #define USB_PORT_FEAT_CONNECTION 0
29
+ #define USB_PORT_FEAT_ENABLE 1
30
+ #define USB_PORT_FEAT_SUSPEND 2
31
+ #define USB_PORT_FEAT_OVER_CURRENT 3
32
+ #define USB_PORT_FEAT_RESET 4
33
+ #define USB_PORT_FEAT_POWER 8
34
+ #define USB_PORT_FEAT_LOWSPEED 9
35
+ #define USB_PORT_FEAT_C_CONNECTION 16
36
+ #define USB_PORT_FEAT_C_ENABLE 17
37
+ #define USB_PORT_FEAT_C_SUSPEND 18
38
+ #define USB_PORT_FEAT_C_OVER_CURRENT 19
39
+ #define USB_PORT_FEAT_C_RESET 20
40
+ #define USB_PORT_FEAT_TEST 21
41
+ #define USB_PORT_FEAT_INDICATOR 22
42
+ #define USB_PORT_FEAT_C_PORT_L1 23
43
+
44
+ struct usb_port_status {
45
+ u16 wPortStatus;
46
+ u16 wPortChange;
47
+ } PACKED;
48
+
49
+ #define USB_PORT_STAT_CONNECTION 0x0001
50
+ #define USB_PORT_STAT_ENABLE 0x0002
51
+ #define USB_PORT_STAT_SUSPEND 0x0004
52
+ #define USB_PORT_STAT_OVERCURRENT 0x0008
53
+ #define USB_PORT_STAT_RESET 0x0010
54
+ #define USB_PORT_STAT_LINK_SHIFT 5
55
+ #define USB_PORT_STAT_LINK_MASK (0x7 << USB_PORT_STAT_LINK_SHIFT)
56
+ #define USB_PORT_STAT_POWER 0x0100
57
+ #define USB_PORT_STAT_SPEED_SHIFT 9
58
+ #define USB_PORT_STAT_SPEED_MASK (0x3 << USB_PORT_STAT_SPEED_SHIFT)
59
+ #define USB_PORT_STAT_LOW_SPEED 0x0200
60
+ #define USB_PORT_STAT_HIGH_SPEED 0x0400
61
+ #define USB_PORT_STAT_TEST 0x0800
62
+ #define USB_PORT_STAT_INDICATOR 0x1000
63
+
64
+ #endif // ush-hid.h
@@ -0,0 +1,222 @@
1
+ // Code for handling USB Mass Storage Controller devices.
2
+ //
3
+ // Copyright (C) 2010 Kevin O'Connor <kevin@koconnor.net>
4
+ //
5
+ // This file may be distributed under the terms of the GNU LGPLv3 license.
6
+
7
+ #include "biosvar.h" // GET_GLOBALFLAT
8
+ #include "block.h" // DTYPE_USB
9
+ #include "blockcmd.h" // cdb_read
10
+ #include "config.h" // CONFIG_USB_MSC
11
+ #include "malloc.h" // free
12
+ #include "output.h" // dprintf
13
+ #include "std/disk.h" // DISK_RET_SUCCESS
14
+ #include "string.h" // memset
15
+ #include "usb.h" // struct usb_s
16
+ #include "usb-msc.h" // usb_msc_setup
17
+ #include "util.h" // bootprio_find_usb
18
+
19
+ struct usbdrive_s {
20
+ struct drive_s drive;
21
+ struct usb_pipe *bulkin, *bulkout;
22
+ int lun;
23
+ };
24
+
25
+
26
+ /****************************************************************
27
+ * Bulk-only drive command processing
28
+ ****************************************************************/
29
+
30
+ #define USB_CDB_SIZE 12
31
+
32
+ #define CBW_SIGNATURE 0x43425355 // USBC
33
+
34
+ struct cbw_s {
35
+ u32 dCBWSignature;
36
+ u32 dCBWTag;
37
+ u32 dCBWDataTransferLength;
38
+ u8 bmCBWFlags;
39
+ u8 bCBWLUN;
40
+ u8 bCBWCBLength;
41
+ u8 CBWCB[16];
42
+ } PACKED;
43
+
44
+ #define CSW_SIGNATURE 0x53425355 // USBS
45
+
46
+ struct csw_s {
47
+ u32 dCSWSignature;
48
+ u32 dCSWTag;
49
+ u32 dCSWDataResidue;
50
+ u8 bCSWStatus;
51
+ } PACKED;
52
+
53
+ static int
54
+ usb_msc_send(struct usbdrive_s *udrive_gf, int dir, void *buf, u32 bytes)
55
+ {
56
+ struct usb_pipe *pipe;
57
+ if (dir == USB_DIR_OUT)
58
+ pipe = GET_GLOBALFLAT(udrive_gf->bulkout);
59
+ else
60
+ pipe = GET_GLOBALFLAT(udrive_gf->bulkin);
61
+ return usb_send_bulk(pipe, dir, buf, bytes);
62
+ }
63
+
64
+ // Low-level usb command transmit function.
65
+ int
66
+ usb_process_op(struct disk_op_s *op)
67
+ {
68
+ if (!CONFIG_USB_MSC)
69
+ return 0;
70
+
71
+ dprintf(16, "usb_cmd_data id=%p write=%d count=%d buf=%p\n"
72
+ , op->drive_fl, 0, op->count, op->buf_fl);
73
+ struct usbdrive_s *udrive_gf = container_of(
74
+ op->drive_fl, struct usbdrive_s, drive);
75
+
76
+ // Setup command block wrapper.
77
+ struct cbw_s cbw;
78
+ memset(&cbw, 0, sizeof(cbw));
79
+ int blocksize = scsi_fill_cmd(op, cbw.CBWCB, USB_CDB_SIZE);
80
+ if (blocksize < 0)
81
+ return default_process_op(op);
82
+ u32 bytes = blocksize * op->count;
83
+ cbw.dCBWSignature = CBW_SIGNATURE;
84
+ cbw.dCBWTag = 999; // XXX
85
+ cbw.dCBWDataTransferLength = bytes;
86
+ cbw.bmCBWFlags = scsi_is_read(op) ? USB_DIR_IN : USB_DIR_OUT;
87
+ cbw.bCBWLUN = GET_GLOBALFLAT(udrive_gf->lun);
88
+ cbw.bCBWCBLength = USB_CDB_SIZE;
89
+
90
+ // Transfer cbw to device.
91
+ int ret = usb_msc_send(udrive_gf, USB_DIR_OUT
92
+ , MAKE_FLATPTR(GET_SEG(SS), &cbw), sizeof(cbw));
93
+ if (ret)
94
+ goto fail;
95
+
96
+ // Transfer data to/from device.
97
+ if (bytes) {
98
+ ret = usb_msc_send(udrive_gf, cbw.bmCBWFlags, op->buf_fl, bytes);
99
+ if (ret)
100
+ goto fail;
101
+ }
102
+
103
+ // Transfer csw info.
104
+ struct csw_s csw;
105
+ ret = usb_msc_send(udrive_gf, USB_DIR_IN
106
+ , MAKE_FLATPTR(GET_SEG(SS), &csw), sizeof(csw));
107
+ if (ret)
108
+ goto fail;
109
+
110
+ if (!csw.bCSWStatus)
111
+ return DISK_RET_SUCCESS;
112
+ if (csw.bCSWStatus == 2)
113
+ goto fail;
114
+
115
+ if (blocksize)
116
+ op->count -= csw.dCSWDataResidue / blocksize;
117
+ return DISK_RET_EBADTRACK;
118
+
119
+ fail:
120
+ // XXX - reset connection
121
+ dprintf(1, "USB transmission failed\n");
122
+ return DISK_RET_EBADTRACK;
123
+ }
124
+
125
+ static int
126
+ usb_msc_maxlun(struct usb_pipe *pipe)
127
+ {
128
+ struct usb_ctrlrequest req;
129
+ req.bRequestType = USB_DIR_IN | USB_TYPE_CLASS | USB_RECIP_INTERFACE;
130
+ req.bRequest = 0xfe;
131
+ req.wValue = 0;
132
+ req.wIndex = 0;
133
+ req.wLength = 1;
134
+ unsigned char maxlun;
135
+ int ret = usb_send_default_control(pipe, &req, &maxlun);
136
+ if (ret)
137
+ return 0;
138
+ return maxlun;
139
+ }
140
+
141
+ static int
142
+ usb_msc_lun_setup(struct usb_pipe *inpipe, struct usb_pipe *outpipe,
143
+ struct usbdevice_s *usbdev, int lun)
144
+ {
145
+ // Allocate drive structure.
146
+ struct usbdrive_s *drive = malloc_fseg(sizeof(*drive));
147
+ if (!drive) {
148
+ warn_noalloc();
149
+ return -1;
150
+ }
151
+ memset(drive, 0, sizeof(*drive));
152
+ if (usb_32bit_pipe(inpipe))
153
+ drive->drive.type = DTYPE_USB_32;
154
+ else
155
+ drive->drive.type = DTYPE_USB;
156
+ drive->bulkin = inpipe;
157
+ drive->bulkout = outpipe;
158
+ drive->lun = lun;
159
+
160
+ int prio = bootprio_find_usb(usbdev, lun);
161
+ int ret = scsi_drive_setup(&drive->drive, "USB MSC", prio);
162
+ if (ret) {
163
+ dprintf(1, "Unable to configure USB MSC drive.\n");
164
+ free(drive);
165
+ return -1;
166
+ }
167
+ return 0;
168
+ }
169
+
170
+ /****************************************************************
171
+ * Setup
172
+ ****************************************************************/
173
+
174
+ // Configure a usb msc device.
175
+ int
176
+ usb_msc_setup(struct usbdevice_s *usbdev)
177
+ {
178
+ if (!CONFIG_USB_MSC)
179
+ return -1;
180
+
181
+ // Verify right kind of device
182
+ struct usb_interface_descriptor *iface = usbdev->iface;
183
+ if ((iface->bInterfaceSubClass != US_SC_SCSI &&
184
+ iface->bInterfaceSubClass != US_SC_ATAPI_8070 &&
185
+ iface->bInterfaceSubClass != US_SC_ATAPI_8020)
186
+ || iface->bInterfaceProtocol != US_PR_BULK) {
187
+ dprintf(1, "Unsupported MSC USB device (subclass=%02x proto=%02x)\n"
188
+ , iface->bInterfaceSubClass, iface->bInterfaceProtocol);
189
+ return -1;
190
+ }
191
+
192
+ // Find bulk in and bulk out endpoints.
193
+ struct usb_pipe *inpipe = NULL, *outpipe = NULL;
194
+ struct usb_endpoint_descriptor *indesc = usb_find_desc(
195
+ usbdev, USB_ENDPOINT_XFER_BULK, USB_DIR_IN);
196
+ struct usb_endpoint_descriptor *outdesc = usb_find_desc(
197
+ usbdev, USB_ENDPOINT_XFER_BULK, USB_DIR_OUT);
198
+ if (!indesc || !outdesc)
199
+ goto fail;
200
+ inpipe = usb_alloc_pipe(usbdev, indesc);
201
+ outpipe = usb_alloc_pipe(usbdev, outdesc);
202
+ if (!inpipe || !outpipe)
203
+ goto fail;
204
+
205
+ int maxlun = usb_msc_maxlun(usbdev->defpipe);
206
+ int lun, pipesused = 0;
207
+ for (lun = 0; lun < maxlun + 1; lun++) {
208
+ int ret = usb_msc_lun_setup(inpipe, outpipe, usbdev, lun);
209
+ if (!ret)
210
+ pipesused = 1;
211
+ }
212
+
213
+ if (!pipesused)
214
+ goto fail;
215
+
216
+ return 0;
217
+ fail:
218
+ dprintf(1, "Unable to configure USB MSC device.\n");
219
+ usb_free_pipe(usbdev, inpipe);
220
+ usb_free_pipe(usbdev, outpipe);
221
+ return -1;
222
+ }
@@ -0,0 +1,10 @@
1
+ #ifndef __USB_MSC_H
2
+ #define __USB_MSC_H
3
+
4
+ // usb-msc.c
5
+ struct disk_op_s;
6
+ int usb_process_op(struct disk_op_s *op);
7
+ struct usbdevice_s;
8
+ int usb_msc_setup(struct usbdevice_s *usbdev);
9
+
10
+ #endif // ush-msc.h