epeg 1.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 (504) hide show
  1. checksums.yaml +7 -0
  2. data/Gemfile +4 -0
  3. data/MANIFEST +5 -0
  4. data/TODO +1 -0
  5. data/epeg/.dockerignore +4 -0
  6. data/epeg/.gitignore +5 -0
  7. data/epeg/CMakeLists.txt +30 -0
  8. data/epeg/Dockerfile +23 -0
  9. data/epeg/Epeg.h +90 -0
  10. data/epeg/README.md +42 -0
  11. data/epeg/epeg_main.c +1642 -0
  12. data/epeg/epeg_private.h +85 -0
  13. data/epeg/example/.gitignore +1 -0
  14. data/epeg/example/CMakeLists.txt +20 -0
  15. data/epeg/example/example.jpg +0 -0
  16. data/epeg/example/rotatetest.c +29 -0
  17. data/epeg/example/scaletest.c +48 -0
  18. data/epeg/vendor/libjpeg-turbo-2.0.4/BUILDING.md +828 -0
  19. data/epeg/vendor/libjpeg-turbo-2.0.4/CMakeLists.txt +1420 -0
  20. data/epeg/vendor/libjpeg-turbo-2.0.4/ChangeLog.md +1494 -0
  21. data/epeg/vendor/libjpeg-turbo-2.0.4/LICENSE.md +132 -0
  22. data/epeg/vendor/libjpeg-turbo-2.0.4/README.ijg +277 -0
  23. data/epeg/vendor/libjpeg-turbo-2.0.4/README.md +356 -0
  24. data/epeg/vendor/libjpeg-turbo-2.0.4/cderror.h +137 -0
  25. data/epeg/vendor/libjpeg-turbo-2.0.4/cdjpeg.c +145 -0
  26. data/epeg/vendor/libjpeg-turbo-2.0.4/cdjpeg.h +157 -0
  27. data/epeg/vendor/libjpeg-turbo-2.0.4/change.log +315 -0
  28. data/epeg/vendor/libjpeg-turbo-2.0.4/cjpeg.1 +354 -0
  29. data/epeg/vendor/libjpeg-turbo-2.0.4/cjpeg.c +695 -0
  30. data/epeg/vendor/libjpeg-turbo-2.0.4/cmakescripts/BuildPackages.cmake +182 -0
  31. data/epeg/vendor/libjpeg-turbo-2.0.4/cmakescripts/GNUInstallDirs.cmake +416 -0
  32. data/epeg/vendor/libjpeg-turbo-2.0.4/cmakescripts/cmake_uninstall.cmake.in +24 -0
  33. data/epeg/vendor/libjpeg-turbo-2.0.4/cmakescripts/testclean.cmake +41 -0
  34. data/epeg/vendor/libjpeg-turbo-2.0.4/cmyk.h +61 -0
  35. data/epeg/vendor/libjpeg-turbo-2.0.4/coderules.txt +78 -0
  36. data/epeg/vendor/libjpeg-turbo-2.0.4/djpeg.1 +296 -0
  37. data/epeg/vendor/libjpeg-turbo-2.0.4/djpeg.c +822 -0
  38. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/annotated.html +104 -0
  39. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/bc_s.png +0 -0
  40. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/bdwn.png +0 -0
  41. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/classes.html +106 -0
  42. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/closed.png +0 -0
  43. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/doxygen-extra.css +3 -0
  44. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/doxygen.css +1184 -0
  45. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/doxygen.png +0 -0
  46. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/dynsections.js +97 -0
  47. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2blank.png +0 -0
  48. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2cl.png +0 -0
  49. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2doc.png +0 -0
  50. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2folderclosed.png +0 -0
  51. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2folderopen.png +0 -0
  52. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2lastnode.png +0 -0
  53. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2link.png +0 -0
  54. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2mlastnode.png +0 -0
  55. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2mnode.png +0 -0
  56. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2mo.png +0 -0
  57. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2node.png +0 -0
  58. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2ns.png +0 -0
  59. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2plastnode.png +0 -0
  60. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2pnode.png +0 -0
  61. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2splitbar.png +0 -0
  62. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/ftv2vertline.png +0 -0
  63. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/functions.html +134 -0
  64. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/functions_vars.html +134 -0
  65. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/group___turbo_j_p_e_g.html +2775 -0
  66. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/index.html +90 -0
  67. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/jquery.js +8 -0
  68. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/modules.html +95 -0
  69. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/nav_f.png +0 -0
  70. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/nav_g.png +0 -0
  71. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/nav_h.png +0 -0
  72. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/open.png +0 -0
  73. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_63.html +26 -0
  74. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_63.js +4 -0
  75. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_64.html +26 -0
  76. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_64.js +5 -0
  77. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_68.html +26 -0
  78. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_68.js +4 -0
  79. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_6e.html +26 -0
  80. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_6e.js +4 -0
  81. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_6f.html +26 -0
  82. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_6f.js +5 -0
  83. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_72.html +26 -0
  84. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_72.js +4 -0
  85. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_74.html +26 -0
  86. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_74.js +102 -0
  87. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_77.html +26 -0
  88. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_77.js +4 -0
  89. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_78.html +26 -0
  90. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_78.js +4 -0
  91. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_79.html +26 -0
  92. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/all_79.js +4 -0
  93. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/classes_74.html +26 -0
  94. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/classes_74.js +6 -0
  95. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/close.png +0 -0
  96. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/enums_74.html +26 -0
  97. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/enums_74.js +8 -0
  98. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/enumvalues_74.html +26 -0
  99. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/enumvalues_74.js +37 -0
  100. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/functions_74.html +26 -0
  101. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/functions_74.js +31 -0
  102. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/groups_74.html +26 -0
  103. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/groups_74.js +4 -0
  104. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/mag_sel.png +0 -0
  105. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/nomatches.html +12 -0
  106. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search.css +271 -0
  107. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search.js +809 -0
  108. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search_l.png +0 -0
  109. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search_m.png +0 -0
  110. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/search_r.png +0 -0
  111. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/typedefs_74.html +26 -0
  112. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/typedefs_74.js +5 -0
  113. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_63.html +26 -0
  114. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_63.js +4 -0
  115. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_64.html +26 -0
  116. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_64.js +5 -0
  117. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_68.html +26 -0
  118. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_68.js +4 -0
  119. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_6e.html +26 -0
  120. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_6e.js +4 -0
  121. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_6f.html +26 -0
  122. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_6f.js +5 -0
  123. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_72.html +26 -0
  124. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_72.js +4 -0
  125. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_74.html +26 -0
  126. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_74.js +10 -0
  127. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_77.html +26 -0
  128. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_77.js +4 -0
  129. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_78.html +26 -0
  130. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_78.js +4 -0
  131. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_79.html +26 -0
  132. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/search/variables_79.js +4 -0
  133. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/structtjregion.html +186 -0
  134. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/structtjscalingfactor.html +148 -0
  135. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/structtjtransform.html +212 -0
  136. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/sync_off.png +0 -0
  137. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/sync_on.png +0 -0
  138. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tab_a.png +0 -0
  139. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tab_b.png +0 -0
  140. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tab_h.png +0 -0
  141. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tab_s.png +0 -0
  142. data/epeg/vendor/libjpeg-turbo-2.0.4/doc/html/tabs.css +60 -0
  143. data/epeg/vendor/libjpeg-turbo-2.0.4/doxygen-extra.css +3 -0
  144. data/epeg/vendor/libjpeg-turbo-2.0.4/doxygen.config +16 -0
  145. data/epeg/vendor/libjpeg-turbo-2.0.4/example.txt +464 -0
  146. data/epeg/vendor/libjpeg-turbo-2.0.4/jaricom.c +157 -0
  147. data/epeg/vendor/libjpeg-turbo-2.0.4/java/CMakeLists.txt +88 -0
  148. data/epeg/vendor/libjpeg-turbo-2.0.4/java/MANIFEST.MF +2 -0
  149. data/epeg/vendor/libjpeg-turbo-2.0.4/java/README +52 -0
  150. data/epeg/vendor/libjpeg-turbo-2.0.4/java/TJBench.java +1021 -0
  151. data/epeg/vendor/libjpeg-turbo-2.0.4/java/TJExample.java +405 -0
  152. data/epeg/vendor/libjpeg-turbo-2.0.4/java/TJUnitTest.java +960 -0
  153. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/allclasses-frame.html +24 -0
  154. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/allclasses-noframe.html +24 -0
  155. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/constant-values.html +532 -0
  156. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/deprecated-list.html +252 -0
  157. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/help-doc.html +210 -0
  158. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/index-all.html +1029 -0
  159. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/index.html +71 -0
  160. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJ.html +1356 -0
  161. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJCompressor.html +926 -0
  162. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJCustomFilter.html +241 -0
  163. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJDecompressor.html +1255 -0
  164. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJException.html +340 -0
  165. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJScalingFactor.html +343 -0
  166. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJTransform.html +751 -0
  167. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/TJTransformer.html +421 -0
  168. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/YUVImage.html +765 -0
  169. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/package-frame.html +31 -0
  170. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/package-summary.html +202 -0
  171. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/org/libjpegturbo/turbojpeg/package-tree.html +160 -0
  172. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/overview-tree.html +164 -0
  173. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/package-list +1 -0
  174. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/resources/background.gif +0 -0
  175. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/resources/tab.gif +0 -0
  176. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/resources/titlebar.gif +0 -0
  177. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/resources/titlebar_end.gif +0 -0
  178. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/script.js +30 -0
  179. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/serialized-form.html +176 -0
  180. data/epeg/vendor/libjpeg-turbo-2.0.4/java/doc/stylesheet.css +474 -0
  181. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJ.java +584 -0
  182. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJCompressor.java +677 -0
  183. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJCustomFilter.java +76 -0
  184. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJDecompressor.java +931 -0
  185. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJException.java +78 -0
  186. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJLoader-unix.java.in +59 -0
  187. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJLoader-win.java.in +35 -0
  188. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJScalingFactor.java +115 -0
  189. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJTransform.java +227 -0
  190. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/TJTransformer.java +163 -0
  191. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org/libjpegturbo/turbojpeg/YUVImage.java +445 -0
  192. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org_libjpegturbo_turbojpeg_TJ.h +129 -0
  193. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org_libjpegturbo_turbojpeg_TJCompressor.h +101 -0
  194. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org_libjpegturbo_turbojpeg_TJDecompressor.h +101 -0
  195. data/epeg/vendor/libjpeg-turbo-2.0.4/java/org_libjpegturbo_turbojpeg_TJTransformer.h +29 -0
  196. data/epeg/vendor/libjpeg-turbo-2.0.4/jcapimin.c +295 -0
  197. data/epeg/vendor/libjpeg-turbo-2.0.4/jcapistd.c +162 -0
  198. data/epeg/vendor/libjpeg-turbo-2.0.4/jcarith.c +932 -0
  199. data/epeg/vendor/libjpeg-turbo-2.0.4/jccoefct.c +449 -0
  200. data/epeg/vendor/libjpeg-turbo-2.0.4/jccolext.c +144 -0
  201. data/epeg/vendor/libjpeg-turbo-2.0.4/jccolor.c +710 -0
  202. data/epeg/vendor/libjpeg-turbo-2.0.4/jcdctmgr.c +721 -0
  203. data/epeg/vendor/libjpeg-turbo-2.0.4/jchuff.c +1096 -0
  204. data/epeg/vendor/libjpeg-turbo-2.0.4/jchuff.h +42 -0
  205. data/epeg/vendor/libjpeg-turbo-2.0.4/jcicc.c +105 -0
  206. data/epeg/vendor/libjpeg-turbo-2.0.4/jcinit.c +77 -0
  207. data/epeg/vendor/libjpeg-turbo-2.0.4/jcmainct.c +162 -0
  208. data/epeg/vendor/libjpeg-turbo-2.0.4/jcmarker.c +664 -0
  209. data/epeg/vendor/libjpeg-turbo-2.0.4/jcmaster.c +640 -0
  210. data/epeg/vendor/libjpeg-turbo-2.0.4/jcomapi.c +109 -0
  211. data/epeg/vendor/libjpeg-turbo-2.0.4/jconfig.h.in +73 -0
  212. data/epeg/vendor/libjpeg-turbo-2.0.4/jconfig.txt +143 -0
  213. data/epeg/vendor/libjpeg-turbo-2.0.4/jconfigint.h.in +31 -0
  214. data/epeg/vendor/libjpeg-turbo-2.0.4/jcparam.c +541 -0
  215. data/epeg/vendor/libjpeg-turbo-2.0.4/jcphuff.c +1105 -0
  216. data/epeg/vendor/libjpeg-turbo-2.0.4/jcprepct.c +351 -0
  217. data/epeg/vendor/libjpeg-turbo-2.0.4/jcsample.c +539 -0
  218. data/epeg/vendor/libjpeg-turbo-2.0.4/jcstest.c +126 -0
  219. data/epeg/vendor/libjpeg-turbo-2.0.4/jctrans.c +400 -0
  220. data/epeg/vendor/libjpeg-turbo-2.0.4/jdapimin.c +407 -0
  221. data/epeg/vendor/libjpeg-turbo-2.0.4/jdapistd.c +639 -0
  222. data/epeg/vendor/libjpeg-turbo-2.0.4/jdarith.c +773 -0
  223. data/epeg/vendor/libjpeg-turbo-2.0.4/jdatadst-tj.c +203 -0
  224. data/epeg/vendor/libjpeg-turbo-2.0.4/jdatadst.c +293 -0
  225. data/epeg/vendor/libjpeg-turbo-2.0.4/jdatasrc-tj.c +194 -0
  226. data/epeg/vendor/libjpeg-turbo-2.0.4/jdatasrc.c +295 -0
  227. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcoefct.c +692 -0
  228. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcoefct.h +82 -0
  229. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcol565.c +384 -0
  230. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcolext.c +143 -0
  231. data/epeg/vendor/libjpeg-turbo-2.0.4/jdcolor.c +883 -0
  232. data/epeg/vendor/libjpeg-turbo-2.0.4/jdct.h +208 -0
  233. data/epeg/vendor/libjpeg-turbo-2.0.4/jddctmgr.c +352 -0
  234. data/epeg/vendor/libjpeg-turbo-2.0.4/jdhuff.c +831 -0
  235. data/epeg/vendor/libjpeg-turbo-2.0.4/jdhuff.h +238 -0
  236. data/epeg/vendor/libjpeg-turbo-2.0.4/jdicc.c +171 -0
  237. data/epeg/vendor/libjpeg-turbo-2.0.4/jdinput.c +408 -0
  238. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmainct.c +460 -0
  239. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmainct.h +71 -0
  240. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmarker.c +1377 -0
  241. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmaster.c +737 -0
  242. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmaster.h +28 -0
  243. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmerge.c +617 -0
  244. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmrg565.c +354 -0
  245. data/epeg/vendor/libjpeg-turbo-2.0.4/jdmrgext.c +184 -0
  246. data/epeg/vendor/libjpeg-turbo-2.0.4/jdphuff.c +687 -0
  247. data/epeg/vendor/libjpeg-turbo-2.0.4/jdpostct.c +294 -0
  248. data/epeg/vendor/libjpeg-turbo-2.0.4/jdsample.c +518 -0
  249. data/epeg/vendor/libjpeg-turbo-2.0.4/jdsample.h +50 -0
  250. data/epeg/vendor/libjpeg-turbo-2.0.4/jdtrans.c +155 -0
  251. data/epeg/vendor/libjpeg-turbo-2.0.4/jerror.c +251 -0
  252. data/epeg/vendor/libjpeg-turbo-2.0.4/jerror.h +316 -0
  253. data/epeg/vendor/libjpeg-turbo-2.0.4/jfdctflt.c +169 -0
  254. data/epeg/vendor/libjpeg-turbo-2.0.4/jfdctfst.c +227 -0
  255. data/epeg/vendor/libjpeg-turbo-2.0.4/jfdctint.c +288 -0
  256. data/epeg/vendor/libjpeg-turbo-2.0.4/jidctflt.c +240 -0
  257. data/epeg/vendor/libjpeg-turbo-2.0.4/jidctfst.c +371 -0
  258. data/epeg/vendor/libjpeg-turbo-2.0.4/jidctint.c +2627 -0
  259. data/epeg/vendor/libjpeg-turbo-2.0.4/jidctred.c +409 -0
  260. data/epeg/vendor/libjpeg-turbo-2.0.4/jinclude.h +88 -0
  261. data/epeg/vendor/libjpeg-turbo-2.0.4/jmemmgr.c +1179 -0
  262. data/epeg/vendor/libjpeg-turbo-2.0.4/jmemnobs.c +115 -0
  263. data/epeg/vendor/libjpeg-turbo-2.0.4/jmemsys.h +178 -0
  264. data/epeg/vendor/libjpeg-turbo-2.0.4/jmorecfg.h +421 -0
  265. data/epeg/vendor/libjpeg-turbo-2.0.4/jpeg_nbits_table.h +4098 -0
  266. data/epeg/vendor/libjpeg-turbo-2.0.4/jpegcomp.h +31 -0
  267. data/epeg/vendor/libjpeg-turbo-2.0.4/jpegint.h +368 -0
  268. data/epeg/vendor/libjpeg-turbo-2.0.4/jpeglib.h +1132 -0
  269. data/epeg/vendor/libjpeg-turbo-2.0.4/jpegtran.1 +295 -0
  270. data/epeg/vendor/libjpeg-turbo-2.0.4/jpegtran.c +601 -0
  271. data/epeg/vendor/libjpeg-turbo-2.0.4/jquant1.c +859 -0
  272. data/epeg/vendor/libjpeg-turbo-2.0.4/jquant2.c +1285 -0
  273. data/epeg/vendor/libjpeg-turbo-2.0.4/jsimd.h +117 -0
  274. data/epeg/vendor/libjpeg-turbo-2.0.4/jsimd_none.c +418 -0
  275. data/epeg/vendor/libjpeg-turbo-2.0.4/jsimddct.h +70 -0
  276. data/epeg/vendor/libjpeg-turbo-2.0.4/jstdhuff.c +143 -0
  277. data/epeg/vendor/libjpeg-turbo-2.0.4/jutils.c +133 -0
  278. data/epeg/vendor/libjpeg-turbo-2.0.4/jversion.h +52 -0
  279. data/epeg/vendor/libjpeg-turbo-2.0.4/libjpeg.map.in +11 -0
  280. data/epeg/vendor/libjpeg-turbo-2.0.4/libjpeg.txt +3144 -0
  281. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/CMakeLists.txt +1 -0
  282. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/md5.c +275 -0
  283. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/md5.h +57 -0
  284. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/md5cmp.c +59 -0
  285. data/epeg/vendor/libjpeg-turbo-2.0.4/md5/md5hl.c +125 -0
  286. data/epeg/vendor/libjpeg-turbo-2.0.4/rdbmp.c +689 -0
  287. data/epeg/vendor/libjpeg-turbo-2.0.4/rdcolmap.c +254 -0
  288. data/epeg/vendor/libjpeg-turbo-2.0.4/rdgif.c +39 -0
  289. data/epeg/vendor/libjpeg-turbo-2.0.4/rdjpgcom.1 +63 -0
  290. data/epeg/vendor/libjpeg-turbo-2.0.4/rdjpgcom.c +510 -0
  291. data/epeg/vendor/libjpeg-turbo-2.0.4/rdppm.c +766 -0
  292. data/epeg/vendor/libjpeg-turbo-2.0.4/rdrle.c +389 -0
  293. data/epeg/vendor/libjpeg-turbo-2.0.4/rdswitch.c +424 -0
  294. data/epeg/vendor/libjpeg-turbo-2.0.4/rdtarga.c +509 -0
  295. data/epeg/vendor/libjpeg-turbo-2.0.4/release/Distribution.xml.in +24 -0
  296. data/epeg/vendor/libjpeg-turbo-2.0.4/release/License.rtf +20 -0
  297. data/epeg/vendor/libjpeg-turbo-2.0.4/release/ReadMe.txt +5 -0
  298. data/epeg/vendor/libjpeg-turbo-2.0.4/release/Welcome.rtf +17 -0
  299. data/epeg/vendor/libjpeg-turbo-2.0.4/release/deb-control.in +31 -0
  300. data/epeg/vendor/libjpeg-turbo-2.0.4/release/installer.nsi.in +191 -0
  301. data/epeg/vendor/libjpeg-turbo-2.0.4/release/libjpeg.pc.in +10 -0
  302. data/epeg/vendor/libjpeg-turbo-2.0.4/release/libturbojpeg.pc.in +10 -0
  303. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makecygwinpkg.in +66 -0
  304. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makedpkg.in +115 -0
  305. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makemacpkg.in +284 -0
  306. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makerpm.in +30 -0
  307. data/epeg/vendor/libjpeg-turbo-2.0.4/release/makesrpm.in +48 -0
  308. data/epeg/vendor/libjpeg-turbo-2.0.4/release/maketarball.in +51 -0
  309. data/epeg/vendor/libjpeg-turbo-2.0.4/release/rpm.spec.in +221 -0
  310. data/epeg/vendor/libjpeg-turbo-2.0.4/release/uninstall.in +113 -0
  311. data/epeg/vendor/libjpeg-turbo-2.0.4/sharedlib/CMakeLists.txt +99 -0
  312. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/CMakeLists.txt +385 -0
  313. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/arm/jsimd.c +721 -0
  314. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/arm/jsimd_neon.S +2878 -0
  315. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/arm64/jsimd.c +798 -0
  316. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/arm64/jsimd_neon.S +3433 -0
  317. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/gas-preprocessor.in +1 -0
  318. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolext-avx2.asm +578 -0
  319. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolext-mmx.asm +476 -0
  320. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolext-sse2.asm +503 -0
  321. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolor-avx2.asm +121 -0
  322. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolor-mmx.asm +121 -0
  323. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jccolor-sse2.asm +120 -0
  324. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgray-avx2.asm +113 -0
  325. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgray-mmx.asm +113 -0
  326. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgray-sse2.asm +112 -0
  327. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgryext-avx2.asm +457 -0
  328. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgryext-mmx.asm +355 -0
  329. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcgryext-sse2.asm +382 -0
  330. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jchuff-sse2.asm +424 -0
  331. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcphuff-sse2.asm +660 -0
  332. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcsample-avx2.asm +388 -0
  333. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcsample-mmx.asm +324 -0
  334. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jcsample-sse2.asm +351 -0
  335. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolext-avx2.asm +515 -0
  336. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolext-mmx.asm +404 -0
  337. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolext-sse2.asm +458 -0
  338. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolor-avx2.asm +118 -0
  339. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolor-mmx.asm +117 -0
  340. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdcolor-sse2.asm +117 -0
  341. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmerge-avx2.asm +136 -0
  342. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmerge-mmx.asm +123 -0
  343. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmerge-sse2.asm +135 -0
  344. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmrgext-avx2.asm +575 -0
  345. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmrgext-mmx.asm +460 -0
  346. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdmrgext-sse2.asm +517 -0
  347. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdsample-avx2.asm +760 -0
  348. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdsample-mmx.asm +731 -0
  349. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jdsample-sse2.asm +724 -0
  350. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctflt-3dn.asm +318 -0
  351. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctflt-sse.asm +369 -0
  352. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctfst-mmx.asm +395 -0
  353. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctfst-sse2.asm +403 -0
  354. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctint-avx2.asm +331 -0
  355. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctint-mmx.asm +620 -0
  356. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jfdctint-sse2.asm +633 -0
  357. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctflt-3dn.asm +451 -0
  358. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctflt-sse.asm +571 -0
  359. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctflt-sse2.asm +497 -0
  360. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctfst-mmx.asm +499 -0
  361. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctfst-sse2.asm +501 -0
  362. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctint-avx2.asm +453 -0
  363. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctint-mmx.asm +851 -0
  364. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctint-sse2.asm +858 -0
  365. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctred-mmx.asm +704 -0
  366. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jidctred-sse2.asm +592 -0
  367. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquant-3dn.asm +230 -0
  368. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquant-mmx.asm +276 -0
  369. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquant-sse.asm +208 -0
  370. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquantf-sse2.asm +168 -0
  371. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquanti-avx2.asm +188 -0
  372. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jquanti-sse2.asm +201 -0
  373. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jsimd.c +1253 -0
  374. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/i386/jsimdcpu.asm +135 -0
  375. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/jsimd.h +1083 -0
  376. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jccolext-mmi.c +483 -0
  377. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jccolor-mmi.c +148 -0
  378. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jcsample-mmi.c +100 -0
  379. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jcsample.h +28 -0
  380. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jdcolext-mmi.c +424 -0
  381. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jdcolor-mmi.c +139 -0
  382. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jdsample-mmi.c +245 -0
  383. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jfdctint-mmi.c +398 -0
  384. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jidctint-mmi.c +571 -0
  385. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jquanti-mmi.c +130 -0
  386. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jsimd.c +610 -0
  387. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/jsimd_mmi.h +57 -0
  388. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/loongson/loongson-mmintrin.h +1324 -0
  389. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/mips/jsimd.c +1123 -0
  390. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/mips/jsimd_dspr2.S +4479 -0
  391. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/mips/jsimd_dspr2_asm.h +292 -0
  392. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jcolsamp.inc +135 -0
  393. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jdct.inc +31 -0
  394. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jpeg_nbits_table.inc +4097 -0
  395. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jsimdcfg.inc +93 -0
  396. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jsimdcfg.inc.h +131 -0
  397. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/nasm/jsimdext.inc +479 -0
  398. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jccolext-altivec.c +269 -0
  399. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jccolor-altivec.c +116 -0
  400. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jcgray-altivec.c +111 -0
  401. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jcgryext-altivec.c +228 -0
  402. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jcsample-altivec.c +159 -0
  403. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jcsample.h +28 -0
  404. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdcolext-altivec.c +276 -0
  405. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdcolor-altivec.c +106 -0
  406. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdmerge-altivec.c +130 -0
  407. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdmrgext-altivec.c +329 -0
  408. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jdsample-altivec.c +400 -0
  409. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jfdctfst-altivec.c +154 -0
  410. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jfdctint-altivec.c +258 -0
  411. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jidctfst-altivec.c +255 -0
  412. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jidctint-altivec.c +357 -0
  413. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jquanti-altivec.c +250 -0
  414. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jsimd.c +872 -0
  415. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/powerpc/jsimd_altivec.h +98 -0
  416. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jccolext-avx2.asm +558 -0
  417. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jccolext-sse2.asm +483 -0
  418. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jccolor-avx2.asm +121 -0
  419. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jccolor-sse2.asm +120 -0
  420. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcgray-avx2.asm +113 -0
  421. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcgray-sse2.asm +112 -0
  422. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcgryext-avx2.asm +437 -0
  423. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcgryext-sse2.asm +362 -0
  424. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jchuff-sse2.asm +346 -0
  425. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcphuff-sse2.asm +637 -0
  426. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcsample-avx2.asm +366 -0
  427. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jcsample-sse2.asm +329 -0
  428. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdcolext-avx2.asm +495 -0
  429. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdcolext-sse2.asm +438 -0
  430. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdcolor-avx2.asm +118 -0
  431. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdcolor-sse2.asm +117 -0
  432. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdmerge-avx2.asm +136 -0
  433. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdmerge-sse2.asm +135 -0
  434. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdmrgext-avx2.asm +593 -0
  435. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdmrgext-sse2.asm +535 -0
  436. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdsample-avx2.asm +695 -0
  437. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jdsample-sse2.asm +664 -0
  438. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jfdctflt-sse.asm +355 -0
  439. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jfdctfst-sse2.asm +389 -0
  440. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jfdctint-avx2.asm +320 -0
  441. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jfdctint-sse2.asm +619 -0
  442. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctflt-sse2.asm +481 -0
  443. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctfst-sse2.asm +490 -0
  444. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctint-avx2.asm +417 -0
  445. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctint-sse2.asm +846 -0
  446. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jidctred-sse2.asm +573 -0
  447. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jquantf-sse2.asm +154 -0
  448. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jquanti-avx2.asm +162 -0
  449. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jquanti-sse2.asm +187 -0
  450. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jsimd.c +1076 -0
  451. data/epeg/vendor/libjpeg-turbo-2.0.4/simd/x86_64/jsimdcpu.asm +86 -0
  452. data/epeg/vendor/libjpeg-turbo-2.0.4/structure.txt +904 -0
  453. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/nightshot_iso_100.bmp +0 -0
  454. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/nightshot_iso_100.txt +25 -0
  455. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test.scan +5 -0
  456. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test1.icc +0 -0
  457. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test1.icc.txt +20 -0
  458. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test2.icc +0 -0
  459. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/test2.icc.txt +20 -0
  460. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testimgari.jpg +0 -0
  461. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testimgint.jpg +0 -0
  462. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testorig.jpg +0 -0
  463. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testorig.ppm +4 -0
  464. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/testorig12.jpg +0 -0
  465. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/vgl_5674_0098.bmp +0 -0
  466. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/vgl_6434_0018a.bmp +0 -0
  467. data/epeg/vendor/libjpeg-turbo-2.0.4/testimages/vgl_6548_0026a.bmp +0 -0
  468. data/epeg/vendor/libjpeg-turbo-2.0.4/tjbench.c +1031 -0
  469. data/epeg/vendor/libjpeg-turbo-2.0.4/tjbenchtest.in +256 -0
  470. data/epeg/vendor/libjpeg-turbo-2.0.4/tjbenchtest.java.in +215 -0
  471. data/epeg/vendor/libjpeg-turbo-2.0.4/tjexample.c +396 -0
  472. data/epeg/vendor/libjpeg-turbo-2.0.4/tjexampletest.in +149 -0
  473. data/epeg/vendor/libjpeg-turbo-2.0.4/tjexampletest.java.in +151 -0
  474. data/epeg/vendor/libjpeg-turbo-2.0.4/tjunittest.c +931 -0
  475. data/epeg/vendor/libjpeg-turbo-2.0.4/tjutil.c +70 -0
  476. data/epeg/vendor/libjpeg-turbo-2.0.4/tjutil.h +47 -0
  477. data/epeg/vendor/libjpeg-turbo-2.0.4/transupp.c +1628 -0
  478. data/epeg/vendor/libjpeg-turbo-2.0.4/transupp.h +210 -0
  479. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg-jni.c +1246 -0
  480. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg-mapfile +65 -0
  481. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg-mapfile.jni +101 -0
  482. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg.c +2152 -0
  483. data/epeg/vendor/libjpeg-turbo-2.0.4/turbojpeg.h +1744 -0
  484. data/epeg/vendor/libjpeg-turbo-2.0.4/usage.txt +635 -0
  485. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jconfig.h.in +34 -0
  486. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg62-memsrcdst.def +108 -0
  487. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg62.def +106 -0
  488. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg7-memsrcdst.def +110 -0
  489. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg7.def +108 -0
  490. data/epeg/vendor/libjpeg-turbo-2.0.4/win/jpeg8.def +111 -0
  491. data/epeg/vendor/libjpeg-turbo-2.0.4/wizard.txt +212 -0
  492. data/epeg/vendor/libjpeg-turbo-2.0.4/wrbmp.c +558 -0
  493. data/epeg/vendor/libjpeg-turbo-2.0.4/wrgif.c +413 -0
  494. data/epeg/vendor/libjpeg-turbo-2.0.4/wrjpgcom.1 +103 -0
  495. data/epeg/vendor/libjpeg-turbo-2.0.4/wrjpgcom.c +591 -0
  496. data/epeg/vendor/libjpeg-turbo-2.0.4/wrppm.c +365 -0
  497. data/epeg/vendor/libjpeg-turbo-2.0.4/wrrle.c +309 -0
  498. data/epeg/vendor/libjpeg-turbo-2.0.4/wrtarga.c +261 -0
  499. data/epeg.c +131 -0
  500. data/epeg.gemspec +18 -0
  501. data/extconf.rb +80 -0
  502. data/test.jpg +0 -0
  503. data/test.rb +42 -0
  504. metadata +546 -0
