hane 1.0.0 → 1.1.1

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 (381) hide show
  1. package/README.md +32 -32
  2. package/binding.gyp +77 -50
  3. package/deps/win-nodeapi/node_api.def +158 -0
  4. package/deps/win-nodeapi/node_api.lib +0 -0
  5. package/dist/index.js +1 -1
  6. package/package.json +34 -33
  7. package/src/native/addon.cc +247 -207
  8. package/src/native/zsign_driver.cc +87 -87
  9. package/src/native/zsign_driver.h +38 -38
  10. package/vendor/zlib/.cmake-format.yaml +245 -245
  11. package/vendor/zlib/.github/workflows/c-std.yml +230 -230
  12. package/vendor/zlib/.github/workflows/cmake.yml +112 -112
  13. package/vendor/zlib/.github/workflows/configure.yml +136 -136
  14. package/vendor/zlib/.github/workflows/fuzz.yml +25 -25
  15. package/vendor/zlib/.github/workflows/msys-cygwin.yml +77 -77
  16. package/vendor/zlib/BUILD.bazel +134 -134
  17. package/vendor/zlib/CMakeLists.txt +330 -330
  18. package/vendor/zlib/ChangeLog +1621 -1621
  19. package/vendor/zlib/FAQ +367 -367
  20. package/vendor/zlib/INDEX +68 -68
  21. package/vendor/zlib/LICENSE +22 -22
  22. package/vendor/zlib/MODULE.bazel +9 -9
  23. package/vendor/zlib/Makefile.in +419 -419
  24. package/vendor/zlib/README +115 -115
  25. package/vendor/zlib/README-cmake.md +83 -83
  26. package/vendor/zlib/adler32.c +164 -164
  27. package/vendor/zlib/amiga/Makefile.pup +69 -69
  28. package/vendor/zlib/amiga/Makefile.sas +68 -68
  29. package/vendor/zlib/compress.c +75 -75
  30. package/vendor/zlib/configure +966 -966
  31. package/vendor/zlib/contrib/README.contrib +57 -57
  32. package/vendor/zlib/contrib/ada/buffer_demo.adb +106 -106
  33. package/vendor/zlib/contrib/ada/mtest.adb +156 -156
  34. package/vendor/zlib/contrib/ada/read.adb +156 -156
  35. package/vendor/zlib/contrib/ada/readme.txt +65 -65
  36. package/vendor/zlib/contrib/ada/test.adb +463 -463
  37. package/vendor/zlib/contrib/ada/zlib-streams.adb +225 -225
  38. package/vendor/zlib/contrib/ada/zlib-streams.ads +114 -114
  39. package/vendor/zlib/contrib/ada/zlib-thin.adb +142 -142
  40. package/vendor/zlib/contrib/ada/zlib-thin.ads +450 -450
  41. package/vendor/zlib/contrib/ada/zlib.adb +701 -701
  42. package/vendor/zlib/contrib/ada/zlib.ads +328 -328
  43. package/vendor/zlib/contrib/ada/zlib.gpr +20 -20
  44. package/vendor/zlib/contrib/blast/Makefile +8 -8
  45. package/vendor/zlib/contrib/blast/README +4 -4
  46. package/vendor/zlib/contrib/blast/blast.c +466 -466
  47. package/vendor/zlib/contrib/blast/blast.h +83 -83
  48. package/vendor/zlib/contrib/delphi/ZLib.pas +557 -557
  49. package/vendor/zlib/contrib/delphi/ZLibConst.pas +11 -11
  50. package/vendor/zlib/contrib/delphi/readme.txt +76 -76
  51. package/vendor/zlib/contrib/delphi/zlibd32.mak +99 -99
  52. package/vendor/zlib/contrib/gcc_gvmat64/gvmat64.S +574 -574
  53. package/vendor/zlib/contrib/infback9/README +1 -1
  54. package/vendor/zlib/contrib/infback9/infback9.c +603 -603
  55. package/vendor/zlib/contrib/infback9/infback9.h +37 -37
  56. package/vendor/zlib/contrib/infback9/inffix9.h +107 -107
  57. package/vendor/zlib/contrib/infback9/inflate9.h +47 -47
  58. package/vendor/zlib/contrib/infback9/inftree9.c +319 -319
  59. package/vendor/zlib/contrib/infback9/inftree9.h +61 -61
  60. package/vendor/zlib/contrib/iostream/test.cpp +24 -24
  61. package/vendor/zlib/contrib/iostream/zfstream.cpp +329 -329
  62. package/vendor/zlib/contrib/iostream/zfstream.h +128 -128
  63. package/vendor/zlib/contrib/iostream2/zstream.h +307 -307
  64. package/vendor/zlib/contrib/iostream2/zstream_test.cpp +25 -25
  65. package/vendor/zlib/contrib/iostream3/README +35 -35
  66. package/vendor/zlib/contrib/iostream3/TODO +17 -17
  67. package/vendor/zlib/contrib/iostream3/test.cc +50 -50
  68. package/vendor/zlib/contrib/iostream3/zfstream.cc +479 -479
  69. package/vendor/zlib/contrib/iostream3/zfstream.h +466 -466
  70. package/vendor/zlib/contrib/minizip/CMakeLists.txt +380 -380
  71. package/vendor/zlib/contrib/minizip/Makefile +37 -37
  72. package/vendor/zlib/contrib/minizip/Makefile.am +45 -45
  73. package/vendor/zlib/contrib/minizip/MiniZip64_Changes.txt +6 -6
  74. package/vendor/zlib/contrib/minizip/MiniZip64_info.txt +74 -74
  75. package/vendor/zlib/contrib/minizip/configure.ac +32 -32
  76. package/vendor/zlib/contrib/minizip/crypt.h +128 -128
  77. package/vendor/zlib/contrib/minizip/ints.h +57 -57
  78. package/vendor/zlib/contrib/minizip/ioapi.c +231 -231
  79. package/vendor/zlib/contrib/minizip/ioapi.h +183 -183
  80. package/vendor/zlib/contrib/minizip/iowin32.c +448 -448
  81. package/vendor/zlib/contrib/minizip/iowin32.h +28 -28
  82. package/vendor/zlib/contrib/minizip/make_vms.com +25 -25
  83. package/vendor/zlib/contrib/minizip/miniunz.c +647 -647
  84. package/vendor/zlib/contrib/minizip/miniunzip.1 +63 -63
  85. package/vendor/zlib/contrib/minizip/minizip.1 +46 -46
  86. package/vendor/zlib/contrib/minizip/minizip.c +512 -512
  87. package/vendor/zlib/contrib/minizip/minizip.pc.in +12 -12
  88. package/vendor/zlib/contrib/minizip/minizip.pc.txt +13 -13
  89. package/vendor/zlib/contrib/minizip/minizipConfig.cmake.in +35 -35
  90. package/vendor/zlib/contrib/minizip/mztools.c +288 -288
  91. package/vendor/zlib/contrib/minizip/mztools.h +37 -37
  92. package/vendor/zlib/contrib/minizip/skipset.h +361 -361
  93. package/vendor/zlib/contrib/minizip/test/CMakeLists.txt +121 -121
  94. package/vendor/zlib/contrib/minizip/test/add_subdirectory_exclude_test.cmake.in +29 -29
  95. package/vendor/zlib/contrib/minizip/test/add_subdirectory_test.cmake.in +28 -28
  96. package/vendor/zlib/contrib/minizip/test/find_package_test.cmake.in +25 -25
  97. package/vendor/zlib/contrib/minizip/test/test_helper.cm +32 -32
  98. package/vendor/zlib/contrib/minizip/unzip.c +1981 -1981
  99. package/vendor/zlib/contrib/minizip/unzip.h +441 -441
  100. package/vendor/zlib/contrib/minizip/zip.c +2199 -2199
  101. package/vendor/zlib/contrib/minizip/zip.h +370 -370
  102. package/vendor/zlib/contrib/nuget/nuget.csproj +43 -43
  103. package/vendor/zlib/contrib/nuget/nuget.sln +22 -22
  104. package/vendor/zlib/contrib/pascal/example.pas +599 -599
  105. package/vendor/zlib/contrib/pascal/readme.txt +76 -76
  106. package/vendor/zlib/contrib/pascal/zlibd32.mak +99 -99
  107. package/vendor/zlib/contrib/pascal/zlibpas.pas +276 -276
  108. package/vendor/zlib/contrib/puff/Makefile +42 -42
  109. package/vendor/zlib/contrib/puff/README +63 -63
  110. package/vendor/zlib/contrib/puff/puff.c +840 -840
  111. package/vendor/zlib/contrib/puff/puff.h +35 -35
  112. package/vendor/zlib/contrib/puff/pufftest.c +169 -169
  113. package/vendor/zlib/contrib/untgz/Makefile +14 -14
  114. package/vendor/zlib/contrib/untgz/Makefile.msc +17 -17
  115. package/vendor/zlib/contrib/untgz/untgz.c +667 -667
  116. package/vendor/zlib/contrib/vstudio/readme.txt +81 -81
  117. package/vendor/zlib/contrib/vstudio/vc12/miniunz.vcxproj +315 -315
  118. package/vendor/zlib/contrib/vstudio/vc12/minizip.vcxproj +312 -312
  119. package/vendor/zlib/contrib/vstudio/vc12/testzlib.vcxproj +421 -421
  120. package/vendor/zlib/contrib/vstudio/vc12/testzlibdll.vcxproj +315 -315
  121. package/vendor/zlib/contrib/vstudio/vc12/zlib.rc +32 -32
  122. package/vendor/zlib/contrib/vstudio/vc12/zlibstat.vcxproj +458 -458
  123. package/vendor/zlib/contrib/vstudio/vc12/zlibvc.sln +119 -119
  124. package/vendor/zlib/contrib/vstudio/vc12/zlibvc.vcxproj +667 -667
  125. package/vendor/zlib/contrib/vstudio/vc14/miniunz.vcxproj +315 -315
  126. package/vendor/zlib/contrib/vstudio/vc14/minizip.vcxproj +312 -312
  127. package/vendor/zlib/contrib/vstudio/vc14/testzlib.vcxproj +421 -421
  128. package/vendor/zlib/contrib/vstudio/vc14/testzlibdll.vcxproj +315 -315
  129. package/vendor/zlib/contrib/vstudio/vc14/zlib.rc +32 -32
  130. package/vendor/zlib/contrib/vstudio/vc14/zlibstat.vcxproj +458 -458
  131. package/vendor/zlib/contrib/vstudio/vc14/zlibvc.sln +119 -119
  132. package/vendor/zlib/contrib/vstudio/vc14/zlibvc.vcxproj +667 -667
  133. package/vendor/zlib/contrib/vstudio/vc17/miniunz.vcxproj +408 -408
  134. package/vendor/zlib/contrib/vstudio/vc17/minizip.vcxproj +404 -404
  135. package/vendor/zlib/contrib/vstudio/vc17/testzlib.vcxproj +472 -472
  136. package/vendor/zlib/contrib/vstudio/vc17/testzlibdll.vcxproj +408 -408
  137. package/vendor/zlib/contrib/vstudio/vc17/zlib.rc +32 -32
  138. package/vendor/zlib/contrib/vstudio/vc17/zlibstat.vcxproj +601 -601
  139. package/vendor/zlib/contrib/vstudio/vc17/zlibvc.sln +179 -179
  140. package/vendor/zlib/contrib/vstudio/vc17/zlibvc.vcxproj +874 -874
  141. package/vendor/zlib/crc32.c +1049 -1049
  142. package/vendor/zlib/crc32.h +9446 -9446
  143. package/vendor/zlib/deflate.c +2152 -2152
  144. package/vendor/zlib/deflate.h +380 -380
  145. package/vendor/zlib/doc/algorithm.txt +209 -209
  146. package/vendor/zlib/doc/rfc1950.txt +619 -619
  147. package/vendor/zlib/doc/rfc1951.txt +955 -955
  148. package/vendor/zlib/doc/rfc1952.txt +675 -675
  149. package/vendor/zlib/doc/txtvsbin.txt +107 -107
  150. package/vendor/zlib/examples/README.examples +54 -54
  151. package/vendor/zlib/examples/enough.c +597 -597
  152. package/vendor/zlib/examples/fitblk.c +233 -233
  153. package/vendor/zlib/examples/gun.c +702 -702
  154. package/vendor/zlib/examples/gzappend.c +504 -504
  155. package/vendor/zlib/examples/gzjoin.c +449 -449
  156. package/vendor/zlib/examples/gzlog.c +1061 -1061
  157. package/vendor/zlib/examples/gzlog.h +91 -91
  158. package/vendor/zlib/examples/gznorm.c +474 -474
  159. package/vendor/zlib/examples/zlib_how.html +549 -549
  160. package/vendor/zlib/examples/zpipe.c +209 -209
  161. package/vendor/zlib/examples/zran.c +550 -550
  162. package/vendor/zlib/examples/zran.h +53 -53
  163. package/vendor/zlib/gzclose.c +23 -23
  164. package/vendor/zlib/gzguts.h +215 -215
  165. package/vendor/zlib/gzlib.c +585 -585
  166. package/vendor/zlib/gzread.c +603 -603
  167. package/vendor/zlib/gzwrite.c +631 -631
  168. package/vendor/zlib/infback.c +628 -628
  169. package/vendor/zlib/inffast.c +320 -320
  170. package/vendor/zlib/inffast.h +11 -11
  171. package/vendor/zlib/inffixed.h +94 -94
  172. package/vendor/zlib/inflate.c +1526 -1526
  173. package/vendor/zlib/inflate.h +126 -126
  174. package/vendor/zlib/inftrees.c +299 -299
  175. package/vendor/zlib/inftrees.h +62 -62
  176. package/vendor/zlib/make_vms.com +867 -867
  177. package/vendor/zlib/msdos/Makefile.bor +115 -115
  178. package/vendor/zlib/msdos/Makefile.dj2 +104 -104
  179. package/vendor/zlib/msdos/Makefile.emx +69 -69
  180. package/vendor/zlib/msdos/Makefile.msc +112 -112
  181. package/vendor/zlib/msdos/Makefile.tc +100 -100
  182. package/vendor/zlib/nintendods/Makefile +126 -126
  183. package/vendor/zlib/nintendods/README +5 -5
  184. package/vendor/zlib/old/Makefile.emx +69 -69
  185. package/vendor/zlib/old/Makefile.riscos +151 -151
  186. package/vendor/zlib/old/README +3 -3
  187. package/vendor/zlib/old/descrip.mms +48 -48
  188. package/vendor/zlib/old/os2/Makefile.os2 +136 -136
  189. package/vendor/zlib/old/os2/zlib.def +51 -51
  190. package/vendor/zlib/old/visual-basic.txt +160 -160
  191. package/vendor/zlib/os400/README400 +48 -48
  192. package/vendor/zlib/os400/bndsrc +133 -133
  193. package/vendor/zlib/os400/make.sh +366 -366
  194. package/vendor/zlib/os400/zlib.inc +531 -531
  195. package/vendor/zlib/qnx/package.qpg +141 -141
  196. package/vendor/zlib/test/CMakeLists.txt +265 -265
  197. package/vendor/zlib/test/add_subdirectory_exclude_test.cmake.in +29 -29
  198. package/vendor/zlib/test/add_subdirectory_test.cmake.in +28 -28
  199. package/vendor/zlib/test/example.c +552 -552
  200. package/vendor/zlib/test/find_package_test.cmake.in +26 -26
  201. package/vendor/zlib/test/infcover.c +672 -672
  202. package/vendor/zlib/test/minigzip.c +590 -590
  203. package/vendor/zlib/treebuild.xml +116 -116
  204. package/vendor/zlib/trees.c +1119 -1119
  205. package/vendor/zlib/trees.h +128 -128
  206. package/vendor/zlib/uncompr.c +85 -85
  207. package/vendor/zlib/watcom/watcom_f.mak +43 -43
  208. package/vendor/zlib/watcom/watcom_l.mak +43 -43
  209. package/vendor/zlib/win32/DLL_FAQ.txt +381 -381
  210. package/vendor/zlib/win32/Makefile.bor +109 -109
  211. package/vendor/zlib/win32/Makefile.gcc +177 -177
  212. package/vendor/zlib/win32/Makefile.msc +159 -159
  213. package/vendor/zlib/win32/README-WIN32.txt +103 -103
  214. package/vendor/zlib/win32/VisualC.txt +3 -3
  215. package/vendor/zlib/win32/zlib1.rc +37 -37
  216. package/vendor/zlib/zconf.h.in +544 -544
  217. package/vendor/zlib/zlib.3 +149 -149
  218. package/vendor/zlib/zlib.h +1957 -1957
  219. package/vendor/zlib/zlib.map +103 -103
  220. package/vendor/zlib/zlib.pc.cmakein +13 -13
  221. package/vendor/zlib/zlib.pc.in +13 -13
  222. package/vendor/zlib/zlibConfig.cmake.in +26 -26
  223. package/vendor/zlib/zutil.c +299 -299
  224. package/vendor/zlib/zutil.h +257 -257
  225. package/vendor/zsign/.gitattributes +3 -3
  226. package/vendor/zsign/LICENSE +20 -20
  227. package/vendor/zsign/README.md +142 -142
  228. package/vendor/zsign/build/linux/Makefile +43 -43
  229. package/vendor/zsign/build/macos/Makefile +43 -43
  230. package/vendor/zsign/build/windows/vs2022/include/minizip/crypt.h +128 -128
  231. package/vendor/zsign/build/windows/vs2022/include/minizip/ioapi.h +216 -216
  232. package/vendor/zsign/build/windows/vs2022/include/minizip/iowin32.h +28 -28
  233. package/vendor/zsign/build/windows/vs2022/include/minizip/mztools.h +37 -37
  234. package/vendor/zsign/build/windows/vs2022/include/minizip/unzip.h +437 -437
  235. package/vendor/zsign/build/windows/vs2022/include/minizip/zip.h +364 -364
  236. package/vendor/zsign/build/windows/vs2022/include/openssl/__DECC_INCLUDE_EPILOGUE.H +22 -22
  237. package/vendor/zsign/build/windows/vs2022/include/openssl/__DECC_INCLUDE_PROLOGUE.H +26 -26
  238. package/vendor/zsign/build/windows/vs2022/include/openssl/aes.h +111 -111
  239. package/vendor/zsign/build/windows/vs2022/include/openssl/applink.c +153 -153
  240. package/vendor/zsign/build/windows/vs2022/include/openssl/asn1_mac.h +10 -10
  241. package/vendor/zsign/build/windows/vs2022/include/openssl/asn1err.h +142 -142
  242. package/vendor/zsign/build/windows/vs2022/include/openssl/async.h +104 -104
  243. package/vendor/zsign/build/windows/vs2022/include/openssl/asyncerr.h +29 -29
  244. package/vendor/zsign/build/windows/vs2022/include/openssl/bioerr.h +72 -72
  245. package/vendor/zsign/build/windows/vs2022/include/openssl/blowfish.h +78 -78
  246. package/vendor/zsign/build/windows/vs2022/include/openssl/bn.h +590 -590
  247. package/vendor/zsign/build/windows/vs2022/include/openssl/bnerr.h +47 -47
  248. package/vendor/zsign/build/windows/vs2022/include/openssl/buffer.h +62 -62
  249. package/vendor/zsign/build/windows/vs2022/include/openssl/buffererr.h +25 -25
  250. package/vendor/zsign/build/windows/vs2022/include/openssl/camellia.h +117 -117
  251. package/vendor/zsign/build/windows/vs2022/include/openssl/cast.h +71 -71
  252. package/vendor/zsign/build/windows/vs2022/include/openssl/cmac.h +52 -52
  253. package/vendor/zsign/build/windows/vs2022/include/openssl/cmp_util.h +56 -56
  254. package/vendor/zsign/build/windows/vs2022/include/openssl/cmperr.h +131 -131
  255. package/vendor/zsign/build/windows/vs2022/include/openssl/cmserr.h +125 -125
  256. package/vendor/zsign/build/windows/vs2022/include/openssl/comperr.h +38 -38
  257. package/vendor/zsign/build/windows/vs2022/include/openssl/conf_api.h +46 -46
  258. package/vendor/zsign/build/windows/vs2022/include/openssl/conferr.h +52 -52
  259. package/vendor/zsign/build/windows/vs2022/include/openssl/conftypes.h +44 -44
  260. package/vendor/zsign/build/windows/vs2022/include/openssl/core.h +236 -236
  261. package/vendor/zsign/build/windows/vs2022/include/openssl/core_dispatch.h +1022 -1022
  262. package/vendor/zsign/build/windows/vs2022/include/openssl/core_object.h +41 -41
  263. package/vendor/zsign/build/windows/vs2022/include/openssl/crmferr.h +50 -50
  264. package/vendor/zsign/build/windows/vs2022/include/openssl/cryptoerr.h +56 -56
  265. package/vendor/zsign/build/windows/vs2022/include/openssl/cryptoerr_legacy.h +1466 -1466
  266. package/vendor/zsign/build/windows/vs2022/include/openssl/cterr.h +45 -45
  267. package/vendor/zsign/build/windows/vs2022/include/openssl/decoder.h +133 -133
  268. package/vendor/zsign/build/windows/vs2022/include/openssl/decodererr.h +28 -28
  269. package/vendor/zsign/build/windows/vs2022/include/openssl/des.h +211 -211
  270. package/vendor/zsign/build/windows/vs2022/include/openssl/dh.h +339 -339
  271. package/vendor/zsign/build/windows/vs2022/include/openssl/dherr.h +59 -59
  272. package/vendor/zsign/build/windows/vs2022/include/openssl/dsa.h +280 -280
  273. package/vendor/zsign/build/windows/vs2022/include/openssl/dsaerr.h +44 -44
  274. package/vendor/zsign/build/windows/vs2022/include/openssl/dtls1.h +57 -57
  275. package/vendor/zsign/build/windows/vs2022/include/openssl/e_os2.h +310 -310
  276. package/vendor/zsign/build/windows/vs2022/include/openssl/e_ostime.h +38 -38
  277. package/vendor/zsign/build/windows/vs2022/include/openssl/ebcdic.h +39 -39
  278. package/vendor/zsign/build/windows/vs2022/include/openssl/ec.h +1588 -1588
  279. package/vendor/zsign/build/windows/vs2022/include/openssl/ecdh.h +10 -10
  280. package/vendor/zsign/build/windows/vs2022/include/openssl/ecdsa.h +10 -10
  281. package/vendor/zsign/build/windows/vs2022/include/openssl/ecerr.h +104 -104
  282. package/vendor/zsign/build/windows/vs2022/include/openssl/encoder.h +124 -124
  283. package/vendor/zsign/build/windows/vs2022/include/openssl/encodererr.h +28 -28
  284. package/vendor/zsign/build/windows/vs2022/include/openssl/engine.h +833 -833
  285. package/vendor/zsign/build/windows/vs2022/include/openssl/engineerr.h +63 -63
  286. package/vendor/zsign/build/windows/vs2022/include/openssl/esserr.h +32 -32
  287. package/vendor/zsign/build/windows/vs2022/include/openssl/evp.h +2231 -2231
  288. package/vendor/zsign/build/windows/vs2022/include/openssl/evperr.h +140 -140
  289. package/vendor/zsign/build/windows/vs2022/include/openssl/fips_names.h +50 -50
  290. package/vendor/zsign/build/windows/vs2022/include/openssl/hmac.h +62 -62
  291. package/vendor/zsign/build/windows/vs2022/include/openssl/hpke.h +169 -169
  292. package/vendor/zsign/build/windows/vs2022/include/openssl/http.h +118 -118
  293. package/vendor/zsign/build/windows/vs2022/include/openssl/httperr.h +56 -56
  294. package/vendor/zsign/build/windows/vs2022/include/openssl/idea.h +82 -82
  295. package/vendor/zsign/build/windows/vs2022/include/openssl/indicator.h +31 -31
  296. package/vendor/zsign/build/windows/vs2022/include/openssl/kdf.h +138 -138
  297. package/vendor/zsign/build/windows/vs2022/include/openssl/kdferr.h +16 -16
  298. package/vendor/zsign/build/windows/vs2022/include/openssl/macros.h +338 -338
  299. package/vendor/zsign/build/windows/vs2022/include/openssl/md2.h +56 -56
  300. package/vendor/zsign/build/windows/vs2022/include/openssl/md4.h +63 -63
  301. package/vendor/zsign/build/windows/vs2022/include/openssl/md5.h +62 -62
  302. package/vendor/zsign/build/windows/vs2022/include/openssl/mdc2.h +55 -55
  303. package/vendor/zsign/build/windows/vs2022/include/openssl/modes.h +219 -219
  304. package/vendor/zsign/build/windows/vs2022/include/openssl/obj_mac.h +5820 -5820
  305. package/vendor/zsign/build/windows/vs2022/include/openssl/objects.h +184 -184
  306. package/vendor/zsign/build/windows/vs2022/include/openssl/objectserr.h +28 -28
  307. package/vendor/zsign/build/windows/vs2022/include/openssl/ocsperr.h +53 -53
  308. package/vendor/zsign/build/windows/vs2022/include/openssl/opensslconf.h +17 -17
  309. package/vendor/zsign/build/windows/vs2022/include/openssl/ossl_typ.h +16 -16
  310. package/vendor/zsign/build/windows/vs2022/include/openssl/param_build.h +63 -63
  311. package/vendor/zsign/build/windows/vs2022/include/openssl/params.h +160 -160
  312. package/vendor/zsign/build/windows/vs2022/include/openssl/pem.h +543 -543
  313. package/vendor/zsign/build/windows/vs2022/include/openssl/pem2.h +19 -19
  314. package/vendor/zsign/build/windows/vs2022/include/openssl/pemerr.h +58 -58
  315. package/vendor/zsign/build/windows/vs2022/include/openssl/pkcs12err.h +46 -46
  316. package/vendor/zsign/build/windows/vs2022/include/openssl/pkcs7err.h +63 -63
  317. package/vendor/zsign/build/windows/vs2022/include/openssl/prov_ssl.h +38 -38
  318. package/vendor/zsign/build/windows/vs2022/include/openssl/proverr.h +162 -162
  319. package/vendor/zsign/build/windows/vs2022/include/openssl/provider.h +66 -66
  320. package/vendor/zsign/build/windows/vs2022/include/openssl/quic.h +70 -70
  321. package/vendor/zsign/build/windows/vs2022/include/openssl/rand.h +125 -125
  322. package/vendor/zsign/build/windows/vs2022/include/openssl/randerr.h +69 -69
  323. package/vendor/zsign/build/windows/vs2022/include/openssl/rc2.h +68 -68
  324. package/vendor/zsign/build/windows/vs2022/include/openssl/rc4.h +47 -47
  325. package/vendor/zsign/build/windows/vs2022/include/openssl/rc5.h +79 -79
  326. package/vendor/zsign/build/windows/vs2022/include/openssl/ripemd.h +59 -59
  327. package/vendor/zsign/build/windows/vs2022/include/openssl/rsa.h +615 -615
  328. package/vendor/zsign/build/windows/vs2022/include/openssl/rsaerr.h +107 -107
  329. package/vendor/zsign/build/windows/vs2022/include/openssl/seed.h +113 -113
  330. package/vendor/zsign/build/windows/vs2022/include/openssl/self_test.h +98 -98
  331. package/vendor/zsign/build/windows/vs2022/include/openssl/sha.h +139 -139
  332. package/vendor/zsign/build/windows/vs2022/include/openssl/srtp.h +68 -68
  333. package/vendor/zsign/build/windows/vs2022/include/openssl/ssl2.h +30 -30
  334. package/vendor/zsign/build/windows/vs2022/include/openssl/ssl3.h +357 -357
  335. package/vendor/zsign/build/windows/vs2022/include/openssl/sslerr.h +379 -379
  336. package/vendor/zsign/build/windows/vs2022/include/openssl/sslerr_legacy.h +467 -467
  337. package/vendor/zsign/build/windows/vs2022/include/openssl/stack.h +90 -90
  338. package/vendor/zsign/build/windows/vs2022/include/openssl/store.h +377 -377
  339. package/vendor/zsign/build/windows/vs2022/include/openssl/storeerr.h +49 -49
  340. package/vendor/zsign/build/windows/vs2022/include/openssl/symhacks.h +39 -39
  341. package/vendor/zsign/build/windows/vs2022/include/openssl/thread.h +31 -31
  342. package/vendor/zsign/build/windows/vs2022/include/openssl/tls1.h +1220 -1220
  343. package/vendor/zsign/build/windows/vs2022/include/openssl/trace.h +320 -320
  344. package/vendor/zsign/build/windows/vs2022/include/openssl/ts.h +522 -522
  345. package/vendor/zsign/build/windows/vs2022/include/openssl/tserr.h +67 -67
  346. package/vendor/zsign/build/windows/vs2022/include/openssl/txt_db.h +63 -63
  347. package/vendor/zsign/build/windows/vs2022/include/openssl/types.h +245 -245
  348. package/vendor/zsign/build/windows/vs2022/include/openssl/uierr.h +38 -38
  349. package/vendor/zsign/build/windows/vs2022/include/openssl/whrlpool.h +62 -62
  350. package/vendor/zsign/build/windows/vs2022/include/openssl/x509err.h +70 -70
  351. package/vendor/zsign/build/windows/vs2022/include/openssl/x509v3err.h +96 -96
  352. package/vendor/zsign/src/archo.cpp +742 -742
  353. package/vendor/zsign/src/archo.h +61 -61
  354. package/vendor/zsign/src/bundle.cpp +589 -589
  355. package/vendor/zsign/src/bundle.h +46 -46
  356. package/vendor/zsign/src/common/archive.cpp +246 -246
  357. package/vendor/zsign/src/common/archive.h +22 -22
  358. package/vendor/zsign/src/common/common.h +56 -56
  359. package/vendor/zsign/src/common/fs.cpp +573 -573
  360. package/vendor/zsign/src/common/fs.h +50 -50
  361. package/vendor/zsign/src/common/log.cpp +145 -145
  362. package/vendor/zsign/src/common/log.h +37 -37
  363. package/vendor/zsign/src/common/mach-o.h +585 -585
  364. package/vendor/zsign/src/common/sha.cpp +133 -133
  365. package/vendor/zsign/src/common/sha.h +24 -24
  366. package/vendor/zsign/src/common/timer.cpp +28 -28
  367. package/vendor/zsign/src/common/timer.h +17 -17
  368. package/vendor/zsign/src/common/util.cpp +185 -185
  369. package/vendor/zsign/src/common/util.h +25 -25
  370. package/vendor/zsign/src/macho.cpp +273 -273
  371. package/vendor/zsign/src/macho.h +38 -38
  372. package/vendor/zsign/src/openssl.cpp +698 -698
  373. package/vendor/zsign/src/openssl.h +71 -71
  374. package/vendor/zsign/src/signing.cpp +745 -745
  375. package/vendor/zsign/src/signing.h +59 -59
  376. package/vendor/zsign/src/zsign.cpp +317 -317
  377. package/vendor/zsign/test/dylib/demo/Makefile +12 -12
  378. package/vendor/zsign/test/dylib/demo/control +9 -9
  379. package/vendor/zsign/test/dylib/demo/demo.m +21 -21
  380. package/vendor/zsign/test/linux/test.sh +19 -19
  381. package/vendor/zsign/test/macos/test.sh +19 -19
