v86 0.3.6 → 0.4.0

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 +17 -6
  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,337 @@
1
+ // 32bit code to Power On Self Test (POST) a machine.
2
+ //
3
+ // Copyright (C) 2008-2013 Kevin O'Connor <kevin@koconnor.net>
4
+ // Copyright (C) 2002 MandrakeSoft S.A.
5
+ //
6
+ // This file may be distributed under the terms of the GNU LGPLv3 license.
7
+
8
+ #include "biosvar.h" // SET_BDA
9
+ #include "block.h" // block_setup
10
+ #include "bregs.h" // struct bregs
11
+ #include "config.h" // CONFIG_*
12
+ #include "e820map.h" // e820_add
13
+ #include "fw/paravirt.h" // qemu_cfg_preinit
14
+ #include "fw/xen.h" // xen_preinit
15
+ #include "hw/pic.h" // pic_setup
16
+ #include "hw/ps2port.h" // ps2port_setup
17
+ #include "hw/rtc.h" // rtc_write
18
+ #include "hw/serialio.h" // serial_debug_preinit
19
+ #include "hw/usb.h" // usb_setup
20
+ #include "malloc.h" // malloc_init
21
+ #include "memmap.h" // SYMBOL
22
+ #include "output.h" // dprintf
23
+ #include "string.h" // memset
24
+ #include "util.h" // kbd_init
25
+ #include "tcgbios.h" // tpm_*
26
+
27
+
28
+ /****************************************************************
29
+ * BIOS initialization and hardware setup
30
+ ****************************************************************/
31
+
32
+ static void
33
+ ivt_init(void)
34
+ {
35
+ dprintf(3, "init ivt\n");
36
+
37
+ // Initialize all vectors to the default handler.
38
+ int i;
39
+ for (i=0; i<256; i++)
40
+ SET_IVT(i, FUNC16(entry_iret_official));
41
+
42
+ // Initialize all hw vectors to a default hw handler.
43
+ for (i=BIOS_HWIRQ0_VECTOR; i<BIOS_HWIRQ0_VECTOR+8; i++)
44
+ SET_IVT(i, FUNC16(entry_hwpic1));
45
+ for (i=BIOS_HWIRQ8_VECTOR; i<BIOS_HWIRQ8_VECTOR+8; i++)
46
+ SET_IVT(i, FUNC16(entry_hwpic2));
47
+
48
+ // Initialize software handlers.
49
+ SET_IVT(0x02, FUNC16(entry_02));
50
+ SET_IVT(0x05, FUNC16(entry_05));
51
+ SET_IVT(0x10, FUNC16(entry_10));
52
+ SET_IVT(0x11, FUNC16(entry_11));
53
+ SET_IVT(0x12, FUNC16(entry_12));
54
+ SET_IVT(0x13, FUNC16(entry_13_official));
55
+ SET_IVT(0x14, FUNC16(entry_14));
56
+ SET_IVT(0x15, FUNC16(entry_15_official));
57
+ SET_IVT(0x16, FUNC16(entry_16));
58
+ SET_IVT(0x17, FUNC16(entry_17));
59
+ SET_IVT(0x18, FUNC16(entry_18));
60
+ SET_IVT(0x19, FUNC16(entry_19_official));
61
+ SET_IVT(0x1a, FUNC16(entry_1a_official));
62
+ SET_IVT(0x40, FUNC16(entry_40));
63
+
64
+ // INT 60h-66h reserved for user interrupt
65
+ for (i=0x60; i<=0x66; i++)
66
+ SET_IVT(i, SEGOFF(0, 0));
67
+
68
+ // set vector 0x79 to zero
69
+ // this is used by 'gardian angel' protection system
70
+ SET_IVT(0x79, SEGOFF(0, 0));
71
+ }
72
+
73
+ static void
74
+ bda_init(void)
75
+ {
76
+ dprintf(3, "init bda\n");
77
+
78
+ struct bios_data_area_s *bda = MAKE_FLATPTR(SEG_BDA, 0);
79
+ memset(bda, 0, sizeof(*bda));
80
+
81
+ int esize = EBDA_SIZE_START;
82
+ u16 ebda_seg = EBDA_SEGMENT_START;
83
+ if (!CONFIG_MALLOC_UPPERMEMORY)
84
+ ebda_seg = FLATPTR_TO_SEG(ALIGN_DOWN(SYMBOL(final_varlow_start), 1024)
85
+ - EBDA_SIZE_START*1024);
86
+ SET_BDA(ebda_seg, ebda_seg);
87
+
88
+ SET_BDA(mem_size_kb, ebda_seg / (1024/16));
89
+
90
+ // Init ebda
91
+ struct extended_bios_data_area_s *ebda = get_ebda_ptr();
92
+ memset(ebda, 0, sizeof(*ebda));
93
+ ebda->size = esize;
94
+
95
+ e820_add((u32)ebda, BUILD_LOWRAM_END-(u32)ebda, E820_RESERVED);
96
+
97
+ // Init extra stack
98
+ StackPos = &ExtraStack[BUILD_EXTRA_STACK_SIZE] - SYMBOL(zonelow_base);
99
+ }
100
+
101
+ void
102
+ interface_init(void)
103
+ {
104
+ // Running at new code address - do code relocation fixups
105
+ malloc_init();
106
+
107
+ // Setup romfile items.
108
+ qemu_cfg_init();
109
+ coreboot_cbfs_init();
110
+ multiboot_init();
111
+
112
+ // Setup ivt/bda/ebda
113
+ ivt_init();
114
+ bda_init();
115
+
116
+ // Other interfaces
117
+ boot_init();
118
+ bios32_init();
119
+ pmm_init();
120
+ pnp_init();
121
+ kbd_init();
122
+ mouse_init();
123
+ }
124
+
125
+ // Initialize hardware devices
126
+ void
127
+ device_hardware_setup(void)
128
+ {
129
+ usb_setup();
130
+ ps2port_setup();
131
+ block_setup();
132
+ lpt_setup();
133
+ serial_setup();
134
+ cbfs_payload_setup();
135
+ }
136
+
137
+ static void
138
+ platform_hardware_setup(void)
139
+ {
140
+ // Make sure legacy DMA isn't running.
141
+ dma_setup();
142
+
143
+ // Init base pc hardware.
144
+ pic_setup();
145
+ thread_setup();
146
+ mathcp_setup();
147
+
148
+ // Platform specific setup
149
+ qemu_platform_setup();
150
+ coreboot_platform_setup();
151
+
152
+ // Setup timers and periodic clock interrupt
153
+ timer_setup();
154
+ clock_setup();
155
+
156
+ // Initialize TPM
157
+ tpm_setup();
158
+ }
159
+
160
+ void
161
+ prepareboot(void)
162
+ {
163
+ // Change TPM phys. presence state befor leaving BIOS
164
+ tpm_prepboot();
165
+
166
+ // Run BCVs
167
+ bcv_prepboot();
168
+
169
+ // Finalize data structures before boot
170
+ cdrom_prepboot();
171
+ pmm_prepboot();
172
+ malloc_prepboot();
173
+ e820_prepboot();
174
+
175
+ HaveRunPost = 2;
176
+
177
+ // Setup bios checksum.
178
+ BiosChecksum -= checksum((u8*)BUILD_BIOS_ADDR, BUILD_BIOS_SIZE);
179
+ }
180
+
181
+ // Begin the boot process by invoking an int0x19 in 16bit mode.
182
+ void VISIBLE32FLAT
183
+ startBoot(void)
184
+ {
185
+ // Clear low-memory allocations (required by PMM spec).
186
+ memset((void*)BUILD_STACK_ADDR, 0, BUILD_EBDA_MINIMUM - BUILD_STACK_ADDR);
187
+
188
+ dprintf(3, "Jump to int19\n");
189
+ struct bregs br;
190
+ memset(&br, 0, sizeof(br));
191
+ br.flags = F_IF;
192
+ call16_int(0x19, &br);
193
+ }
194
+
195
+ // Main setup code.
196
+ static void
197
+ maininit(void)
198
+ {
199
+ // Initialize internal interfaces.
200
+ interface_init();
201
+
202
+ // Setup platform devices.
203
+ platform_hardware_setup();
204
+
205
+ // Start hardware initialization (if threads allowed during optionroms)
206
+ if (threads_during_optionroms())
207
+ device_hardware_setup();
208
+
209
+ // Run vga option rom
210
+ vgarom_setup();
211
+ sercon_setup();
212
+ enable_vga_console();
213
+
214
+ // Do hardware initialization (if running synchronously)
215
+ if (!threads_during_optionroms()) {
216
+ device_hardware_setup();
217
+ wait_threads();
218
+ }
219
+
220
+ // Run option roms
221
+ optionrom_setup();
222
+
223
+ // Allow user to modify overall boot order.
224
+ interactive_bootmenu();
225
+ wait_threads();
226
+
227
+ // Prepare for boot.
228
+ prepareboot();
229
+
230
+ // Write protect bios memory.
231
+ make_bios_readonly();
232
+
233
+ // Invoke int 19 to start boot process.
234
+ startBoot();
235
+ }
236
+
237
+
238
+ /****************************************************************
239
+ * POST entry and code relocation
240
+ ****************************************************************/
241
+
242
+ // Update given relocs for the code at 'dest' with a given 'delta'
243
+ static void
244
+ updateRelocs(void *dest, u32 *rstart, u32 *rend, u32 delta)
245
+ {
246
+ u32 *reloc;
247
+ for (reloc = rstart; reloc < rend; reloc++)
248
+ *((u32*)(dest + *reloc)) += delta;
249
+ }
250
+
251
+ // Relocate init code and then call a function at its new address.
252
+ // The passed function should be in the "init" section and must not
253
+ // return.
254
+ void __noreturn
255
+ reloc_preinit(void *f, void *arg)
256
+ {
257
+ void (*func)(void *) __noreturn = f;
258
+ if (!CONFIG_RELOCATE_INIT)
259
+ func(arg);
260
+
261
+ // Allocate space for init code.
262
+ u32 initsize = SYMBOL(code32init_end) - SYMBOL(code32init_start);
263
+ u32 codealign = SYMBOL(_reloc_min_align);
264
+ void *codedest = memalign_tmp(codealign, initsize);
265
+ void *codesrc = VSYMBOL(code32init_start);
266
+ if (!codedest)
267
+ panic("No space for init relocation.\n");
268
+
269
+ // Copy code and update relocs (init absolute, init relative, and runtime)
270
+ dprintf(1, "Relocating init from %p to %p (size %d)\n"
271
+ , codesrc, codedest, initsize);
272
+ s32 delta = codedest - codesrc;
273
+ memcpy(codedest, codesrc, initsize);
274
+ updateRelocs(codedest, VSYMBOL(_reloc_abs_start), VSYMBOL(_reloc_abs_end)
275
+ , delta);
276
+ updateRelocs(codedest, VSYMBOL(_reloc_rel_start), VSYMBOL(_reloc_rel_end)
277
+ , -delta);
278
+ updateRelocs(VSYMBOL(code32flat_start), VSYMBOL(_reloc_init_start)
279
+ , VSYMBOL(_reloc_init_end), delta);
280
+ if (f >= codesrc && f < VSYMBOL(code32init_end))
281
+ func = f + delta;
282
+
283
+ // Call function in relocated code.
284
+ barrier();
285
+ func(arg);
286
+ }
287
+
288
+ // Runs after all code is present and prior to any modifications
289
+ void
290
+ code_mutable_preinit(void)
291
+ {
292
+ if (HaveRunPost)
293
+ // Already run
294
+ return;
295
+ // Setup reset-vector entry point (controls legacy reboots).
296
+ rtc_write(CMOS_RESET_CODE, 0);
297
+ barrier();
298
+ HaveRunPost = 1;
299
+ barrier();
300
+ }
301
+
302
+ // Setup for code relocation and then relocate.
303
+ void VISIBLE32INIT
304
+ dopost(void)
305
+ {
306
+ code_mutable_preinit();
307
+
308
+ // Detect ram and setup internal malloc.
309
+ qemu_preinit();
310
+ coreboot_preinit();
311
+ malloc_preinit();
312
+
313
+ // Relocate initialization code and call maininit().
314
+ reloc_preinit(maininit, NULL);
315
+ }
316
+
317
+ // Entry point for Power On Self Test (POST) - the BIOS initilization
318
+ // phase. This function makes the memory at 0xc0000-0xfffff
319
+ // read/writable and then calls dopost().
320
+ void VISIBLE32FLAT
321
+ handle_post(void)
322
+ {
323
+ if (!CONFIG_QEMU && !CONFIG_COREBOOT)
324
+ return;
325
+
326
+ serial_debug_preinit();
327
+ debug_banner();
328
+
329
+ // Check if we are running under Xen.
330
+ xen_preinit();
331
+
332
+ // Allow writes to modify bios area (0xf0000)
333
+ make_bios_writable();
334
+
335
+ // Now that memory is read/writable - start post process.
336
+ dopost();
337
+ }
@@ -0,0 +1,157 @@
1
+ // Code for handling calls to "post" that are resume related.
2
+ //
3
+ // Copyright (C) 2008,2009 Kevin O'Connor <kevin@koconnor.net>
4
+ //
5
+ // This file may be distributed under the terms of the GNU LGPLv3 license.
6
+
7
+ #include "bregs.h" // struct bregs
8
+ #include "config.h" // CONFIG_*
9
+ #include "farptr.h" // FLATPTR_TO_SEGOFF
10
+ #include "hw/pci.h" // pci_reboot
11
+ #include "hw/pic.h" // pic_eoi2
12
+ #include "hw/ps2port.h" // i8042_reboot
13
+ #include "hw/rtc.h" // rtc_read
14
+ #include "output.h" // dprintf
15
+ #include "stacks.h" // farcall16big
16
+ #include "std/bda.h" // struct bios_data_area_s
17
+ #include "string.h" // memset
18
+ #include "util.h" // dma_setup
19
+ #include "tcgbios.h" // tpm_s3_resume
20
+ #include "fw/romfile_loader.h" // romfile_fw_cfg_resume
21
+
22
+ // Handler for post calls that look like a resume.
23
+ void VISIBLE16
24
+ handle_resume(void)
25
+ {
26
+ ASSERT16();
27
+ int status = rtc_read(CMOS_RESET_CODE);
28
+ rtc_write(CMOS_RESET_CODE, 0);
29
+ dprintf(1, "In resume (status=%d)\n", status);
30
+
31
+ dma_setup();
32
+
33
+ switch (status) {
34
+ case 0x01 ... 0x04:
35
+ case 0x06 ... 0x09:
36
+ panic("Unimplemented shutdown status: %02x\n", status);
37
+
38
+ case 0x05:
39
+ // flush keyboard (issue EOI) and jump via 40h:0067h
40
+ pic_eoi2();
41
+ // NO BREAK
42
+ case 0x0a:
43
+ #define BDA_JUMP (((struct bios_data_area_s *)0)->jump)
44
+ // resume execution by jump via 40h:0067h
45
+ asm volatile(
46
+ "movw %w1, %%ds\n"
47
+ "ljmpw *%0\n"
48
+ : : "m"(BDA_JUMP), "r"(SEG_BDA)
49
+ );
50
+ break;
51
+
52
+ case 0x0b:
53
+ // resume execution via IRET via 40h:0067h
54
+ asm volatile(
55
+ "movw %w1, %%ds\n"
56
+ "lssw %0, %%sp\n"
57
+ "iretw\n"
58
+ : : "m"(BDA_JUMP), "r"(SEG_BDA)
59
+ );
60
+ break;
61
+
62
+ case 0x0c:
63
+ // resume execution via RETF via 40h:0067h
64
+ asm volatile(
65
+ "movw %w1, %%ds\n"
66
+ "lssw %0, %%sp\n"
67
+ "lretw\n"
68
+ : : "m"(BDA_JUMP), "r"(SEG_BDA)
69
+ );
70
+ break;
71
+
72
+ default:
73
+ break;
74
+ }
75
+
76
+ // Not a 16bit resume - do remaining checks in 32bit mode
77
+ asm volatile(
78
+ "movw %w1, %%ss\n"
79
+ "movl %0, %%esp\n"
80
+ "movl $_cfunc32flat_handle_resume32, %%edx\n"
81
+ "jmp transition32\n"
82
+ : : "i"(BUILD_S3RESUME_STACK_ADDR), "r"(0), "a"(status)
83
+ );
84
+ }
85
+
86
+ // Handle an S3 resume event
87
+ static void
88
+ s3_resume(void)
89
+ {
90
+ if (!CONFIG_S3_RESUME)
91
+ return;
92
+
93
+ u32 s3_resume_vector = find_resume_vector();
94
+ if (!s3_resume_vector) {
95
+ dprintf(1, "No resume vector set!\n");
96
+ return;
97
+ }
98
+
99
+ pic_setup();
100
+ smm_setup();
101
+ smp_resume();
102
+
103
+ pci_resume();
104
+
105
+ /* resume TPM before we may measure option roms */
106
+ tpm_s3_resume();
107
+ s3_resume_vga();
108
+
109
+ /* Replay any fw_cfg entries that go back to the host */
110
+ romfile_fw_cfg_resume();
111
+
112
+ make_bios_readonly();
113
+
114
+ // Invoke the resume vector.
115
+ struct bregs br;
116
+ memset(&br, 0, sizeof(br));
117
+ dprintf(1, "Jump to resume vector (%x)\n", s3_resume_vector);
118
+ br.code = FLATPTR_TO_SEGOFF((void*)s3_resume_vector);
119
+ farcall16big(&br);
120
+ }
121
+
122
+ // Attempt to invoke a hard-reboot.
123
+ static void
124
+ tryReboot(void)
125
+ {
126
+ dprintf(1, "Attempting a hard reboot\n");
127
+
128
+ // Use a QEMU specific reboot on QEMU
129
+ qemu_reboot();
130
+
131
+ // Reboot using ACPI RESET_REG
132
+ acpi_reboot();
133
+
134
+ // Try keyboard controller reboot.
135
+ i8042_reboot();
136
+
137
+ // Try PCI 0xcf9 reboot
138
+ pci_reboot();
139
+
140
+ // Try triple fault
141
+ asm volatile("int3");
142
+
143
+ panic("Could not reboot");
144
+ }
145
+
146
+ void VISIBLE32FLAT
147
+ handle_resume32(int status)
148
+ {
149
+ ASSERT32FLAT();
150
+ dprintf(1, "In 32bit resume\n");
151
+
152
+ if (status == 0xfe)
153
+ s3_resume();
154
+
155
+ // Must be a soft reboot - invoke a hard reboot.
156
+ tryReboot();
157
+ }
@@ -0,0 +1,146 @@
1
+ // Access to pseudo "file" interface for configuration information.
2
+ //
3
+ // Copyright (C) 2012 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_*
8
+ #include "malloc.h" // free
9
+ #include "output.h" // dprintf
10
+ #include "romfile.h" // struct romfile_s
11
+ #include "string.h" // memcmp
12
+
13
+ static struct romfile_s *RomfileRoot VARVERIFY32INIT;
14
+
15
+ void
16
+ romfile_add(struct romfile_s *file)
17
+ {
18
+ dprintf(3, "Add romfile: %s (size=%d)\n", file->name, file->size);
19
+ file->next = RomfileRoot;
20
+ RomfileRoot = file;
21
+ }
22
+
23
+ // Search for the specified file.
24
+ static struct romfile_s *
25
+ __romfile_findprefix(const char *prefix, int prefixlen, struct romfile_s *prev)
26
+ {
27
+ struct romfile_s *cur = RomfileRoot;
28
+ if (prev)
29
+ cur = prev->next;
30
+ while (cur) {
31
+ if (memcmp(prefix, cur->name, prefixlen) == 0)
32
+ return cur;
33
+ cur = cur->next;
34
+ }
35
+ return NULL;
36
+ }
37
+
38
+ struct romfile_s *
39
+ romfile_findprefix(const char *prefix, struct romfile_s *prev)
40
+ {
41
+ return __romfile_findprefix(prefix, strlen(prefix), prev);
42
+ }
43
+
44
+ struct romfile_s *
45
+ romfile_find(const char *name)
46
+ {
47
+ return __romfile_findprefix(name, strlen(name) + 1, NULL);
48
+ }
49
+
50
+ // Helper function to find, malloc_tmphigh, and copy a romfile. This
51
+ // function adds a trailing zero to the malloc'd copy.
52
+ void *
53
+ romfile_loadfile(const char *name, int *psize)
54
+ {
55
+ struct romfile_s *file = romfile_find(name);
56
+ if (!file)
57
+ return NULL;
58
+
59
+ int filesize = file->size;
60
+ if (!filesize)
61
+ return NULL;
62
+
63
+ char *data = malloc_tmphigh(filesize+1);
64
+ if (!data) {
65
+ warn_noalloc();
66
+ return NULL;
67
+ }
68
+
69
+ dprintf(5, "Copying romfile '%s' (len %d)\n", name, filesize);
70
+ int ret = file->copy(file, data, filesize);
71
+ if (ret < 0) {
72
+ free(data);
73
+ return NULL;
74
+ }
75
+ if (psize)
76
+ *psize = filesize;
77
+ data[filesize] = '\0';
78
+ return data;
79
+ }
80
+
81
+ // Attempt to load an integer from the given file - return 'defval'
82
+ // if unsuccessful.
83
+ u64
84
+ romfile_loadint(const char *name, u64 defval)
85
+ {
86
+ struct romfile_s *file = romfile_find(name);
87
+ if (!file)
88
+ return defval;
89
+
90
+ int filesize = file->size;
91
+ if (!filesize || filesize > sizeof(u64) || (filesize & (filesize-1)))
92
+ // Doesn't look like a valid integer.
93
+ return defval;
94
+
95
+ u64 val = 0;
96
+ int ret = file->copy(file, &val, sizeof(val));
97
+ if (ret < 0)
98
+ return defval;
99
+ return val;
100
+ }
101
+
102
+ struct const_romfile_s {
103
+ struct romfile_s file;
104
+ void *data;
105
+ };
106
+
107
+ static int
108
+ const_read_file(struct romfile_s *file, void *dst, u32 maxlen)
109
+ {
110
+ if (file->size > maxlen)
111
+ return -1;
112
+ struct const_romfile_s *cfile;
113
+ cfile = container_of(file, struct const_romfile_s, file);
114
+ if (maxlen > file->size)
115
+ maxlen = file->size;
116
+ memcpy(dst, cfile->data, maxlen);
117
+ return file->size;
118
+ }
119
+
120
+ static void
121
+ const_romfile_add(char *name, void *data, int size)
122
+ {
123
+ struct const_romfile_s *cfile = malloc_tmp(sizeof(*cfile));
124
+ if (!cfile) {
125
+ warn_noalloc();
126
+ return;
127
+ }
128
+ memset(cfile, 0, sizeof(*cfile));
129
+ strtcpy(cfile->file.name, name, sizeof(cfile->file.name));
130
+ cfile->file.size = size;
131
+ cfile->file.copy = const_read_file;
132
+ cfile->data = data;
133
+ romfile_add(&cfile->file);
134
+ }
135
+
136
+ void
137
+ const_romfile_add_int(char *name, u32 value)
138
+ {
139
+ u32 *data = malloc_tmp(sizeof(*data));
140
+ if (!data) {
141
+ warn_noalloc();
142
+ return;
143
+ }
144
+ *data = value;
145
+ const_romfile_add(name, data, sizeof(*data));
146
+ }
@@ -0,0 +1,21 @@
1
+ #ifndef __ROMFILE_H
2
+ #define __ROMFILE_H
3
+
4
+ #include "types.h" // u32
5
+
6
+ // romfile.c
7
+ struct romfile_s {
8
+ struct romfile_s *next;
9
+ char name[128];
10
+ u32 size;
11
+ int (*copy)(struct romfile_s *file, void *dest, u32 maxlen);
12
+ };
13
+ void romfile_add(struct romfile_s *file);
14
+ struct romfile_s *romfile_findprefix(const char *prefix, struct romfile_s *prev);
15
+ struct romfile_s *romfile_find(const char *name);
16
+ void *romfile_loadfile(const char *name, int *psize);
17
+ u64 romfile_loadint(const char *name, u64 defval);
18
+
19
+ void const_romfile_add_int(char *name, u32 value);
20
+
21
+ #endif // romfile.h