@@ -0,0 +1,388 @@
1
+ ;
2
+ ; jcsample.asm - downsampling (AVX2)
3
+ ;
4
+ ; Copyright 2009 Pierre Ossman <ossman@cendio.se> for Cendio AB
5
+ ; Copyright (C) 2015, Intel Corporation.
6
+ ; Copyright (C) 2016, D. R. Commander.
7
+ ;
8
+ ; Based on the x86 SIMD extension for IJG JPEG library
9
+ ; Copyright (C) 1999-2006, MIYASAKA Masaru.
10
+ ; For conditions of distribution and use, see copyright notice in jsimdext.inc
11
+ ;
12
+ ; This file should be assembled with NASM (Netwide Assembler),
13
+ ; can *not* be assembled with Microsoft's MASM or any compatible
14
+ ; assembler (including Borland's Turbo Assembler).
15
+ ; NASM is available from http://nasm.sourceforge.net/ or
16
+ ; http://sourceforge.net/project/showfiles.php?group_id=6208
17
+
18
+ %include "jsimdext.inc"
19
+
20
+ ; --------------------------------------------------------------------------
21
+ SECTION SEG_TEXT
22
+ BITS 32
23
+ ;
24
+ ; Downsample pixel values of a single component.
25
+ ; This version handles the common case of 2:1 horizontal and 1:1 vertical,
26
+ ; without smoothing.
27
+ ;
28
+ ; GLOBAL(void)
29
+ ; jsimd_h2v1_downsample_avx2(JDIMENSION image_width, int max_v_samp_factor,
30
+ ; JDIMENSION v_samp_factor,
31
+ ; JDIMENSION width_in_blocks, JSAMPARRAY input_data,
32
+ ; JSAMPARRAY output_data);
33
+ ;
34
+
35
+ %define img_width(b) (b) + 8 ; JDIMENSION image_width
36
+ %define max_v_samp(b) (b) + 12 ; int max_v_samp_factor
37
+ %define v_samp(b) (b) + 16 ; JDIMENSION v_samp_factor
38
+ %define width_blks(b) (b) + 20 ; JDIMENSION width_in_blocks
39
+ %define input_data(b) (b) + 24 ; JSAMPARRAY input_data
40
+ %define output_data(b) (b) + 28 ; JSAMPARRAY output_data
41
+
42
+ align 32
43
+ GLOBAL_FUNCTION(jsimd_h2v1_downsample_avx2)
44
+
45
+ EXTN(jsimd_h2v1_downsample_avx2):
46
+ push ebp
47
+ mov ebp, esp
48
+ ; push ebx ; unused
49
+ ; push ecx ; need not be preserved
50
+ ; push edx ; need not be preserved
51
+ push esi
52
+ push edi
53
+
54
+ mov ecx, JDIMENSION [width_blks(ebp)]
55
+ shl ecx, 3 ; imul ecx,DCTSIZE (ecx = output_cols)
56
+ jz near .return
57
+
58
+ mov edx, JDIMENSION [img_width(ebp)]
59
+
60
+ ; -- expand_right_edge
61
+
62
+ push ecx
63
+ shl ecx, 1 ; output_cols * 2
64
+ sub ecx, edx
65
+ jle short .expand_end
66
+
67
+ mov eax, INT [max_v_samp(ebp)]
68
+ test eax, eax
69
+ jle short .expand_end
70
+
71
+ cld
72
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
73
+ alignx 16, 7
74
+ .expandloop:
75
+ push eax
76
+ push ecx
77
+
78
+ mov edi, JSAMPROW [esi]
79
+ add edi, edx
80
+ mov al, JSAMPLE [edi-1]
81
+
82
+ rep stosb
83
+
84
+ pop ecx
85
+ pop eax
86
+
87
+ add esi, byte SIZEOF_JSAMPROW
88
+ dec eax
89
+ jg short .expandloop
90
+
91
+ .expand_end:
92
+ pop ecx ; output_cols
93
+
94
+ ; -- h2v1_downsample
95
+
96
+ mov eax, JDIMENSION [v_samp(ebp)] ; rowctr
97
+ test eax, eax
98
+ jle near .return
99
+
100
+ mov edx, 0x00010000 ; bias pattern
101
+ vmovd xmm7, edx
102
+ vpshufd xmm7, xmm7, 0x00 ; xmm7={0, 1, 0, 1, 0, 1, 0, 1}
103
+ vperm2i128 ymm7, ymm7, ymm7, 0 ; ymm7={xmm7, xmm7}
104
+ vpcmpeqw ymm6, ymm6, ymm6
105
+ vpsrlw ymm6, ymm6, BYTE_BIT ; ymm6={0xFF 0x00 0xFF 0x00 ..}
106
+
107
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
108
+ mov edi, JSAMPARRAY [output_data(ebp)] ; output_data
109
+ alignx 16, 7
110
+ .rowloop:
111
+ push ecx
112
+ push edi
113
+ push esi
114
+
115
+ mov esi, JSAMPROW [esi] ; inptr
116
+ mov edi, JSAMPROW [edi] ; outptr
117
+
118
+ cmp ecx, byte SIZEOF_YMMWORD
119
+ jae short .columnloop
120
+ alignx 16, 7
121
+
122
+ .columnloop_r24:
123
+ ; ecx can possibly be 8, 16, 24
124
+ cmp ecx, 24
125
+ jne .columnloop_r16
126
+ vmovdqu ymm0, YMMWORD [esi+0*SIZEOF_YMMWORD]
127
+ vmovdqu xmm1, XMMWORD [esi+1*SIZEOF_YMMWORD]
128
+ mov ecx, SIZEOF_YMMWORD
129
+ jmp short .downsample
130
+
131
+ .columnloop_r16:
132
+ cmp ecx, 16
133
+ jne .columnloop_r8
134
+ vmovdqu ymm0, YMMWORD [esi+0*SIZEOF_YMMWORD]
135
+ vpxor ymm1, ymm1, ymm1
136
+ mov ecx, SIZEOF_YMMWORD
137
+ jmp short .downsample
138
+
139
+ .columnloop_r8:
140
+ vmovdqu xmm0, XMMWORD[esi+0*SIZEOF_YMMWORD]
141
+ vpxor ymm1, ymm1, ymm1
142
+ mov ecx, SIZEOF_YMMWORD
143
+ jmp short .downsample
144
+ alignx 16, 7
145
+
146
+ .columnloop:
147
+ vmovdqu ymm0, YMMWORD [esi+0*SIZEOF_YMMWORD]
148
+ vmovdqu ymm1, YMMWORD [esi+1*SIZEOF_YMMWORD]
149
+
150
+ .downsample:
151
+ vpsrlw ymm2, ymm0, BYTE_BIT
152
+ vpand ymm0, ymm0, ymm6
153
+ vpsrlw ymm3, ymm1, BYTE_BIT
154
+ vpand ymm1, ymm1, ymm6
155
+
156
+ vpaddw ymm0, ymm0, ymm2
157
+ vpaddw ymm1, ymm1, ymm3
158
+ vpaddw ymm0, ymm0, ymm7
159
+ vpaddw ymm1, ymm1, ymm7
160
+ vpsrlw ymm0, ymm0, 1
161
+ vpsrlw ymm1, ymm1, 1
162
+
163
+ vpackuswb ymm0, ymm0, ymm1
164
+ vpermq ymm0, ymm0, 0xd8
165
+
166
+ vmovdqu YMMWORD [edi+0*SIZEOF_YMMWORD], ymm0
167
+
168
+ sub ecx, byte SIZEOF_YMMWORD ; outcol
169
+ add esi, byte 2*SIZEOF_YMMWORD ; inptr
170
+ add edi, byte 1*SIZEOF_YMMWORD ; outptr
171
+ cmp ecx, byte SIZEOF_YMMWORD
172
+ jae short .columnloop
173
+ test ecx, ecx
174
+ jnz near .columnloop_r24
175
+
176
+ pop esi
177
+ pop edi
178
+ pop ecx
179
+
180
+ add esi, byte SIZEOF_JSAMPROW ; input_data
181
+ add edi, byte SIZEOF_JSAMPROW ; output_data
182
+ dec eax ; rowctr
183
+ jg near .rowloop
184
+
185
+ .return:
186
+ vzeroupper
187
+ pop edi
188
+ pop esi
189
+ ; pop edx ; need not be preserved
190
+ ; pop ecx ; need not be preserved
191
+ ; pop ebx ; unused
192
+ pop ebp
193
+ ret
194
+
195
+ ; --------------------------------------------------------------------------
196
+ ;
197
+ ; Downsample pixel values of a single component.
198
+ ; This version handles the standard case of 2:1 horizontal and 2:1 vertical,
199
+ ; without smoothing.
200
+ ;
201
+ ; GLOBAL(void)
202
+ ; jsimd_h2v2_downsample_avx2(JDIMENSION image_width, int max_v_samp_factor,
203
+ ; JDIMENSION v_samp_factor,
204
+ ; JDIMENSION width_in_blocks, JSAMPARRAY input_data,
205
+ ; JSAMPARRAY output_data);
206
+ ;
207
+
208
+ %define img_width(b) (b) + 8 ; JDIMENSION image_width
209
+ %define max_v_samp(b) (b) + 12 ; int max_v_samp_factor
210
+ %define v_samp(b) (b) + 16 ; JDIMENSION v_samp_factor
211
+ %define width_blks(b) (b) + 20 ; JDIMENSION width_in_blocks
212
+ %define input_data(b) (b) + 24 ; JSAMPARRAY input_data
213
+ %define output_data(b) (b) + 28 ; JSAMPARRAY output_data
214
+
215
+ align 32
216
+ GLOBAL_FUNCTION(jsimd_h2v2_downsample_avx2)
217
+
218
+ EXTN(jsimd_h2v2_downsample_avx2):
219
+ push ebp
220
+ mov ebp, esp
221
+ ; push ebx ; unused
222
+ ; push ecx ; need not be preserved
223
+ ; push edx ; need not be preserved
224
+ push esi
225
+ push edi
226
+
227
+ mov ecx, JDIMENSION [width_blks(ebp)]
228
+ shl ecx, 3 ; imul ecx,DCTSIZE (ecx = output_cols)
229
+ jz near .return
230
+
231
+ mov edx, JDIMENSION [img_width(ebp)]
232
+
233
+ ; -- expand_right_edge
234
+
235
+ push ecx
236
+ shl ecx, 1 ; output_cols * 2
237
+ sub ecx, edx
238
+ jle short .expand_end
239
+
240
+ mov eax, INT [max_v_samp(ebp)]
241
+ test eax, eax
242
+ jle short .expand_end
243
+
244
+ cld
245
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
246
+ alignx 16, 7
247
+ .expandloop:
248
+ push eax
249
+ push ecx
250
+
251
+ mov edi, JSAMPROW [esi]
252
+ add edi, edx
253
+ mov al, JSAMPLE [edi-1]
254
+
255
+ rep stosb
256
+
257
+ pop ecx
258
+ pop eax
259
+
260
+ add esi, byte SIZEOF_JSAMPROW
261
+ dec eax
262
+ jg short .expandloop
263
+
264
+ .expand_end:
265
+ pop ecx ; output_cols
266
+
267
+ ; -- h2v2_downsample
268
+
269
+ mov eax, JDIMENSION [v_samp(ebp)] ; rowctr
270
+ test eax, eax
271
+ jle near .return
272
+
273
+ mov edx, 0x00020001 ; bias pattern
274
+ vmovd xmm7, edx
275
+ vpcmpeqw ymm6, ymm6, ymm6
276
+ vpshufd xmm7, xmm7, 0x00 ; ymm7={1, 2, 1, 2, 1, 2, 1, 2}
277
+ vperm2i128 ymm7, ymm7, ymm7, 0
278
+ vpsrlw ymm6, ymm6, BYTE_BIT ; ymm6={0xFF 0x00 0xFF 0x00 ..}
279
+
280
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
281
+ mov edi, JSAMPARRAY [output_data(ebp)] ; output_data
282
+ alignx 16, 7
283
+ .rowloop:
284
+ push ecx
285
+ push edi
286
+ push esi
287
+
288
+ mov edx, JSAMPROW [esi+0*SIZEOF_JSAMPROW] ; inptr0
289
+ mov esi, JSAMPROW [esi+1*SIZEOF_JSAMPROW] ; inptr1
290
+ mov edi, JSAMPROW [edi] ; outptr
291
+
292
+ cmp ecx, byte SIZEOF_YMMWORD
293
+ jae short .columnloop
294
+ alignx 16, 7
295
+
296
+ .columnloop_r24:
297
+ cmp ecx, 24
298
+ jne .columnloop_r16
299
+ vmovdqu ymm0, YMMWORD [edx+0*SIZEOF_YMMWORD]
300
+ vmovdqu ymm1, YMMWORD [esi+0*SIZEOF_YMMWORD]
301
+ vmovdqu xmm2, XMMWORD [edx+1*SIZEOF_YMMWORD]
302
+ vmovdqu xmm3, XMMWORD [esi+1*SIZEOF_YMMWORD]
303
+ mov ecx, SIZEOF_YMMWORD
304
+ jmp short .downsample
305
+
306
+ .columnloop_r16:
307
+ cmp ecx, 16
308
+ jne .columnloop_r8
309
+ vmovdqu ymm0, YMMWORD [edx+0*SIZEOF_YMMWORD]
310
+ vmovdqu ymm1, YMMWORD [esi+0*SIZEOF_YMMWORD]
311
+ vpxor ymm2, ymm2, ymm2
312
+ vpxor ymm3, ymm3, ymm3
313
+ mov ecx, SIZEOF_YMMWORD
314
+ jmp short .downsample
315
+
316
+ .columnloop_r8:
317
+ vmovdqu xmm0, XMMWORD [edx+0*SIZEOF_XMMWORD]
318
+ vmovdqu xmm1, XMMWORD [esi+0*SIZEOF_XMMWORD]
319
+ vpxor ymm2, ymm2, ymm2
320
+ vpxor ymm3, ymm3, ymm3
321
+ mov ecx, SIZEOF_YMMWORD
322
+ jmp short .downsample
323
+ alignx 16, 7
324
+
325
+ .columnloop:
326
+ vmovdqu ymm0, YMMWORD [edx+0*SIZEOF_YMMWORD]
327
+ vmovdqu ymm1, YMMWORD [esi+0*SIZEOF_YMMWORD]
328
+ vmovdqu ymm2, YMMWORD [edx+1*SIZEOF_YMMWORD]
329
+ vmovdqu ymm3, YMMWORD [esi+1*SIZEOF_YMMWORD]
330
+
331
+ .downsample:
332
+ vpand ymm4, ymm0, ymm6
333
+ vpsrlw ymm0, ymm0, BYTE_BIT
334
+ vpand ymm5, ymm1, ymm6
335
+ vpsrlw ymm1, ymm1, BYTE_BIT
336
+ vpaddw ymm0, ymm0, ymm4
337
+ vpaddw ymm1, ymm1, ymm5
338
+
339
+ vpand ymm4, ymm2, ymm6
340
+ vpsrlw ymm2, ymm2, BYTE_BIT
341
+ vpand ymm5, ymm3, ymm6
342
+ vpsrlw ymm3, ymm3, BYTE_BIT
343
+ vpaddw ymm2, ymm2, ymm4
344
+ vpaddw ymm3, ymm3, ymm5
345
+
346
+ vpaddw ymm0, ymm0, ymm1
347
+ vpaddw ymm2, ymm2, ymm3
348
+ vpaddw ymm0, ymm0, ymm7
349
+ vpaddw ymm2, ymm2, ymm7
350
+ vpsrlw ymm0, ymm0, 2
351
+ vpsrlw ymm2, ymm2, 2
352
+
353
+ vpackuswb ymm0, ymm0, ymm2
354
+ vpermq ymm0, ymm0, 0xd8
355
+
356
+ vmovdqu YMMWORD [edi+0*SIZEOF_YMMWORD], ymm0
357
+
358
+ sub ecx, byte SIZEOF_YMMWORD ; outcol
359
+ add edx, byte 2*SIZEOF_YMMWORD ; inptr0
360
+ add esi, byte 2*SIZEOF_YMMWORD ; inptr1
361
+ add edi, byte 1*SIZEOF_YMMWORD ; outptr
362
+ cmp ecx, byte SIZEOF_YMMWORD
363
+ jae near .columnloop
364
+ test ecx, ecx
365
+ jnz near .columnloop_r24
366
+
367
+ pop esi
368
+ pop edi
369
+ pop ecx
370
+
371
+ add esi, byte 2*SIZEOF_JSAMPROW ; input_data
372
+ add edi, byte 1*SIZEOF_JSAMPROW ; output_data
373
+ dec eax ; rowctr
374
+ jg near .rowloop
375
+
376
+ .return:
377
+ vzeroupper
378
+ pop edi
379
+ pop esi
380
+ ; pop edx ; need not be preserved
381
+ ; pop ecx ; need not be preserved
382
+ ; pop ebx ; unused
383
+ pop ebp
384
+ ret
385
+
386
+ ; For some reason, the OS X linker does not honor the request to align the
387
+ ; segment unless we do this.
388
+ align 32
@@ -0,0 +1,324 @@
1
+ ;
2
+ ; jcsample.asm - downsampling (MMX)
3
+ ;
4
+ ; Copyright 2009 Pierre Ossman <ossman@cendio.se> for Cendio AB
5
+ ; Copyright (C) 2016, D. R. Commander.
6
+ ;
7
+ ; Based on the x86 SIMD extension for IJG JPEG library
8
+ ; Copyright (C) 1999-2006, MIYASAKA Masaru.
9
+ ; For conditions of distribution and use, see copyright notice in jsimdext.inc
10
+ ;
11
+ ; This file should be assembled with NASM (Netwide Assembler),
12
+ ; can *not* be assembled with Microsoft's MASM or any compatible
13
+ ; assembler (including Borland's Turbo Assembler).
14
+ ; NASM is available from http://nasm.sourceforge.net/ or
15
+ ; http://sourceforge.net/project/showfiles.php?group_id=6208
16
+
17
+ %include "jsimdext.inc"
18
+
19
+ ; --------------------------------------------------------------------------
20
+ SECTION SEG_TEXT
21
+ BITS 32
22
+ ;
23
+ ; Downsample pixel values of a single component.
24
+ ; This version handles the common case of 2:1 horizontal and 1:1 vertical,
25
+ ; without smoothing.
26
+ ;
27
+ ; GLOBAL(void)
28
+ ; jsimd_h2v1_downsample_mmx(JDIMENSION image_width, int max_v_samp_factor,
29
+ ; JDIMENSION v_samp_factor,
30
+ ; JDIMENSION width_in_blocks, JSAMPARRAY input_data,
31
+ ; JSAMPARRAY output_data);
32
+ ;
33
+
34
+ %define img_width(b) (b) + 8 ; JDIMENSION image_width
35
+ %define max_v_samp(b) (b) + 12 ; int max_v_samp_factor
36
+ %define v_samp(b) (b) + 16 ; JDIMENSION v_samp_factor
37
+ %define width_blks(b) (b) + 20 ; JDIMENSION width_in_blocks
38
+ %define input_data(b) (b) + 24 ; JSAMPARRAY input_data
39
+ %define output_data(b) (b) + 28 ; JSAMPARRAY output_data
40
+
41
+ align 32
42
+ GLOBAL_FUNCTION(jsimd_h2v1_downsample_mmx)
43
+
44
+ EXTN(jsimd_h2v1_downsample_mmx):
45
+ push ebp
46
+ mov ebp, esp
47
+ ; push ebx ; unused
48
+ ; push ecx ; need not be preserved
49
+ ; push edx ; need not be preserved
50
+ push esi
51
+ push edi
52
+
53
+ mov ecx, JDIMENSION [width_blks(ebp)]
54
+ shl ecx, 3 ; imul ecx,DCTSIZE (ecx = output_cols)
55
+ jz near .return
56
+
57
+ mov edx, JDIMENSION [img_width(ebp)]
58
+
59
+ ; -- expand_right_edge
60
+
61
+ push ecx
62
+ shl ecx, 1 ; output_cols * 2
63
+ sub ecx, edx
64
+ jle short .expand_end
65
+
66
+ mov eax, INT [max_v_samp(ebp)]
67
+ test eax, eax
68
+ jle short .expand_end
69
+
70
+ cld
71
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
72
+ alignx 16, 7
73
+ .expandloop:
74
+ push eax
75
+ push ecx
76
+
77
+ mov edi, JSAMPROW [esi]
78
+ add edi, edx
79
+ mov al, JSAMPLE [edi-1]
80
+
81
+ rep stosb
82
+
83
+ pop ecx
84
+ pop eax
85
+
86
+ add esi, byte SIZEOF_JSAMPROW
87
+ dec eax
88
+ jg short .expandloop
89
+
90
+ .expand_end:
91
+ pop ecx ; output_cols
92
+
93
+ ; -- h2v1_downsample
94
+
95
+ mov eax, JDIMENSION [v_samp(ebp)] ; rowctr
96
+ test eax, eax
97
+ jle near .return
98
+
99
+ mov edx, 0x00010000 ; bias pattern
100
+ movd mm7, edx
101
+ pcmpeqw mm6, mm6
102
+ punpckldq mm7, mm7 ; mm7={0, 1, 0, 1}
103
+ psrlw mm6, BYTE_BIT ; mm6={0xFF 0x00 0xFF 0x00 ..}
104
+
105
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
106
+ mov edi, JSAMPARRAY [output_data(ebp)] ; output_data
107
+ alignx 16, 7
108
+ .rowloop:
109
+ push ecx
110
+ push edi
111
+ push esi
112
+
113
+ mov esi, JSAMPROW [esi] ; inptr
114
+ mov edi, JSAMPROW [edi] ; outptr
115
+ alignx 16, 7
116
+ .columnloop:
117
+
118
+ movq mm0, MMWORD [esi+0*SIZEOF_MMWORD]
119
+ movq mm1, MMWORD [esi+1*SIZEOF_MMWORD]
120
+ movq mm2, mm0
121
+ movq mm3, mm1
122
+
123
+ pand mm0, mm6
124
+ psrlw mm2, BYTE_BIT
125
+ pand mm1, mm6
126
+ psrlw mm3, BYTE_BIT
127
+
128
+ paddw mm0, mm2
129
+ paddw mm1, mm3
130
+ paddw mm0, mm7
131
+ paddw mm1, mm7
132
+ psrlw mm0, 1
133
+ psrlw mm1, 1
134
+
135
+ packuswb mm0, mm1
136
+
137
+ movq MMWORD [edi+0*SIZEOF_MMWORD], mm0
138
+
139
+ add esi, byte 2*SIZEOF_MMWORD ; inptr
140
+ add edi, byte 1*SIZEOF_MMWORD ; outptr
141
+ sub ecx, byte SIZEOF_MMWORD ; outcol
142
+ jnz short .columnloop
143
+
144
+ pop esi
145
+ pop edi
146
+ pop ecx
147
+
148
+ add esi, byte SIZEOF_JSAMPROW ; input_data
149
+ add edi, byte SIZEOF_JSAMPROW ; output_data
150
+ dec eax ; rowctr
151
+ jg short .rowloop
152
+
153
+ emms ; empty MMX state
154
+
155
+ .return:
156
+ pop edi
157
+ pop esi
158
+ ; pop edx ; need not be preserved
159
+ ; pop ecx ; need not be preserved
160
+ ; pop ebx ; unused
161
+ pop ebp
162
+ ret
163
+
164
+ ; --------------------------------------------------------------------------
165
+ ;
166
+ ; Downsample pixel values of a single component.
167
+ ; This version handles the standard case of 2:1 horizontal and 2:1 vertical,
168
+ ; without smoothing.
169
+ ;
170
+ ; GLOBAL(void)
171
+ ; jsimd_h2v2_downsample_mmx(JDIMENSION image_width, int max_v_samp_factor,
172
+ ; JDIMENSION v_samp_factor,
173
+ ; JDIMENSION width_in_blocks, JSAMPARRAY input_data,
174
+ ; JSAMPARRAY output_data);
175
+ ;
176
+
177
+ %define img_width(b) (b) + 8 ; JDIMENSION image_width
178
+ %define max_v_samp(b) (b) + 12 ; int max_v_samp_factor
179
+ %define v_samp(b) (b) + 16 ; JDIMENSION v_samp_factor
180
+ %define width_blks(b) (b) + 20 ; JDIMENSION width_in_blocks
181
+ %define input_data(b) (b) + 24 ; JSAMPARRAY input_data
182
+ %define output_data(b) (b) + 28 ; JSAMPARRAY output_data
183
+
184
+ align 32
185
+ GLOBAL_FUNCTION(jsimd_h2v2_downsample_mmx)
186
+
187
+ EXTN(jsimd_h2v2_downsample_mmx):
188
+ push ebp
189
+ mov ebp, esp
190
+ ; push ebx ; unused
191
+ ; push ecx ; need not be preserved
192
+ ; push edx ; need not be preserved
193
+ push esi
194
+ push edi
195
+
196
+ mov ecx, JDIMENSION [width_blks(ebp)]
197
+ shl ecx, 3 ; imul ecx,DCTSIZE (ecx = output_cols)
198
+ jz near .return
199
+
200
+ mov edx, JDIMENSION [img_width(ebp)]
201
+
202
+ ; -- expand_right_edge
203
+
204
+ push ecx
205
+ shl ecx, 1 ; output_cols * 2
206
+ sub ecx, edx
207
+ jle short .expand_end
208
+
209
+ mov eax, INT [max_v_samp(ebp)]
210
+ test eax, eax
211
+ jle short .expand_end
212
+
213
+ cld
214
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
215
+ alignx 16, 7
216
+ .expandloop:
217
+ push eax
218
+ push ecx
219
+
220
+ mov edi, JSAMPROW [esi]
221
+ add edi, edx
222
+ mov al, JSAMPLE [edi-1]
223
+
224
+ rep stosb
225
+
226
+ pop ecx
227
+ pop eax
228
+
229
+ add esi, byte SIZEOF_JSAMPROW
230
+ dec eax
231
+ jg short .expandloop
232
+
233
+ .expand_end:
234
+ pop ecx ; output_cols
235
+
236
+ ; -- h2v2_downsample
237
+
238
+ mov eax, JDIMENSION [v_samp(ebp)] ; rowctr
239
+ test eax, eax
240
+ jle near .return
241
+
242
+ mov edx, 0x00020001 ; bias pattern
243
+ movd mm7, edx
244
+ pcmpeqw mm6, mm6
245
+ punpckldq mm7, mm7 ; mm7={1, 2, 1, 2}
246
+ psrlw mm6, BYTE_BIT ; mm6={0xFF 0x00 0xFF 0x00 ..}
247
+
248
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
249
+ mov edi, JSAMPARRAY [output_data(ebp)] ; output_data
250
+ alignx 16, 7
251
+ .rowloop:
252
+ push ecx
253
+ push edi
254
+ push esi
255
+
256
+ mov edx, JSAMPROW [esi+0*SIZEOF_JSAMPROW] ; inptr0
257
+ mov esi, JSAMPROW [esi+1*SIZEOF_JSAMPROW] ; inptr1
258
+ mov edi, JSAMPROW [edi] ; outptr
259
+ alignx 16, 7
260
+ .columnloop:
261
+
262
+ movq mm0, MMWORD [edx+0*SIZEOF_MMWORD]
263
+ movq mm1, MMWORD [esi+0*SIZEOF_MMWORD]
264
+ movq mm2, MMWORD [edx+1*SIZEOF_MMWORD]
265
+ movq mm3, MMWORD [esi+1*SIZEOF_MMWORD]
266
+
267
+ movq mm4, mm0
268
+ movq mm5, mm1
269
+ pand mm0, mm6
270
+ psrlw mm4, BYTE_BIT
271
+ pand mm1, mm6
272
+ psrlw mm5, BYTE_BIT
273
+ paddw mm0, mm4
274
+ paddw mm1, mm5
275
+
276
+ movq mm4, mm2
277
+ movq mm5, mm3
278
+ pand mm2, mm6
279
+ psrlw mm4, BYTE_BIT
280
+ pand mm3, mm6
281
+ psrlw mm5, BYTE_BIT
282
+ paddw mm2, mm4
283
+ paddw mm3, mm5
284
+
285
+ paddw mm0, mm1
286
+ paddw mm2, mm3
287
+ paddw mm0, mm7
288
+ paddw mm2, mm7
289
+ psrlw mm0, 2
290
+ psrlw mm2, 2
291
+
292
+ packuswb mm0, mm2
293
+
294
+ movq MMWORD [edi+0*SIZEOF_MMWORD], mm0
295
+
296
+ add edx, byte 2*SIZEOF_MMWORD ; inptr0
297
+ add esi, byte 2*SIZEOF_MMWORD ; inptr1
298
+ add edi, byte 1*SIZEOF_MMWORD ; outptr
299
+ sub ecx, byte SIZEOF_MMWORD ; outcol
300
+ jnz near .columnloop
301
+
302
+ pop esi
303
+ pop edi
304
+ pop ecx
305
+
306
+ add esi, byte 2*SIZEOF_JSAMPROW ; input_data
307
+ add edi, byte 1*SIZEOF_JSAMPROW ; output_data
308
+ dec eax ; rowctr
309
+ jg near .rowloop
310
+
311
+ emms ; empty MMX state
312
+
313
+ .return:
314
+ pop edi
315
+ pop esi
316
+ ; pop edx ; need not be preserved
317
+ ; pop ecx ; need not be preserved
318
+ ; pop ebx ; unused
319
+ pop ebp
320
+ ret
321
+
322
+ ; For some reason, the OS X linker does not honor the request to align the
323
+ ; segment unless we do this.
324
+ align 32