@@ -1,574 +1,574 @@
1
- /*
2
- ;uInt longest_match_x64(
3
- ; deflate_state *s,
4
- ; IPos cur_match); // current match
5
-
6
- ; gvmat64.S -- Asm portion of the optimized longest_match for 32 bits x86_64
7
- ; (AMD64 on Athlon 64, Opteron, Phenom
8
- ; and Intel EM64T on Pentium 4 with EM64T, Pentium D, Core 2 Duo, Core I5/I7)
9
- ; this file is translation from gvmat64.asm to GCC 4.x (for Linux, Mac XCode)
10
- ; Copyright (C) 1995-2010 Jean-loup Gailly, Brian Raiter and Gilles Vollant.
11
- ;
12
- ; File written by Gilles Vollant, by converting to assembly the longest_match
13
- ; from Jean-loup Gailly in deflate.c of zLib and infoZip zip.
14
- ; and by taking inspiration on asm686 with masm, optimised assembly code
15
- ; from Brian Raiter, written 1998
16
- ;
17
- ; This software is provided 'as-is', without any express or implied
18
- ; warranty. In no event will the authors be held liable for any damages
19
- ; arising from the use of this software.
20
- ;
21
- ; Permission is granted to anyone to use this software for any purpose,
22
- ; including commercial applications, and to alter it and redistribute it
23
- ; freely, subject to the following restrictions:
24
- ;
25
- ; 1. The origin of this software must not be misrepresented; you must not
26
- ; claim that you wrote the original software. If you use this software
27
- ; in a product, an acknowledgment in the product documentation would be
28
- ; appreciated but is not required.
29
- ; 2. Altered source versions must be plainly marked as such, and must not be
30
- ; misrepresented as being the original software
31
- ; 3. This notice may not be removed or altered from any source distribution.
32
- ;
33
- ; http://www.zlib.net
34
- ; http://www.winimage.com/zLibDll
35
- ; http://www.muppetlabs.com/~breadbox/software/assembly.html
36
- ;
37
- ; to compile this file for zLib, I use option:
38
- ; gcc -c -arch x86_64 gvmat64.S
39
-
40
-
41
- ;uInt longest_match(s, cur_match)
42
- ; deflate_state *s;
43
- ; IPos cur_match; // current match /
44
- ;
45
- ; with XCode for Mac, I had strange error with some jump on intel syntax
46
- ; this is why BEFORE_JMP and AFTER_JMP are used
47
- */
48
-
49
-
50
- #define BEFORE_JMP .att_syntax
51
- #define AFTER_JMP .intel_syntax noprefix
52
-
53
- #ifndef NO_UNDERLINE
54
- # define match_init _match_init
55
- # define longest_match _longest_match
56
- #endif
57
-
58
- .intel_syntax noprefix
59
-
60
- .globl match_init, longest_match
61
- .text
62
- longest_match:
63
-
64
-
65
-
66
- #define LocalVarsSize 96
67
- /*
68
- ; register used : rax,rbx,rcx,rdx,rsi,rdi,r8,r9,r10,r11,r12
69
- ; free register : r14,r15
70
- ; register can be saved : rsp
71
- */
72
-
73
- #define chainlenwmask (rsp + 8 - LocalVarsSize)
74
- #define nicematch (rsp + 16 - LocalVarsSize)
75
-
76
- #define save_rdi (rsp + 24 - LocalVarsSize)
77
- #define save_rsi (rsp + 32 - LocalVarsSize)
78
- #define save_rbx (rsp + 40 - LocalVarsSize)
79
- #define save_rbp (rsp + 48 - LocalVarsSize)
80
- #define save_r12 (rsp + 56 - LocalVarsSize)
81
- #define save_r13 (rsp + 64 - LocalVarsSize)
82
- #define save_r14 (rsp + 72 - LocalVarsSize)
83
- #define save_r15 (rsp + 80 - LocalVarsSize)
84
-
85
-
86
- /*
87
- ; all the +4 offsets are due to the addition of pending_buf_size (in zlib
88
- ; in the deflate_state structure since the asm code was first written
89
- ; (if you compile with zlib 1.0.4 or older, remove the +4).
90
- ; Note : these value are good with a 8 bytes boundary pack structure
91
- */
92
-
93
- #define MAX_MATCH 258
94
- #define MIN_MATCH 3
95
- #define MIN_LOOKAHEAD (MAX_MATCH+MIN_MATCH+1)
96
-
97
- /*
98
- ;;; Offsets for fields in the deflate_state structure. These numbers
99
- ;;; are calculated from the definition of deflate_state, with the
100
- ;;; assumption that the compiler will dword-align the fields. (Thus,
101
- ;;; changing the definition of deflate_state could easily cause this
102
- ;;; program to crash horribly, without so much as a warning at
103
- ;;; compile time. Sigh.)
104
-
105
- ; all the +zlib1222add offsets are due to the addition of fields
106
- ; in zlib in the deflate_state structure since the asm code was first written
107
- ; (if you compile with zlib 1.0.4 or older, use "zlib1222add equ (-4)").
108
- ; (if you compile with zlib between 1.0.5 and 1.2.2.1, use "zlib1222add equ 0").
109
- ; if you compile with zlib 1.2.2.2 or later , use "zlib1222add equ 8").
110
- */
111
-
112
-
113
-
114
- /* you can check the structure offset by running
115
-
116
- #include <stdlib.h>
117
- #include <stdio.h>
118
- #include "deflate.h"
119
-
120
- void print_depl()
121
- {
122
- deflate_state ds;
123
- deflate_state *s=&ds;
124
- printf("size pointer=%u\n",(int)sizeof(void*));
125
-
126
- printf("#define dsWSize %u\n",(int)(((char*)&(s->w_size))-((char*)s)));
127
- printf("#define dsWMask %u\n",(int)(((char*)&(s->w_mask))-((char*)s)));
128
- printf("#define dsWindow %u\n",(int)(((char*)&(s->window))-((char*)s)));
129
- printf("#define dsPrev %u\n",(int)(((char*)&(s->prev))-((char*)s)));
130
- printf("#define dsMatchLen %u\n",(int)(((char*)&(s->match_length))-((char*)s)));
131
- printf("#define dsPrevMatch %u\n",(int)(((char*)&(s->prev_match))-((char*)s)));
132
- printf("#define dsStrStart %u\n",(int)(((char*)&(s->strstart))-((char*)s)));
133
- printf("#define dsMatchStart %u\n",(int)(((char*)&(s->match_start))-((char*)s)));
134
- printf("#define dsLookahead %u\n",(int)(((char*)&(s->lookahead))-((char*)s)));
135
- printf("#define dsPrevLen %u\n",(int)(((char*)&(s->prev_length))-((char*)s)));
136
- printf("#define dsMaxChainLen %u\n",(int)(((char*)&(s->max_chain_length))-((char*)s)));
137
- printf("#define dsGoodMatch %u\n",(int)(((char*)&(s->good_match))-((char*)s)));
138
- printf("#define dsNiceMatch %u\n",(int)(((char*)&(s->nice_match))-((char*)s)));
139
- }
140
- */
141
-
142
- #define dsWSize 68
143
- #define dsWMask 76
144
- #define dsWindow 80
145
- #define dsPrev 96
146
- #define dsMatchLen 144
147
- #define dsPrevMatch 148
148
- #define dsStrStart 156
149
- #define dsMatchStart 160
150
- #define dsLookahead 164
151
- #define dsPrevLen 168
152
- #define dsMaxChainLen 172
153
- #define dsGoodMatch 188
154
- #define dsNiceMatch 192
155
-
156
- #define window_size [ rcx + dsWSize]
157
- #define WMask [ rcx + dsWMask]
158
- #define window_ad [ rcx + dsWindow]
159
- #define prev_ad [ rcx + dsPrev]
160
- #define strstart [ rcx + dsStrStart]
161
- #define match_start [ rcx + dsMatchStart]
162
- #define Lookahead [ rcx + dsLookahead] //; 0ffffffffh on infozip
163
- #define prev_length [ rcx + dsPrevLen]
164
- #define max_chain_length [ rcx + dsMaxChainLen]
165
- #define good_match [ rcx + dsGoodMatch]
166
- #define nice_match [ rcx + dsNiceMatch]
167
-
168
- /*
169
- ; windows:
170
- ; parameter 1 in rcx(deflate state s), param 2 in rdx (cur match)
171
-
172
- ; see http://weblogs.asp.net/oldnewthing/archive/2004/01/14/58579.aspx and
173
- ; http://msdn.microsoft.com/library/en-us/kmarch/hh/kmarch/64bitAMD_8e951dd2-ee77-4728-8702-55ce4b5dd24a.xml.asp
174
- ;
175
- ; All registers must be preserved across the call, except for
176
- ; rax, rcx, rdx, r8, r9, r10, and r11, which are scratch.
177
-
178
- ;
179
- ; gcc on macosx-linux:
180
- ; see https://refspecs.linuxbase.org/elf/x86_64-abi-0.99.pdf
181
- ; param 1 in rdi, param 2 in rsi
182
- ; rbx, rsp, rbp, r12 to r15 must be preserved
183
-
184
- ;;; Save registers that the compiler may be using, and adjust esp to
185
- ;;; make room for our stack frame.
186
-
187
-
188
- ;;; Retrieve the function arguments. r8d will hold cur_match
189
- ;;; throughout the entire function. edx will hold the pointer to the
190
- ;;; deflate_state structure during the function's setup (before
191
- ;;; entering the main loop.
192
-
193
- ; ms: parameter 1 in rcx (deflate_state* s), param 2 in edx -> r8 (cur match)
194
- ; mac: param 1 in rdi, param 2 rsi
195
- ; this clear high 32 bits of r8, which can be garbage in both r8 and rdx
196
- */
197
- mov [save_rbx],rbx
198
- mov [save_rbp],rbp
199
-
200
-
201
- mov rcx,rdi
202
-
203
- mov r8d,esi
204
-
205
-
206
- mov [save_r12],r12
207
- mov [save_r13],r13
208
- mov [save_r14],r14
209
- mov [save_r15],r15
210
-
211
-
212
- //;;; uInt wmask = s->w_mask;
213
- //;;; unsigned chain_length = s->max_chain_length;
214
- //;;; if (s->prev_length >= s->good_match) {
215
- //;;; chain_length >>= 2;
216
- //;;; }
217
-
218
-
219
- mov edi, prev_length
220
- mov esi, good_match
221
- mov eax, WMask
222
- mov ebx, max_chain_length
223
- cmp edi, esi
224
- jl LastMatchGood
225
- shr ebx, 2
226
- LastMatchGood:
227
-
228
- //;;; chainlen is decremented once beforehand so that the function can
229
- //;;; use the sign flag instead of the zero flag for the exit test.
230
- //;;; It is then shifted into the high word, to make room for the wmask
231
- //;;; value, which it will always accompany.
232
-
233
- dec ebx
234
- shl ebx, 16
235
- or ebx, eax
236
-
237
- //;;; on zlib only
238
- //;;; if ((uInt)nice_match > s->lookahead) nice_match = s->lookahead;
239
-
240
-
241
-
242
- mov eax, nice_match
243
- mov [chainlenwmask], ebx
244
- mov r10d, Lookahead
245
- cmp r10d, eax
246
- cmovnl r10d, eax
247
- mov [nicematch],r10d
248
-
249
-
250
-
251
- //;;; register Bytef *scan = s->window + s->strstart;
252
- mov r10, window_ad
253
- mov ebp, strstart
254
- lea r13, [r10 + rbp]
255
-
256
- //;;; Determine how many bytes the scan ptr is off from being
257
- //;;; dword-aligned.
258
-
259
- mov r9,r13
260
- neg r13
261
- and r13,3
262
-
263
- //;;; IPos limit = s->strstart > (IPos)MAX_DIST(s) ?
264
- //;;; s->strstart - (IPos)MAX_DIST(s) : NIL;
265
-
266
-
267
- mov eax, window_size
268
- sub eax, MIN_LOOKAHEAD
269
-
270
-
271
- xor edi,edi
272
- sub ebp, eax
273
-
274
- mov r11d, prev_length
275
-
276
- cmovng ebp,edi
277
-
278
- //;;; int best_len = s->prev_length;
279
-
280
-
281
- //;;; Store the sum of s->window + best_len in esi locally, and in esi.
282
-
283
- lea rsi,[r10+r11]
284
-
285
- //;;; register ush scan_start = *(ushf*)scan;
286
- //;;; register ush scan_end = *(ushf*)(scan+best_len-1);
287
- //;;; Posf *prev = s->prev;
288
-
289
- movzx r12d,word ptr [r9]
290
- movzx ebx, word ptr [r9 + r11 - 1]
291
-
292
- mov rdi, prev_ad
293
-
294
- //;;; Jump into the main loop.
295
-
296
- mov edx, [chainlenwmask]
297
-
298
- cmp bx,word ptr [rsi + r8 - 1]
299
- jz LookupLoopIsZero
300
-
301
-
302
-
303
- LookupLoop1:
304
- and r8d, edx
305
-
306
- movzx r8d, word ptr [rdi + r8*2]
307
- cmp r8d, ebp
308
- jbe LeaveNow
309
-
310
-
311
-
312
- sub edx, 0x00010000
313
- BEFORE_JMP
314
- js LeaveNow
315
- AFTER_JMP
316
-
317
- LoopEntry1:
318
- cmp bx,word ptr [rsi + r8 - 1]
319
- BEFORE_JMP
320
- jz LookupLoopIsZero
321
- AFTER_JMP
322
-
323
- LookupLoop2:
324
- and r8d, edx
325
-
326
- movzx r8d, word ptr [rdi + r8*2]
327
- cmp r8d, ebp
328
- BEFORE_JMP
329
- jbe LeaveNow
330
- AFTER_JMP
331
- sub edx, 0x00010000
332
- BEFORE_JMP
333
- js LeaveNow
334
- AFTER_JMP
335
-
336
- LoopEntry2:
337
- cmp bx,word ptr [rsi + r8 - 1]
338
- BEFORE_JMP
339
- jz LookupLoopIsZero
340
- AFTER_JMP
341
-
342
- LookupLoop4:
343
- and r8d, edx
344
-
345
- movzx r8d, word ptr [rdi + r8*2]
346
- cmp r8d, ebp
347
- BEFORE_JMP
348
- jbe LeaveNow
349
- AFTER_JMP
350
- sub edx, 0x00010000
351
- BEFORE_JMP
352
- js LeaveNow
353
- AFTER_JMP
354
-
355
- LoopEntry4:
356
-
357
- cmp bx,word ptr [rsi + r8 - 1]
358
- BEFORE_JMP
359
- jnz LookupLoop1
360
- jmp LookupLoopIsZero
361
- AFTER_JMP
362
- /*
363
- ;;; do {
364
- ;;; match = s->window + cur_match;
365
- ;;; if (*(ushf*)(match+best_len-1) != scan_end ||
366
- ;;; *(ushf*)match != scan_start) continue;
367
- ;;; [...]
368
- ;;; } while ((cur_match = prev[cur_match & wmask]) > limit
369
- ;;; && --chain_length != 0);
370
- ;;;
371
- ;;; Here is the inner loop of the function. The function will spend the
372
- ;;; majority of its time in this loop, and majority of that time will
373
- ;;; be spent in the first ten instructions.
374
- ;;;
375
- ;;; Within this loop:
376
- ;;; ebx = scanend
377
- ;;; r8d = curmatch
378
- ;;; edx = chainlenwmask - i.e., ((chainlen << 16) | wmask)
379
- ;;; esi = windowbestlen - i.e., (window + bestlen)
380
- ;;; edi = prev
381
- ;;; ebp = limit
382
- */
383
- .balign 16
384
- LookupLoop:
385
- and r8d, edx
386
-
387
- movzx r8d, word ptr [rdi + r8*2]
388
- cmp r8d, ebp
389
- BEFORE_JMP
390
- jbe LeaveNow
391
- AFTER_JMP
392
- sub edx, 0x00010000
393
- BEFORE_JMP
394
- js LeaveNow
395
- AFTER_JMP
396
-
397
- LoopEntry:
398
-
399
- cmp bx,word ptr [rsi + r8 - 1]
400
- BEFORE_JMP
401
- jnz LookupLoop1
402
- AFTER_JMP
403
- LookupLoopIsZero:
404
- cmp r12w, word ptr [r10 + r8]
405
- BEFORE_JMP
406
- jnz LookupLoop1
407
- AFTER_JMP
408
-
409
-
410
- //;;; Store the current value of chainlen.
411
- mov [chainlenwmask], edx
412
- /*
413
- ;;; Point edi to the string under scrutiny, and esi to the string we
414
- ;;; are hoping to match it up with. In actuality, esi and edi are
415
- ;;; both pointed (MAX_MATCH_8 - scanalign) bytes ahead, and edx is
416
- ;;; initialized to -(MAX_MATCH_8 - scanalign).
417
- */
418
- lea rsi,[r8+r10]
419
- mov rdx, 0xfffffffffffffef8 //; -(MAX_MATCH_8)
420
- lea rsi, [rsi + r13 + 0x0108] //;MAX_MATCH_8]
421
- lea rdi, [r9 + r13 + 0x0108] //;MAX_MATCH_8]
422
-
423
- prefetcht1 [rsi+rdx]
424
- prefetcht1 [rdi+rdx]
425
-
426
- /*
427
- ;;; Test the strings for equality, 8 bytes at a time. At the end,
428
- ;;; adjust rdx so that it is offset to the exact byte that mismatched.
429
- ;;;
430
- ;;; We already know at this point that the first three bytes of the
431
- ;;; strings match each other, and they can be safely passed over before
432
- ;;; starting the compare loop. So what this code does is skip over 0-3
433
- ;;; bytes, as much as necessary in order to dword-align the edi
434
- ;;; pointer. (rsi will still be misaligned three times out of four.)
435
- ;;;
436
- ;;; It should be confessed that this loop usually does not represent
437
- ;;; much of the total running time. Replacing it with a more
438
- ;;; straightforward "rep cmpsb" would not drastically degrade
439
- ;;; performance.
440
- */
441
-
442
- LoopCmps:
443
- mov rax, [rsi + rdx]
444
- xor rax, [rdi + rdx]
445
- jnz LeaveLoopCmps
446
-
447
- mov rax, [rsi + rdx + 8]
448
- xor rax, [rdi + rdx + 8]
449
- jnz LeaveLoopCmps8
450
-
451
-
452
- mov rax, [rsi + rdx + 8+8]
453
- xor rax, [rdi + rdx + 8+8]
454
- jnz LeaveLoopCmps16
455
-
456
- add rdx,8+8+8
457
-
458
- BEFORE_JMP
459
- jnz LoopCmps
460
- jmp LenMaximum
461
- AFTER_JMP
462
-
463
- LeaveLoopCmps16: add rdx,8
464
- LeaveLoopCmps8: add rdx,8
465
- LeaveLoopCmps:
466
-
467
- test eax, 0x0000FFFF
468
- jnz LenLower
469
-
470
- test eax,0xffffffff
471
-
472
- jnz LenLower32
473
-
474
- add rdx,4
475
- shr rax,32
476
- or ax,ax
477
- BEFORE_JMP
478
- jnz LenLower
479
- AFTER_JMP
480
-
481
- LenLower32:
482
- shr eax,16
483
- add rdx,2
484
-
485
- LenLower:
486
- sub al, 1
487
- adc rdx, 0
488
- //;;; Calculate the length of the match. If it is longer than MAX_MATCH,
489
- //;;; then automatically accept it as the best possible match and leave.
490
-
491
- lea rax, [rdi + rdx]
492
- sub rax, r9
493
- cmp eax, MAX_MATCH
494
- BEFORE_JMP
495
- jge LenMaximum
496
- AFTER_JMP
497
- /*
498
- ;;; If the length of the match is not longer than the best match we
499
- ;;; have so far, then forget it and return to the lookup loop.
500
- ;///////////////////////////////////
501
- */
502
- cmp eax, r11d
503
- jg LongerMatch
504
-
505
- lea rsi,[r10+r11]
506
-
507
- mov rdi, prev_ad
508
- mov edx, [chainlenwmask]
509
- BEFORE_JMP
510
- jmp LookupLoop
511
- AFTER_JMP
512
- /*
513
- ;;; s->match_start = cur_match;
514
- ;;; best_len = len;
515
- ;;; if (len >= nice_match) break;
516
- ;;; scan_end = *(ushf*)(scan+best_len-1);
517
- */
518
- LongerMatch:
519
- mov r11d, eax
520
- mov match_start, r8d
521
- cmp eax, [nicematch]
522
- BEFORE_JMP
523
- jge LeaveNow
524
- AFTER_JMP
525
-
526
- lea rsi,[r10+rax]
527
-
528
- movzx ebx, word ptr [r9 + rax - 1]
529
- mov rdi, prev_ad
530
- mov edx, [chainlenwmask]
531
- BEFORE_JMP
532
- jmp LookupLoop
533
- AFTER_JMP
534
-
535
- //;;; Accept the current string, with the maximum possible length.
536
-
537
- LenMaximum:
538
- mov r11d,MAX_MATCH
539
- mov match_start, r8d
540
-
541
- //;;; if ((uInt)best_len <= s->lookahead) return (uInt)best_len;
542
- //;;; return s->lookahead;
543
-
544
- LeaveNow:
545
- mov eax, Lookahead
546
- cmp r11d, eax
547
- cmovng eax, r11d
548
-
549
-
550
-
551
- //;;; Restore the stack and return from whence we came.
552
-
553
-
554
- // mov rsi,[save_rsi]
555
- // mov rdi,[save_rdi]
556
- mov rbx,[save_rbx]
557
- mov rbp,[save_rbp]
558
- mov r12,[save_r12]
559
- mov r13,[save_r13]
560
- mov r14,[save_r14]
561
- mov r15,[save_r15]
562
-
563
-
564
- ret 0
565
- //; please don't remove this string !
566
- //; Your can freely use gvmat64 in any free or commercial app
567
- //; but it is far better don't remove the string in the binary!
568
- // db 0dh,0ah,"asm686 with masm, optimised assembly code from Brian Raiter, written 1998, converted to amd 64 by Gilles Vollant 2005",0dh,0ah,0
569
-
570
-
571
- match_init:
572
- ret 0
573
-
574
-
1
+ /*
2
+ ;uInt longest_match_x64(
3
+ ; deflate_state *s,
4
+ ; IPos cur_match); // current match
5
+
6
+ ; gvmat64.S -- Asm portion of the optimized longest_match for 32 bits x86_64
7
+ ; (AMD64 on Athlon 64, Opteron, Phenom
8
+ ; and Intel EM64T on Pentium 4 with EM64T, Pentium D, Core 2 Duo, Core I5/I7)
9
+ ; this file is translation from gvmat64.asm to GCC 4.x (for Linux, Mac XCode)
10
+ ; Copyright (C) 1995-2010 Jean-loup Gailly, Brian Raiter and Gilles Vollant.
11
+ ;
12
+ ; File written by Gilles Vollant, by converting to assembly the longest_match
13
+ ; from Jean-loup Gailly in deflate.c of zLib and infoZip zip.
14
+ ; and by taking inspiration on asm686 with masm, optimised assembly code
15
+ ; from Brian Raiter, written 1998
16
+ ;
17
+ ; This software is provided 'as-is', without any express or implied
18
+ ; warranty. In no event will the authors be held liable for any damages
19
+ ; arising from the use of this software.
20
+ ;
21
+ ; Permission is granted to anyone to use this software for any purpose,
22
+ ; including commercial applications, and to alter it and redistribute it
23
+ ; freely, subject to the following restrictions:
24
+ ;
25
+ ; 1. The origin of this software must not be misrepresented; you must not
26
+ ; claim that you wrote the original software. If you use this software
27
+ ; in a product, an acknowledgment in the product documentation would be
28
+ ; appreciated but is not required.
29
+ ; 2. Altered source versions must be plainly marked as such, and must not be
30
+ ; misrepresented as being the original software
31
+ ; 3. This notice may not be removed or altered from any source distribution.
32
+ ;
33
+ ; http://www.zlib.net
34
+ ; http://www.winimage.com/zLibDll
35
+ ; http://www.muppetlabs.com/~breadbox/software/assembly.html
36
+ ;
37
+ ; to compile this file for zLib, I use option:
38
+ ; gcc -c -arch x86_64 gvmat64.S
39
+
40
+
41
+ ;uInt longest_match(s, cur_match)
42
+ ; deflate_state *s;
43
+ ; IPos cur_match; // current match /
44
+ ;
45
+ ; with XCode for Mac, I had strange error with some jump on intel syntax
46
+ ; this is why BEFORE_JMP and AFTER_JMP are used
47
+ */
48
+
49
+
50
+ #define BEFORE_JMP .att_syntax
51
+ #define AFTER_JMP .intel_syntax noprefix
52
+
53
+ #ifndef NO_UNDERLINE
54
+ # define match_init _match_init
55
+ # define longest_match _longest_match
56
+ #endif
57
+
58
+ .intel_syntax noprefix
59
+
60
+ .globl match_init, longest_match
61
+ .text
62
+ longest_match:
63
+
64
+
65
+
66
+ #define LocalVarsSize 96
67
+ /*
68
+ ; register used : rax,rbx,rcx,rdx,rsi,rdi,r8,r9,r10,r11,r12
69
+ ; free register : r14,r15
70
+ ; register can be saved : rsp
71
+ */
72
+
73
+ #define chainlenwmask (rsp + 8 - LocalVarsSize)
74
+ #define nicematch (rsp + 16 - LocalVarsSize)
75
+
76
+ #define save_rdi (rsp + 24 - LocalVarsSize)
77
+ #define save_rsi (rsp + 32 - LocalVarsSize)
78
+ #define save_rbx (rsp + 40 - LocalVarsSize)
79
+ #define save_rbp (rsp + 48 - LocalVarsSize)
80
+ #define save_r12 (rsp + 56 - LocalVarsSize)
81
+ #define save_r13 (rsp + 64 - LocalVarsSize)
82
+ #define save_r14 (rsp + 72 - LocalVarsSize)
83
+ #define save_r15 (rsp + 80 - LocalVarsSize)
84
+
85
+
86
+ /*
87
+ ; all the +4 offsets are due to the addition of pending_buf_size (in zlib
88
+ ; in the deflate_state structure since the asm code was first written
89
+ ; (if you compile with zlib 1.0.4 or older, remove the +4).
90
+ ; Note : these value are good with a 8 bytes boundary pack structure
91
+ */
92
+
93
+ #define MAX_MATCH 258
94
+ #define MIN_MATCH 3
95
+ #define MIN_LOOKAHEAD (MAX_MATCH+MIN_MATCH+1)
96
+
97
+ /*
98
+ ;;; Offsets for fields in the deflate_state structure. These numbers
99
+ ;;; are calculated from the definition of deflate_state, with the
100
+ ;;; assumption that the compiler will dword-align the fields. (Thus,
101
+ ;;; changing the definition of deflate_state could easily cause this
102
+ ;;; program to crash horribly, without so much as a warning at
103
+ ;;; compile time. Sigh.)
104
+
105
+ ; all the +zlib1222add offsets are due to the addition of fields
106
+ ; in zlib in the deflate_state structure since the asm code was first written
107
+ ; (if you compile with zlib 1.0.4 or older, use "zlib1222add equ (-4)").
108
+ ; (if you compile with zlib between 1.0.5 and 1.2.2.1, use "zlib1222add equ 0").
109
+ ; if you compile with zlib 1.2.2.2 or later , use "zlib1222add equ 8").
110
+ */
111
+
112
+
113
+
114
+ /* you can check the structure offset by running
115
+
116
+ #include <stdlib.h>
117
+ #include <stdio.h>
118
+ #include "deflate.h"
119
+
120
+ void print_depl()
121
+ {
122
+ deflate_state ds;
123
+ deflate_state *s=&ds;
124
+ printf("size pointer=%u\n",(int)sizeof(void*));
125
+
126
+ printf("#define dsWSize %u\n",(int)(((char*)&(s->w_size))-((char*)s)));
127
+ printf("#define dsWMask %u\n",(int)(((char*)&(s->w_mask))-((char*)s)));
128
+ printf("#define dsWindow %u\n",(int)(((char*)&(s->window))-((char*)s)));
129
+ printf("#define dsPrev %u\n",(int)(((char*)&(s->prev))-((char*)s)));
130
+ printf("#define dsMatchLen %u\n",(int)(((char*)&(s->match_length))-((char*)s)));
131
+ printf("#define dsPrevMatch %u\n",(int)(((char*)&(s->prev_match))-((char*)s)));
132
+ printf("#define dsStrStart %u\n",(int)(((char*)&(s->strstart))-((char*)s)));
133
+ printf("#define dsMatchStart %u\n",(int)(((char*)&(s->match_start))-((char*)s)));
134
+ printf("#define dsLookahead %u\n",(int)(((char*)&(s->lookahead))-((char*)s)));
135
+ printf("#define dsPrevLen %u\n",(int)(((char*)&(s->prev_length))-((char*)s)));
136
+ printf("#define dsMaxChainLen %u\n",(int)(((char*)&(s->max_chain_length))-((char*)s)));
137
+ printf("#define dsGoodMatch %u\n",(int)(((char*)&(s->good_match))-((char*)s)));
138
+ printf("#define dsNiceMatch %u\n",(int)(((char*)&(s->nice_match))-((char*)s)));
139
+ }
140
+ */
141
+
142
+ #define dsWSize 68
143
+ #define dsWMask 76
144
+ #define dsWindow 80
145
+ #define dsPrev 96
146
+ #define dsMatchLen 144
147
+ #define dsPrevMatch 148
148
+ #define dsStrStart 156
149
+ #define dsMatchStart 160
150
+ #define dsLookahead 164
151
+ #define dsPrevLen 168
152
+ #define dsMaxChainLen 172
153
+ #define dsGoodMatch 188
154
+ #define dsNiceMatch 192
155
+
156
+ #define window_size [ rcx + dsWSize]
157
+ #define WMask [ rcx + dsWMask]
158
+ #define window_ad [ rcx + dsWindow]
159
+ #define prev_ad [ rcx + dsPrev]
160
+ #define strstart [ rcx + dsStrStart]
161
+ #define match_start [ rcx + dsMatchStart]
162
+ #define Lookahead [ rcx + dsLookahead] //; 0ffffffffh on infozip
163
+ #define prev_length [ rcx + dsPrevLen]
164
+ #define max_chain_length [ rcx + dsMaxChainLen]
165
+ #define good_match [ rcx + dsGoodMatch]
166
+ #define nice_match [ rcx + dsNiceMatch]
167
+
168
+ /*
169
+ ; windows:
170
+ ; parameter 1 in rcx(deflate state s), param 2 in rdx (cur match)
171
+
172
+ ; see http://weblogs.asp.net/oldnewthing/archive/2004/01/14/58579.aspx and
173
+ ; http://msdn.microsoft.com/library/en-us/kmarch/hh/kmarch/64bitAMD_8e951dd2-ee77-4728-8702-55ce4b5dd24a.xml.asp
174
+ ;
175
+ ; All registers must be preserved across the call, except for
176
+ ; rax, rcx, rdx, r8, r9, r10, and r11, which are scratch.
177
+
178
+ ;
179
+ ; gcc on macosx-linux:
180
+ ; see https://refspecs.linuxbase.org/elf/x86_64-abi-0.99.pdf
181
+ ; param 1 in rdi, param 2 in rsi
182
+ ; rbx, rsp, rbp, r12 to r15 must be preserved
183
+
184
+ ;;; Save registers that the compiler may be using, and adjust esp to
185
+ ;;; make room for our stack frame.
186
+
187
+
188
+ ;;; Retrieve the function arguments. r8d will hold cur_match
189
+ ;;; throughout the entire function. edx will hold the pointer to the
190
+ ;;; deflate_state structure during the function's setup (before
191
+ ;;; entering the main loop.
192
+
193
+ ; ms: parameter 1 in rcx (deflate_state* s), param 2 in edx -> r8 (cur match)
194
+ ; mac: param 1 in rdi, param 2 rsi
195
+ ; this clear high 32 bits of r8, which can be garbage in both r8 and rdx
196
+ */
197
+ mov [save_rbx],rbx
198
+ mov [save_rbp],rbp
199
+
200
+
201
+ mov rcx,rdi
202
+
203
+ mov r8d,esi
204
+
205
+
206
+ mov [save_r12],r12
207
+ mov [save_r13],r13
208
+ mov [save_r14],r14
209
+ mov [save_r15],r15
210
+
211
+
212
+ //;;; uInt wmask = s->w_mask;
213
+ //;;; unsigned chain_length = s->max_chain_length;
214
+ //;;; if (s->prev_length >= s->good_match) {
215
+ //;;; chain_length >>= 2;
216
+ //;;; }
217
+
218
+
219
+ mov edi, prev_length
220
+ mov esi, good_match
221
+ mov eax, WMask
222
+ mov ebx, max_chain_length
223
+ cmp edi, esi
224
+ jl LastMatchGood
225
+ shr ebx, 2
226
+ LastMatchGood:
227
+
228
+ //;;; chainlen is decremented once beforehand so that the function can
229
+ //;;; use the sign flag instead of the zero flag for the exit test.
230
+ //;;; It is then shifted into the high word, to make room for the wmask
231
+ //;;; value, which it will always accompany.
232
+
233
+ dec ebx
234
+ shl ebx, 16
235
+ or ebx, eax
236
+
237
+ //;;; on zlib only
238
+ //;;; if ((uInt)nice_match > s->lookahead) nice_match = s->lookahead;
239
+
240
+
241
+
242
+ mov eax, nice_match
243
+ mov [chainlenwmask], ebx
244
+ mov r10d, Lookahead
245
+ cmp r10d, eax
246
+ cmovnl r10d, eax
247
+ mov [nicematch],r10d
248
+
249
+
250
+
251
+ //;;; register Bytef *scan = s->window + s->strstart;
252
+ mov r10, window_ad
253
+ mov ebp, strstart
254
+ lea r13, [r10 + rbp]
255
+
256
+ //;;; Determine how many bytes the scan ptr is off from being
257
+ //;;; dword-aligned.
258
+
259
+ mov r9,r13
260
+ neg r13
261
+ and r13,3
262
+
263
+ //;;; IPos limit = s->strstart > (IPos)MAX_DIST(s) ?
264
+ //;;; s->strstart - (IPos)MAX_DIST(s) : NIL;
265
+
266
+
267
+ mov eax, window_size
268
+ sub eax, MIN_LOOKAHEAD
269
+
270
+
271
+ xor edi,edi
272
+ sub ebp, eax
273
+
274
+ mov r11d, prev_length
275
+
276
+ cmovng ebp,edi
277
+
278
+ //;;; int best_len = s->prev_length;
279
+
280
+
281
+ //;;; Store the sum of s->window + best_len in esi locally, and in esi.
282
+
283
+ lea rsi,[r10+r11]
284
+
285
+ //;;; register ush scan_start = *(ushf*)scan;
286
+ //;;; register ush scan_end = *(ushf*)(scan+best_len-1);
287
+ //;;; Posf *prev = s->prev;
288
+
289
+ movzx r12d,word ptr [r9]
290
+ movzx ebx, word ptr [r9 + r11 - 1]
291
+
292
+ mov rdi, prev_ad
293
+
294
+ //;;; Jump into the main loop.
295
+
296
+ mov edx, [chainlenwmask]
297
+
298
+ cmp bx,word ptr [rsi + r8 - 1]
299
+ jz LookupLoopIsZero
300
+
301
+
302
+
303
+ LookupLoop1:
304
+ and r8d, edx
305
+
306
+ movzx r8d, word ptr [rdi + r8*2]
307
+ cmp r8d, ebp
308
+ jbe LeaveNow
309
+
310
+
311
+
312
+ sub edx, 0x00010000
313
+ BEFORE_JMP
314
+ js LeaveNow
315
+ AFTER_JMP
316
+
317
+ LoopEntry1:
318
+ cmp bx,word ptr [rsi + r8 - 1]
319
+ BEFORE_JMP
320
+ jz LookupLoopIsZero
321
+ AFTER_JMP
322
+
323
+ LookupLoop2:
324
+ and r8d, edx
325
+
326
+ movzx r8d, word ptr [rdi + r8*2]
327
+ cmp r8d, ebp
328
+ BEFORE_JMP
329
+ jbe LeaveNow
330
+ AFTER_JMP
331
+ sub edx, 0x00010000
332
+ BEFORE_JMP
333
+ js LeaveNow
334
+ AFTER_JMP
335
+
336
+ LoopEntry2:
337
+ cmp bx,word ptr [rsi + r8 - 1]
338
+ BEFORE_JMP
339
+ jz LookupLoopIsZero
340
+ AFTER_JMP
341
+
342
+ LookupLoop4:
343
+ and r8d, edx
344
+
345
+ movzx r8d, word ptr [rdi + r8*2]
346
+ cmp r8d, ebp
347
+ BEFORE_JMP
348
+ jbe LeaveNow
349
+ AFTER_JMP
350
+ sub edx, 0x00010000
351
+ BEFORE_JMP
352
+ js LeaveNow
353
+ AFTER_JMP
354
+
355
+ LoopEntry4:
356
+
357
+ cmp bx,word ptr [rsi + r8 - 1]
358
+ BEFORE_JMP
359
+ jnz LookupLoop1
360
+ jmp LookupLoopIsZero
361
+ AFTER_JMP
362
+ /*
363
+ ;;; do {
364
+ ;;; match = s->window + cur_match;
365
+ ;;; if (*(ushf*)(match+best_len-1) != scan_end ||
366
+ ;;; *(ushf*)match != scan_start) continue;
367
+ ;;; [...]
368
+ ;;; } while ((cur_match = prev[cur_match & wmask]) > limit
369
+ ;;; && --chain_length != 0);
370
+ ;;;
371
+ ;;; Here is the inner loop of the function. The function will spend the
372
+ ;;; majority of its time in this loop, and majority of that time will
373
+ ;;; be spent in the first ten instructions.
374
+ ;;;
375
+ ;;; Within this loop:
376
+ ;;; ebx = scanend
377
+ ;;; r8d = curmatch
378
+ ;;; edx = chainlenwmask - i.e., ((chainlen << 16) | wmask)
379
+ ;;; esi = windowbestlen - i.e., (window + bestlen)
380
+ ;;; edi = prev
381
+ ;;; ebp = limit
382
+ */
383
+ .balign 16
384
+ LookupLoop:
385
+ and r8d, edx
386
+
387
+ movzx r8d, word ptr [rdi + r8*2]
388
+ cmp r8d, ebp
389
+ BEFORE_JMP
390
+ jbe LeaveNow
391
+ AFTER_JMP
392
+ sub edx, 0x00010000
393
+ BEFORE_JMP
394
+ js LeaveNow
395
+ AFTER_JMP
396
+
397
+ LoopEntry:
398
+
399
+ cmp bx,word ptr [rsi + r8 - 1]
400
+ BEFORE_JMP
401
+ jnz LookupLoop1
402
+ AFTER_JMP
403
+ LookupLoopIsZero:
404
+ cmp r12w, word ptr [r10 + r8]
405
+ BEFORE_JMP
406
+ jnz LookupLoop1
407
+ AFTER_JMP
408
+
409
+
410
+ //;;; Store the current value of chainlen.
411
+ mov [chainlenwmask], edx
412
+ /*
413
+ ;;; Point edi to the string under scrutiny, and esi to the string we
414
+ ;;; are hoping to match it up with. In actuality, esi and edi are
415
+ ;;; both pointed (MAX_MATCH_8 - scanalign) bytes ahead, and edx is
416
+ ;;; initialized to -(MAX_MATCH_8 - scanalign).
417
+ */
418
+ lea rsi,[r8+r10]
419
+ mov rdx, 0xfffffffffffffef8 //; -(MAX_MATCH_8)
420
+ lea rsi, [rsi + r13 + 0x0108] //;MAX_MATCH_8]
421
+ lea rdi, [r9 + r13 + 0x0108] //;MAX_MATCH_8]
422
+
423
+ prefetcht1 [rsi+rdx]
424
+ prefetcht1 [rdi+rdx]
425
+
426
+ /*
427
+ ;;; Test the strings for equality, 8 bytes at a time. At the end,
428
+ ;;; adjust rdx so that it is offset to the exact byte that mismatched.
429
+ ;;;
430
+ ;;; We already know at this point that the first three bytes of the
431
+ ;;; strings match each other, and they can be safely passed over before
432
+ ;;; starting the compare loop. So what this code does is skip over 0-3
433
+ ;;; bytes, as much as necessary in order to dword-align the edi
434
+ ;;; pointer. (rsi will still be misaligned three times out of four.)
435
+ ;;;
436
+ ;;; It should be confessed that this loop usually does not represent
437
+ ;;; much of the total running time. Replacing it with a more
438
+ ;;; straightforward "rep cmpsb" would not drastically degrade
439
+ ;;; performance.
440
+ */
441
+
442
+ LoopCmps:
443
+ mov rax, [rsi + rdx]
444
+ xor rax, [rdi + rdx]
445
+ jnz LeaveLoopCmps
446
+
447
+ mov rax, [rsi + rdx + 8]
448
+ xor rax, [rdi + rdx + 8]
449
+ jnz LeaveLoopCmps8
450
+
451
+
452
+ mov rax, [rsi + rdx + 8+8]
453
+ xor rax, [rdi + rdx + 8+8]
454
+ jnz LeaveLoopCmps16
455
+
456
+ add rdx,8+8+8
457
+
458
+ BEFORE_JMP
459
+ jnz LoopCmps
460
+ jmp LenMaximum
461
+ AFTER_JMP
462
+
463
+ LeaveLoopCmps16: add rdx,8
464
+ LeaveLoopCmps8: add rdx,8
465
+ LeaveLoopCmps:
466
+
467
+ test eax, 0x0000FFFF
468
+ jnz LenLower
469
+
470
+ test eax,0xffffffff
471
+
472
+ jnz LenLower32
473
+
474
+ add rdx,4
475
+ shr rax,32
476
+ or ax,ax
477
+ BEFORE_JMP
478
+ jnz LenLower
479
+ AFTER_JMP
480
+
481
+ LenLower32:
482
+ shr eax,16
483
+ add rdx,2
484
+
485
+ LenLower:
486
+ sub al, 1
487
+ adc rdx, 0
488
+ //;;; Calculate the length of the match. If it is longer than MAX_MATCH,
489
+ //;;; then automatically accept it as the best possible match and leave.
490
+
491
+ lea rax, [rdi + rdx]
492
+ sub rax, r9
493
+ cmp eax, MAX_MATCH
494
+ BEFORE_JMP
495
+ jge LenMaximum
496
+ AFTER_JMP
497
+ /*
498
+ ;;; If the length of the match is not longer than the best match we
499
+ ;;; have so far, then forget it and return to the lookup loop.
500
+ ;///////////////////////////////////
501
+ */
502
+ cmp eax, r11d
503
+ jg LongerMatch
504
+
505
+ lea rsi,[r10+r11]
506
+
507
+ mov rdi, prev_ad
508
+ mov edx, [chainlenwmask]
509
+ BEFORE_JMP
510
+ jmp LookupLoop
511
+ AFTER_JMP
512
+ /*
513
+ ;;; s->match_start = cur_match;
514
+ ;;; best_len = len;
515
+ ;;; if (len >= nice_match) break;
516
+ ;;; scan_end = *(ushf*)(scan+best_len-1);
517
+ */
518
+ LongerMatch:
519
+ mov r11d, eax
520
+ mov match_start, r8d
521
+ cmp eax, [nicematch]
522
+ BEFORE_JMP
523
+ jge LeaveNow
524
+ AFTER_JMP
525
+
526
+ lea rsi,[r10+rax]
527
+
528
+ movzx ebx, word ptr [r9 + rax - 1]
529
+ mov rdi, prev_ad
530
+ mov edx, [chainlenwmask]
531
+ BEFORE_JMP
532
+ jmp LookupLoop
533
+ AFTER_JMP
534
+
535
+ //;;; Accept the current string, with the maximum possible length.
536
+
537
+ LenMaximum:
538
+ mov r11d,MAX_MATCH
539
+ mov match_start, r8d
540
+
541
+ //;;; if ((uInt)best_len <= s->lookahead) return (uInt)best_len;
542
+ //;;; return s->lookahead;
543
+
544
+ LeaveNow:
545
+ mov eax, Lookahead
546
+ cmp r11d, eax
547
+ cmovng eax, r11d
548
+
549
+
550
+
551
+ //;;; Restore the stack and return from whence we came.
552
+
553
+
554
+ // mov rsi,[save_rsi]
555
+ // mov rdi,[save_rdi]
556
+ mov rbx,[save_rbx]
557
+ mov rbp,[save_rbp]
558
+ mov r12,[save_r12]
559
+ mov r13,[save_r13]
560
+ mov r14,[save_r14]
561
+ mov r15,[save_r15]
562
+
563
+
564
+ ret 0
565
+ //; please don't remove this string !
566
+ //; Your can freely use gvmat64 in any free or commercial app
567
+ //; but it is far better don't remove the string in the binary!
568
+ // db 0dh,0ah,"asm686 with masm, optimised assembly code from Brian Raiter, written 1998, converted to amd 64 by Gilles Vollant 2005",0dh,0ah,0
569
+
570
+
571
+ match_init:
572
+ ret 0
573
+
574
+