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,398 @@
1
+ /*
2
+ LzmaDecode.c
3
+ LZMA Decoder (optimized for Speed version)
4
+
5
+ LZMA SDK 4.40 Copyright (c) 1999-2006 Igor Pavlov (2006-05-01)
6
+ http://www.7-zip.org/
7
+
8
+ LZMA SDK is licensed under two licenses:
9
+ 1) GNU Lesser General Public License (GNU LGPL)
10
+ 2) Common Public License (CPL)
11
+ It means that you can select one of these two licenses and
12
+ follow rules of that license.
13
+
14
+ SPECIAL EXCEPTION:
15
+ Igor Pavlov, as the author of this Code, expressly permits you to
16
+ statically or dynamically link your Code (or bind by name) to the
17
+ interfaces of this file without subjecting your linked Code to the
18
+ terms of the CPL or GNU LGPL. Any modifications or additions
19
+ to this file, however, are subject to the LGPL or CPL terms.
20
+ */
21
+
22
+ #include "lzmadecode.h"
23
+
24
+ #define kNumTopBits 24
25
+ #define kTopValue ((UInt32)1 << kNumTopBits)
26
+
27
+ #define kNumBitModelTotalBits 11
28
+ #define kBitModelTotal (1 << kNumBitModelTotalBits)
29
+ #define kNumMoveBits 5
30
+
31
+ #define RC_READ_BYTE (*Buffer++)
32
+
33
+ #define RC_INIT2 Code = 0; Range = 0xFFFFFFFF; \
34
+ { int i; for(i = 0; i < 5; i++) { RC_TEST; Code = (Code << 8) | RC_READ_BYTE; }}
35
+
36
+
37
+ #define RC_TEST { if (Buffer == BufferLim) return LZMA_RESULT_DATA_ERROR; }
38
+
39
+ #define RC_INIT(buffer, bufferSize) Buffer = buffer; BufferLim = buffer + bufferSize; RC_INIT2
40
+
41
+
42
+ #define RC_NORMALIZE if (Range < kTopValue) { RC_TEST; Range <<= 8; Code = (Code << 8) | RC_READ_BYTE; }
43
+
44
+ #define IfBit0(p) RC_NORMALIZE; bound = (Range >> kNumBitModelTotalBits) * *(p); if (Code < bound)
45
+ #define UpdateBit0(p) Range = bound; *(p) += (kBitModelTotal - *(p)) >> kNumMoveBits;
46
+ #define UpdateBit1(p) Range -= bound; Code -= bound; *(p) -= (*(p)) >> kNumMoveBits;
47
+
48
+ #define RC_GET_BIT2(p, mi, A0, A1) IfBit0(p) \
49
+ { UpdateBit0(p); mi <<= 1; A0; } else \
50
+ { UpdateBit1(p); mi = (mi + mi) + 1; A1; }
51
+
52
+ #define RC_GET_BIT(p, mi) RC_GET_BIT2(p, mi, ; , ;)
53
+
54
+ #define RangeDecoderBitTreeDecode(probs, numLevels, res) \
55
+ { int i = numLevels; res = 1; \
56
+ do { CProb *cp = probs + res; RC_GET_BIT(cp, res) } while(--i != 0); \
57
+ res -= (1 << numLevels); }
58
+
59
+
60
+ #define kNumPosBitsMax 4
61
+ #define kNumPosStatesMax (1 << kNumPosBitsMax)
62
+
63
+ #define kLenNumLowBits 3
64
+ #define kLenNumLowSymbols (1 << kLenNumLowBits)
65
+ #define kLenNumMidBits 3
66
+ #define kLenNumMidSymbols (1 << kLenNumMidBits)
67
+ #define kLenNumHighBits 8
68
+ #define kLenNumHighSymbols (1 << kLenNumHighBits)
69
+
70
+ #define LenChoice 0
71
+ #define LenChoice2 (LenChoice + 1)
72
+ #define LenLow (LenChoice2 + 1)
73
+ #define LenMid (LenLow + (kNumPosStatesMax << kLenNumLowBits))
74
+ #define LenHigh (LenMid + (kNumPosStatesMax << kLenNumMidBits))
75
+ #define kNumLenProbs (LenHigh + kLenNumHighSymbols)
76
+
77
+
78
+ #define kNumStates 12
79
+ #define kNumLitStates 7
80
+
81
+ #define kStartPosModelIndex 4
82
+ #define kEndPosModelIndex 14
83
+ #define kNumFullDistances (1 << (kEndPosModelIndex >> 1))
84
+
85
+ #define kNumPosSlotBits 6
86
+ #define kNumLenToPosStates 4
87
+
88
+ #define kNumAlignBits 4
89
+ #define kAlignTableSize (1 << kNumAlignBits)
90
+
91
+ #define kMatchMinLen 2
92
+
93
+ #define IsMatch 0
94
+ #define IsRep (IsMatch + (kNumStates << kNumPosBitsMax))
95
+ #define IsRepG0 (IsRep + kNumStates)
96
+ #define IsRepG1 (IsRepG0 + kNumStates)
97
+ #define IsRepG2 (IsRepG1 + kNumStates)
98
+ #define IsRep0Long (IsRepG2 + kNumStates)
99
+ #define PosSlot (IsRep0Long + (kNumStates << kNumPosBitsMax))
100
+ #define SpecPos (PosSlot + (kNumLenToPosStates << kNumPosSlotBits))
101
+ #define Align (SpecPos + kNumFullDistances - kEndPosModelIndex)
102
+ #define LenCoder (Align + kAlignTableSize)
103
+ #define RepLenCoder (LenCoder + kNumLenProbs)
104
+ #define Literal (RepLenCoder + kNumLenProbs)
105
+
106
+ #if Literal != LZMA_BASE_SIZE
107
+ StopCompilingDueBUG
108
+ #endif
109
+
110
+ int LzmaDecodeProperties(CLzmaProperties *propsRes, const unsigned char *propsData, int size)
111
+ {
112
+ unsigned char prop0;
113
+ if (size < LZMA_PROPERTIES_SIZE)
114
+ return LZMA_RESULT_DATA_ERROR;
115
+ prop0 = propsData[0];
116
+ if (prop0 >= (9 * 5 * 5))
117
+ return LZMA_RESULT_DATA_ERROR;
118
+ {
119
+ for (propsRes->pb = 0; prop0 >= (9 * 5); propsRes->pb++, prop0 -= (9 * 5));
120
+ for (propsRes->lp = 0; prop0 >= 9; propsRes->lp++, prop0 -= 9);
121
+ propsRes->lc = prop0;
122
+ /*
123
+ unsigned char remainder = (unsigned char)(prop0 / 9);
124
+ propsRes->lc = prop0 % 9;
125
+ propsRes->pb = remainder / 5;
126
+ propsRes->lp = remainder % 5;
127
+ */
128
+ }
129
+
130
+ return LZMA_RESULT_OK;
131
+ }
132
+
133
+ #define kLzmaStreamWasFinishedId (-1)
134
+
135
+ int LzmaDecode(CLzmaDecoderState *vs,
136
+ const unsigned char *inStream, SizeT inSize, SizeT *inSizeProcessed,
137
+ unsigned char *outStream, SizeT outSize, SizeT *outSizeProcessed)
138
+ {
139
+ CProb *p = vs->Probs;
140
+ SizeT nowPos = 0;
141
+ Byte previousByte = 0;
142
+ UInt32 posStateMask = (1 << (vs->Properties.pb)) - 1;
143
+ UInt32 literalPosMask = (1 << (vs->Properties.lp)) - 1;
144
+ int lc = vs->Properties.lc;
145
+
146
+
147
+ int state = 0;
148
+ UInt32 rep0 = 1, rep1 = 1, rep2 = 1, rep3 = 1;
149
+ int len = 0;
150
+ const Byte *Buffer;
151
+ const Byte *BufferLim;
152
+ UInt32 Range;
153
+ UInt32 Code;
154
+
155
+ *inSizeProcessed = 0;
156
+ *outSizeProcessed = 0;
157
+
158
+ {
159
+ UInt32 i;
160
+ UInt32 numProbs = Literal + ((UInt32)LZMA_LIT_SIZE << (lc + vs->Properties.lp));
161
+ for (i = 0; i < numProbs; i++)
162
+ p[i] = kBitModelTotal >> 1;
163
+ }
164
+
165
+ RC_INIT(inStream, inSize);
166
+
167
+
168
+ while(nowPos < outSize)
169
+ {
170
+ CProb *prob;
171
+ UInt32 bound;
172
+ int posState = (int)(
173
+ (nowPos
174
+ )
175
+ & posStateMask);
176
+
177
+ prob = p + IsMatch + (state << kNumPosBitsMax) + posState;
178
+ IfBit0(prob)
179
+ {
180
+ int symbol = 1;
181
+ UpdateBit0(prob)
182
+ prob = p + Literal + (LZMA_LIT_SIZE *
183
+ (((
184
+ (nowPos
185
+ )
186
+ & literalPosMask) << lc) + (previousByte >> (8 - lc))));
187
+
188
+ if (state >= kNumLitStates)
189
+ {
190
+ int matchByte;
191
+ matchByte = outStream[nowPos - rep0];
192
+ do
193
+ {
194
+ int bit;
195
+ CProb *probLit;
196
+ matchByte <<= 1;
197
+ bit = (matchByte & 0x100);
198
+ probLit = prob + 0x100 + bit + symbol;
199
+ RC_GET_BIT2(probLit, symbol, if (bit != 0) break, if (bit == 0) break)
200
+ }
201
+ while (symbol < 0x100);
202
+ }
203
+ while (symbol < 0x100)
204
+ {
205
+ CProb *probLit = prob + symbol;
206
+ RC_GET_BIT(probLit, symbol)
207
+ }
208
+ previousByte = (Byte)symbol;
209
+
210
+ outStream[nowPos++] = previousByte;
211
+ if (state < 4) state = 0;
212
+ else if (state < 10) state -= 3;
213
+ else state -= 6;
214
+ }
215
+ else
216
+ {
217
+ UpdateBit1(prob);
218
+ prob = p + IsRep + state;
219
+ IfBit0(prob)
220
+ {
221
+ UpdateBit0(prob);
222
+ rep3 = rep2;
223
+ rep2 = rep1;
224
+ rep1 = rep0;
225
+ state = state < kNumLitStates ? 0 : 3;
226
+ prob = p + LenCoder;
227
+ }
228
+ else
229
+ {
230
+ UpdateBit1(prob);
231
+ prob = p + IsRepG0 + state;
232
+ IfBit0(prob)
233
+ {
234
+ UpdateBit0(prob);
235
+ prob = p + IsRep0Long + (state << kNumPosBitsMax) + posState;
236
+ IfBit0(prob)
237
+ {
238
+ UpdateBit0(prob);
239
+
240
+ if (nowPos == 0)
241
+ return LZMA_RESULT_DATA_ERROR;
242
+
243
+ state = state < kNumLitStates ? 9 : 11;
244
+ previousByte = outStream[nowPos - rep0];
245
+ outStream[nowPos++] = previousByte;
246
+
247
+ continue;
248
+ }
249
+ else
250
+ {
251
+ UpdateBit1(prob);
252
+ }
253
+ }
254
+ else
255
+ {
256
+ UInt32 distance;
257
+ UpdateBit1(prob);
258
+ prob = p + IsRepG1 + state;
259
+ IfBit0(prob)
260
+ {
261
+ UpdateBit0(prob);
262
+ distance = rep1;
263
+ }
264
+ else
265
+ {
266
+ UpdateBit1(prob);
267
+ prob = p + IsRepG2 + state;
268
+ IfBit0(prob)
269
+ {
270
+ UpdateBit0(prob);
271
+ distance = rep2;
272
+ }
273
+ else
274
+ {
275
+ UpdateBit1(prob);
276
+ distance = rep3;
277
+ rep3 = rep2;
278
+ }
279
+ rep2 = rep1;
280
+ }
281
+ rep1 = rep0;
282
+ rep0 = distance;
283
+ }
284
+ state = state < kNumLitStates ? 8 : 11;
285
+ prob = p + RepLenCoder;
286
+ }
287
+ {
288
+ int numBits, offset;
289
+ CProb *probLen = prob + LenChoice;
290
+ IfBit0(probLen)
291
+ {
292
+ UpdateBit0(probLen);
293
+ probLen = prob + LenLow + (posState << kLenNumLowBits);
294
+ offset = 0;
295
+ numBits = kLenNumLowBits;
296
+ }
297
+ else
298
+ {
299
+ UpdateBit1(probLen);
300
+ probLen = prob + LenChoice2;
301
+ IfBit0(probLen)
302
+ {
303
+ UpdateBit0(probLen);
304
+ probLen = prob + LenMid + (posState << kLenNumMidBits);
305
+ offset = kLenNumLowSymbols;
306
+ numBits = kLenNumMidBits;
307
+ }
308
+ else
309
+ {
310
+ UpdateBit1(probLen);
311
+ probLen = prob + LenHigh;
312
+ offset = kLenNumLowSymbols + kLenNumMidSymbols;
313
+ numBits = kLenNumHighBits;
314
+ }
315
+ }
316
+ RangeDecoderBitTreeDecode(probLen, numBits, len);
317
+ len += offset;
318
+ }
319
+
320
+ if (state < 4)
321
+ {
322
+ int posSlot;
323
+ state += kNumLitStates;
324
+ prob = p + PosSlot +
325
+ ((len < kNumLenToPosStates ? len : kNumLenToPosStates - 1) <<
326
+ kNumPosSlotBits);
327
+ RangeDecoderBitTreeDecode(prob, kNumPosSlotBits, posSlot);
328
+ if (posSlot >= kStartPosModelIndex)
329
+ {
330
+ int numDirectBits = ((posSlot >> 1) - 1);
331
+ rep0 = (2 | ((UInt32)posSlot & 1));
332
+ if (posSlot < kEndPosModelIndex)
333
+ {
334
+ rep0 <<= numDirectBits;
335
+ prob = p + SpecPos + rep0 - posSlot - 1;
336
+ }
337
+ else
338
+ {
339
+ numDirectBits -= kNumAlignBits;
340
+ do
341
+ {
342
+ RC_NORMALIZE
343
+ Range >>= 1;
344
+ rep0 <<= 1;
345
+ if (Code >= Range)
346
+ {
347
+ Code -= Range;
348
+ rep0 |= 1;
349
+ }
350
+ }
351
+ while (--numDirectBits != 0);
352
+ prob = p + Align;
353
+ rep0 <<= kNumAlignBits;
354
+ numDirectBits = kNumAlignBits;
355
+ }
356
+ {
357
+ int i = 1;
358
+ int mi = 1;
359
+ do
360
+ {
361
+ CProb *prob3 = prob + mi;
362
+ RC_GET_BIT2(prob3, mi, ; , rep0 |= i);
363
+ i <<= 1;
364
+ }
365
+ while(--numDirectBits != 0);
366
+ }
367
+ }
368
+ else
369
+ rep0 = posSlot;
370
+ if (++rep0 == (UInt32)(0))
371
+ {
372
+ /* it's for stream version */
373
+ len = kLzmaStreamWasFinishedId;
374
+ break;
375
+ }
376
+ }
377
+
378
+ len += kMatchMinLen;
379
+ if (rep0 > nowPos)
380
+ return LZMA_RESULT_DATA_ERROR;
381
+
382
+
383
+ do
384
+ {
385
+ previousByte = outStream[nowPos - rep0];
386
+ len--;
387
+ outStream[nowPos++] = previousByte;
388
+ }
389
+ while(len != 0 && nowPos < outSize);
390
+ }
391
+ }
392
+ RC_NORMALIZE;
393
+
394
+
395
+ *inSizeProcessed = (SizeT)(Buffer - inStream);
396
+ *outSizeProcessed = nowPos;
397
+ return LZMA_RESULT_OK;
398
+ }
@@ -0,0 +1,67 @@
1
+ /*
2
+ LzmaDecode.h
3
+ LZMA Decoder interface
4
+
5
+ LZMA SDK 4.40 Copyright (c) 1999-2006 Igor Pavlov (2006-05-01)
6
+ http://www.7-zip.org/
7
+
8
+ LZMA SDK is licensed under two licenses:
9
+ 1) GNU Lesser General Public License (GNU LGPL)
10
+ 2) Common Public License (CPL)
11
+ It means that you can select one of these two licenses and
12
+ follow rules of that license.
13
+
14
+ SPECIAL EXCEPTION:
15
+ Igor Pavlov, as the author of this code, expressly permits you to
16
+ statically or dynamically link your code (or bind by name) to the
17
+ interfaces of this file without subjecting your linked code to the
18
+ terms of the CPL or GNU LGPL. Any modifications or additions
19
+ to this file, however, are subject to the LGPL or CPL terms.
20
+ */
21
+
22
+ #ifndef __LZMADECODE_H
23
+ #define __LZMADECODE_H
24
+
25
+ typedef unsigned char Byte;
26
+ typedef unsigned short UInt16;
27
+ typedef unsigned int UInt32;
28
+ typedef UInt32 SizeT;
29
+
30
+ #define CProb UInt16
31
+
32
+ #define LZMA_RESULT_OK 0
33
+ #define LZMA_RESULT_DATA_ERROR 1
34
+
35
+
36
+ #define LZMA_BASE_SIZE 1846
37
+ #define LZMA_LIT_SIZE 768
38
+
39
+ #define LZMA_PROPERTIES_SIZE 5
40
+
41
+ typedef struct _CLzmaProperties
42
+ {
43
+ int lc;
44
+ int lp;
45
+ int pb;
46
+ }CLzmaProperties;
47
+
48
+ int LzmaDecodeProperties(CLzmaProperties *propsRes, const unsigned char *propsData, int size);
49
+
50
+ #define LzmaGetNumProbs(Properties) (LZMA_BASE_SIZE + (LZMA_LIT_SIZE << ((Properties)->lc + (Properties)->lp)))
51
+
52
+ #define kLzmaNeedInitId (-2)
53
+
54
+ typedef struct _CLzmaDecoderState
55
+ {
56
+ CLzmaProperties Properties;
57
+ CProb *Probs;
58
+
59
+
60
+ } CLzmaDecoderState;
61
+
62
+
63
+ int LzmaDecode(CLzmaDecoderState *vs,
64
+ const unsigned char *inStream, SizeT inSize, SizeT *inSizeProcessed,
65
+ unsigned char *outStream, SizeT outSize, SizeT *outSizeProcessed);
66
+
67
+ #endif
@@ -0,0 +1,197 @@
1
+ // MPTable generation (on emulators)
2
+ // DO NOT ADD NEW FEATURES HERE. (See paravirt.c / biostables.c instead.)
3
+ //
4
+ // Copyright (C) 2008-2010 Kevin O'Connor <kevin@koconnor.net>
5
+ // Copyright (C) 2006 Fabrice Bellard
6
+ //
7
+ // This file may be distributed under the terms of the GNU LGPLv3 license.
8
+
9
+ #include "config.h" // CONFIG_*
10
+ #include "hw/pci.h" // pci_bdf_to_bus
11
+ #include "hw/pcidevice.h" // foreachpci
12
+ #include "hw/pci_regs.h" // PCI_INTERRUPT_PIN
13
+ #include "malloc.h" // free
14
+ #include "output.h" // dprintf
15
+ #include "romfile.h" // romfile_loadint
16
+ #include "std/mptable.h" // MPTABLE_SIGNATURE
17
+ #include "string.h" // memset
18
+ #include "util.h" // MaxCountCPUs
19
+ #include "x86.h" // cpuid
20
+
21
+ void
22
+ mptable_setup(void)
23
+ {
24
+ if (! CONFIG_MPTABLE)
25
+ return;
26
+
27
+ dprintf(3, "init MPTable\n");
28
+
29
+ // Config structure in temp area.
30
+ struct mptable_config_s *config = malloc_tmp(32*1024);
31
+ if (!config) {
32
+ warn_noalloc();
33
+ return;
34
+ }
35
+ memset(config, 0, sizeof(*config));
36
+ config->signature = MPCONFIG_SIGNATURE;
37
+ config->spec = 4;
38
+ memcpy(config->oemid, BUILD_CPUNAME8, sizeof(config->oemid));
39
+ memcpy(config->productid, "0.1 ", sizeof(config->productid));
40
+ config->lapic = BUILD_APIC_ADDR;
41
+
42
+ // Detect cpu info
43
+ u32 cpuid_signature, ebx, ecx, cpuid_features;
44
+ cpuid(1, &cpuid_signature, &ebx, &ecx, &cpuid_features);
45
+ if (! cpuid_signature) {
46
+ // Use default values.
47
+ cpuid_signature = 0x600;
48
+ cpuid_features = 0x201;
49
+ }
50
+ int pkgcpus = 1;
51
+ if (cpuid_features & (1 << 28)) {
52
+ /* Only populate the MPS tables with the first logical CPU in
53
+ each package */
54
+ pkgcpus = (ebx >> 16) & 0xff;
55
+ pkgcpus = 1 << (__fls(pkgcpus - 1) + 1); /* round up to power of 2 */
56
+ }
57
+ u8 apic_version = readl((u8*)BUILD_APIC_ADDR + 0x30) & 0xff;
58
+
59
+ // CPU definitions.
60
+ struct mpt_cpu *cpus = (void*)&config[1], *cpu = cpus;
61
+ int i;
62
+ for (i = 0; i < MaxCountCPUs; i+=pkgcpus) {
63
+ memset(cpu, 0, sizeof(*cpu));
64
+ cpu->type = MPT_TYPE_CPU;
65
+ cpu->apicid = i;
66
+ cpu->apicver = apic_version;
67
+ /* cpu flags: enabled, bootstrap cpu */
68
+ cpu->cpuflag = (apic_id_is_present(i) ? 0x01 : 0x00) | ((i==0) ? 0x02 : 0x00);
69
+ cpu->cpusignature = cpuid_signature;
70
+ cpu->featureflag = cpuid_features;
71
+ cpu++;
72
+ }
73
+ int entrycount = cpu - cpus;
74
+
75
+ // PCI bus
76
+ struct mpt_bus *buses = (void*)cpu, *bus = buses;
77
+ if (!hlist_empty(&PCIDevices)) {
78
+ memset(bus, 0, sizeof(*bus));
79
+ bus->type = MPT_TYPE_BUS;
80
+ bus->busid = 0;
81
+ memcpy(bus->bustype, "PCI ", sizeof(bus->bustype));
82
+ bus++;
83
+ entrycount++;
84
+ }
85
+
86
+ /* isa bus */
87
+ int isabusid = bus - buses;
88
+ memset(bus, 0, sizeof(*bus));
89
+ bus->type = MPT_TYPE_BUS;
90
+ bus->busid = isabusid;
91
+ memcpy(bus->bustype, "ISA ", sizeof(bus->bustype));
92
+ bus++;
93
+ entrycount++;
94
+
95
+ /* ioapic */
96
+ u8 ioapic_id = BUILD_IOAPIC_ID;
97
+ struct mpt_ioapic *ioapic = (void*)bus;
98
+ memset(ioapic, 0, sizeof(*ioapic));
99
+ ioapic->type = MPT_TYPE_IOAPIC;
100
+ ioapic->apicid = ioapic_id;
101
+ ioapic->apicver = 0x11;
102
+ ioapic->flags = 1; // enable
103
+ ioapic->apicaddr = BUILD_IOAPIC_ADDR;
104
+ entrycount++;
105
+
106
+ /* irqs */
107
+ struct mpt_intsrc *intsrcs = (void*)&ioapic[1], *intsrc = intsrcs;
108
+ int dev = -1;
109
+ unsigned short pinmask = 0;
110
+
111
+ struct pci_device *pci;
112
+ foreachpci(pci) {
113
+ u16 bdf = pci->bdf;
114
+ if (pci_bdf_to_bus(bdf) != 0)
115
+ break;
116
+ int pin = pci_config_readb(bdf, PCI_INTERRUPT_PIN);
117
+ int irq = pci_config_readb(bdf, PCI_INTERRUPT_LINE);
118
+ if (pin == 0)
119
+ continue;
120
+ if (dev != pci_bdf_to_busdev(bdf)) {
121
+ dev = pci_bdf_to_busdev(bdf);
122
+ pinmask = 0;
123
+ }
124
+ if (pinmask & (1 << pin)) /* pin was seen already */
125
+ continue;
126
+ pinmask |= (1 << pin);
127
+ memset(intsrc, 0, sizeof(*intsrc));
128
+ intsrc->type = MPT_TYPE_INTSRC;
129
+ intsrc->irqtype = 0; /* INT */
130
+ intsrc->irqflag = 1; /* active high */
131
+ intsrc->srcbus = pci_bdf_to_bus(bdf); /* PCI bus */
132
+ intsrc->srcbusirq = (pci_bdf_to_dev(bdf) << 2) | (pin - 1);
133
+ intsrc->dstapic = ioapic_id;
134
+ intsrc->dstirq = irq;
135
+ intsrc++;
136
+ }
137
+
138
+ int irq0_override = romfile_loadint("etc/irq0-override", 0);
139
+ for (i = 0; i < 16; i++) {
140
+ memset(intsrc, 0, sizeof(*intsrc));
141
+ if (BUILD_PCI_IRQS & (1 << i))
142
+ continue;
143
+ intsrc->type = MPT_TYPE_INTSRC;
144
+ intsrc->irqtype = 0; /* INT */
145
+ intsrc->irqflag = 0; /* conform to bus spec */
146
+ intsrc->srcbus = isabusid; /* ISA bus */
147
+ intsrc->srcbusirq = i;
148
+ intsrc->dstapic = ioapic_id;
149
+ intsrc->dstirq = i;
150
+ if (irq0_override) {
151
+ /* Destination 2 is covered by irq0->inti2 override (i ==
152
+ 0). Source IRQ 2 is unused */
153
+ if (i == 0)
154
+ intsrc->dstirq = 2;
155
+ else if (i == 2)
156
+ intsrc--;
157
+ }
158
+ intsrc++;
159
+ }
160
+
161
+ /* Local interrupt assignment */
162
+ intsrc->type = MPT_TYPE_LOCAL_INT;
163
+ intsrc->irqtype = 3; /* ExtINT */
164
+ intsrc->irqflag = 0; /* PO, EL default */
165
+ intsrc->srcbus = isabusid; /* ISA */
166
+ intsrc->srcbusirq = 0;
167
+ intsrc->dstapic = 0; /* BSP == APIC #0 */
168
+ intsrc->dstirq = 0; /* LINTIN0 */
169
+ intsrc++;
170
+
171
+ intsrc->type = MPT_TYPE_LOCAL_INT;
172
+ intsrc->irqtype = 1; /* NMI */
173
+ intsrc->irqflag = 0; /* PO, EL default */
174
+ intsrc->srcbus = isabusid; /* ISA */
175
+ intsrc->srcbusirq = 0;
176
+ intsrc->dstapic = 0xff; /* to all local APICs */
177
+ intsrc->dstirq = 1; /* LINTIN1 */
178
+ intsrc++;
179
+ entrycount += intsrc - intsrcs;
180
+
181
+ // Finalize config structure.
182
+ int length = (void*)intsrc - (void*)config;
183
+ config->entrycount = entrycount;
184
+ config->length = length;
185
+ config->checksum -= checksum(config, length);
186
+
187
+ // floating pointer structure
188
+ struct mptable_floating_s floating;
189
+ memset(&floating, 0, sizeof(floating));
190
+ floating.signature = MPTABLE_SIGNATURE;
191
+ floating.physaddr = (u32)config;
192
+ floating.length = 1;
193
+ floating.spec_rev = 4;
194
+ floating.checksum -= checksum(&floating, sizeof(floating));
195
+ copy_mptable(&floating);
196
+ free(config);
197
+ }