xenix 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. #------------------------------------------------------------------------------
  2. # $File: xenix,v 1.17 2024/02/29 03:42:40 christos Exp $
  3. # xenix: file(1) magic for Microsoft Xenix
  4. #
  5. # "Middle model" stuff, and "Xenix 8086 relocatable or i286 small
  6. # model" lifted from "magic.xenix", with comment "derived empirically;
  7. # treat as folklore until proven"
  8. #
  9. # "small model", "large model", "huge model" stuff lifted from XXX
  10. #
  11. # XXX - "x.out" collides with PDP-11 archives
  12. #
  13. 0 string core core file (Xenix)
  14. # URL: http://www.polarhome.com/service/man/?qf=86rel&tf=2&of=Xenix
  15. # http://fileformats.archiveteam.org/wiki/OMF
  16. # Reference: http://www.azillionmonkeys.com/qed/Omfg.pdf
  17. # Update: Joerg Jenderek
  18. # recordtype~TranslatorHEADerRecord
  19. 0 byte 0x80
  20. # GRR: line above is too general as it catches also Extensible storage engine DataBase,
  21. # all lif files like forth.lif hpcc88.lif lex90b.lif ( See ./lif)
  22. # and all compressed DEGAS low-res bitmaps like: MUNCHIE.PC1 PIDER1.PC1
  23. # skip examples like GENA.SND Switch.Snd by looking for record length maximal 1024-3
  24. >1 uleshort <1022
  25. # skip examples like GAME.PICTURE Strange.Pic by looking for positive record length
  26. >>1 uleshort >0
  27. # skip examples like Xtable.Data FRACTAL.GEN SHR.VIEW by looking for positive string length
  28. >>>3 ubyte >0
  29. # skip examples like OMBRE.6 with "UUUUUU" name by looking for valid high second record type
  30. >>>>(1.s+3) ubyte >0x6D
  31. # skip few Atari DEGAS bitmap TPDEMO.PC2 RECIPE.PC2 with invalid "high" second record type FEh FFh
  32. >>>>>(1.s+3) ubyte <0xF2 8086 relocatable (Microsoft)
  33. #!:mime application/octet-stream
  34. !:mime application/x-object
  35. !:ext obj/o/a
  36. # T-module name often source name like "hello.c" or "jmppm32.asm" in JMPPM32.OBJ or
  37. # "kbhit" in KBHITS.OBJ or "CAUSEWAY_KERNAL" in CWAPI.OBJ
  38. >>>>>>3 pstring x \b, "%s"
  39. # data length probably lower 256 according to TrID obj_omf.trid.xml
  40. >>>>>>1 uleshort x \b, 1st record data length %u
  41. # checksum
  42. #>>>>>>(3.b+4) ubyte x \b, checksum %#2.2x
  43. # second recordtype: 96h~LNAMES 88h~COMENT 8CH~EXTDEF
  44. # highest F1h~Library End Record
  45. >>>>>>(1.s+3) ubyte x \b, 2nd record type %#x
  46. >>>>>>(1.s+4) uleshort x \b, 2nd record data length %u
  47. # Microsoft Xenix archive header
  48. 0 leshort 0xff65 Microsoft x.out
  49. >2 string __.SYMDEF randomized
  50. >0 byte x archive
  51. # Microsoft Xenix x.out header
  52. # Used by Xenix and also by Windows/386 2.x for WIN386.386 file
  53. # URL: http://www.polarhome.com/service/man/?qf=a.out&tf=2&of=Xenix
  54. # http://lock.cmpxchg8b.com/files/a.out.h
  55. # https://www.geoffchappell.com/notes/windows/retro/win386.htm
  56. # Big-endian examples:
  57. # - static executables for Xenix V2.x from Motorola 6800 files in IMD tar archive:
  58. # https://github.com/pski/model2archive/blob/master/Software/Xenix/Xenix_Games/GAMES1.IMD
  59. # Little-endian examples:
  60. # - static executables from Windows/386 2.x: WIN386.386, CGA.386, EGA.386, CTVGA.386, HERCULES.386, 8514.386
  61. # - static executables from SCO Xenix 2.1.3 for 8086: /bin/vi, /bin/file, ...
  62. # - standalone kernel executables from SCO Xenix 2.1.3 for 8086: /boot, /dos, /xenix
  63. 0 leshort 0x206
  64. >0x1c byte&0xc0 =0x40 Microsoft x.out little-endian
  65. >>0 use microsoft-x.out
  66. 0 beshort 0x206
  67. >0x1c byte&0xc0 =0x00 Microsoft x.out PDP-11-endian
  68. # PDP-11-endian is not supported by magic "use" keyword yet but because
  69. # we do not use long and quad types, we can parse it as big-endian
  70. >>0 use \^microsoft-x.out
  71. >0x1c byte&0xc0 =0x80 Microsoft x.out big-endian
  72. >>0 use \^microsoft-x.out
  73. 0 name microsoft-x.out
  74. # Parse type mask
  75. >0x1e leshort &0x10 overlay
  76. >0x1e leshort &0x2 separate
  77. >0x1e leshort &0x4 pure
  78. >0x1e leshort &0x800 segmented
  79. >0x1e clear x
  80. >0x1e leshort&0x501 =0x001 static executable
  81. >0x1e leshort&0x501 =0x100 shared library module
  82. >0x1e leshort&0x501 =0x101 dynamic executable
  83. >0x1e leshort&0x501 =0x401 standalone kernel executable
  84. >0x1e leshort&0x501 =0x500 virtual kernel module
  85. >0x1e default x unknown binary type
  86. # Parse OS type and OS version mask
  87. >0x1e leshort&0xc000 =0x0000 for pre-SysV
  88. >0x1e leshort&0xc000 =0x4000 for Xenix V2.x
  89. >0x1e leshort&0xc000 =0x8000 for Xenix V3.x
  90. >0x1e leshort&0xc000 =0xc000
  91. >>0x1e leshort ^0x800 for Xenix V5.x
  92. >>0x1e leshort &0x800
  93. >>>2 leshort =0x2c
  94. >>>>0x46 ubyte 1
  95. >>>>>0x47 ubyte 0 for Xenix V2.x
  96. >>>>>0x47 ubyte 1 for Xenix V3.x
  97. >>>>>0x47 ubyte 2 for Xenix V5.x
  98. # little-endian segmented static executable for Intel i386 with OS type 1 and
  99. # OS version 2 is used also by Windows/386 2.x for *.386 files (e.g. WIN386.386)
  100. >>>>>>0x1c ulequad&0x3fff00ff =0x0801004a or Windows/386 2.x
  101. >>>>0x46 ubyte 2 for iRMX
  102. >>>>0x46 ubyte 3 for Concurrent CP/M
  103. # Parse CPU mask
  104. >0x1c byte&0x3f =0x01 \b, PDP-11
  105. >0x1c byte&0x3f =0x02 \b, PDP-11/23
  106. >0x1c byte&0x3f =0x03 \b, Zilog Z8000
  107. >0x1c byte&0x3f =0x04 \b, Intel 8086
  108. >0x1c byte&0x3f =0x05 \b, Motorola 6800
  109. >0x1c byte&0x3f =0x06 \b, Zilog Z80
  110. >0x1c byte&0x3f =0x07 \b, VAX 780/750
  111. >0x1c byte&0x3f =0x08 \b, NS16032
  112. >0x1c byte&0x3f =0x09 \b, Intel i286
  113. >0x1c byte&0x3f =0x0a \b, Intel i386
  114. >0x1c byte&0x3f =0x0b \b, Intel i186
  115. >0x1c byte&0x3f =0x29 \b, Intel i286
  116. # Parse other flags
  117. # /bin/file from SCO Xenix 2.1.3 for 8086 reports bit 0x40 as Middle model
  118. # even that in a.out.h is this defined as large model text, so do same
  119. >0x1e leshort &0x40 \b, Middle model
  120. # following long check works in any endianity (including PDP-11)
  121. >0x10 lelong !0 \b, not stripped
  122. # Flags for debugging
  123. #>0x1c byte &0x40 \b, words swapped (differs from PDP-11)
  124. #>0x1c byte &0x80 \b, bytes swapped (differs from PDP-11)
  125. #>0x1e leshort &0x1 \b, executable
  126. #>0x1e leshort &0x2 \b, separate I&D
  127. #>0x1e leshort &0x4 \b, pure text
  128. #>0x1e leshort &0x8 \b, fixed stack
  129. #>0x1e leshort &0x10 \b, text overlay
  130. #>0x1e leshort &0x20 \b, large model data
  131. #>0x1e leshort &0x40 \b, large model text
  132. #>0x1e leshort &0x80 \b, FPU required
  133. #>0x1e leshort &0x100 \b, virtual module / huge model data
  134. #>0x1e leshort &0x200 \b, iterated text/data present
  135. #>0x1e leshort &0x400 \b, absolute memory image
  136. #>0x1e leshort &0x800 \b, segment table present
  137. #>0x1e leshort &0x1000 \b, advisory locking
  138. #>0x1e leshort &0x2000 \b, needs 5.3 functionality
  139. # Microsoft Xenix a.out header
  140. # URL: http://www.polarhome.com/service/man/?qf=a.out&tf=2&of=Xenix
  141. # http://lock.cmpxchg8b.com/files/a.out.h
  142. # FIXME: Below magic definition is probably wrong, it does not match struct aexec from a.out.h
  143. 0 leshort 0x140 old Microsoft 8086 x.out
  144. >0x3 byte &0x4 separate
  145. >0x3 byte &0x2 pure
  146. >0 byte &0x1 executable
  147. >0 byte ^0x1 relocatable
  148. >0x14 lelong >0 not stripped
  149. # Microsoft Xenix b.out header
  150. # URL: http://www.polarhome.com/service/man/?qf=a.out&tf=2&of=Xenix
  151. # http://lock.cmpxchg8b.com/files/a.out.h
  152. # FIXME: Below magic definition is probably wrong, it does not match struct bexec from a.out.h
  153. 0 lelong 0x206 b.out
  154. >0x1e leshort &0x10 overlay
  155. >0x1e leshort &0x2 separate
  156. >0x1e leshort &0x4 pure
  157. >0x1e leshort &0x800 segmented
  158. >0x1e leshort &0x400 standalone
  159. >0x1e leshort &0x1 executable
  160. >0x1e leshort ^0x1 object file
  161. >0x1e leshort &0x4000 V2.3
  162. >0x1e leshort &0x8000 V3.0
  163. >0x1c byte &0x4 8086
  164. >0x1c byte &0xb i186
  165. >0x1c byte &0x9 i286
  166. >0x1c byte &0x29 i286
  167. >0x1c byte &0xa i386
  168. >0x1e leshort &0x4 Large Text
  169. >0x1e leshort &0x2 Large Data
  170. >0x1e leshort &0x102 Huge Objects Enabled
  171. 0 leshort 0x580 XENIX 8086 relocatable or i286 small model
  172. # GRR: line above is too general as it catches also all 8086 relocatable (Microsoft) with 1st record data length 5 C0M.OBJ C0T.OBJ C0S.OBJ