epeg 1.0

Sign up to get free protection for your applications and to get access to all the features.
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,1253 @@
1
+ /*
2
+ * jsimd_i386.c
3
+ *
4
+ * Copyright 2009 Pierre Ossman <ossman@cendio.se> for Cendio AB
5
+ * Copyright (C) 2009-2011, 2013-2014, 2016, 2018, D. R. Commander.
6
+ * Copyright (C) 2015-2016, 2018, Matthieu Darbois.
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 contains the interface between the "normal" portions
13
+ * of the library and the SIMD implementations when running on a
14
+ * 32-bit x86 architecture.
15
+ */
16
+
17
+ #define JPEG_INTERNALS
18
+ #include "../../jinclude.h"
19
+ #include "../../jpeglib.h"
20
+ #include "../../jsimd.h"
21
+ #include "../../jdct.h"
22
+ #include "../../jsimddct.h"
23
+ #include "../jsimd.h"
24
+ #include "jconfigint.h"
25
+
26
+ /*
27
+ * In the PIC cases, we have no guarantee that constants will keep
28
+ * their alignment. This macro allows us to verify it at runtime.
29
+ */
30
+ #define IS_ALIGNED(ptr, order) (((unsigned)ptr & ((1 << order) - 1)) == 0)
31
+
32
+ #define IS_ALIGNED_SSE(ptr) (IS_ALIGNED(ptr, 4)) /* 16 byte alignment */
33
+ #define IS_ALIGNED_AVX(ptr) (IS_ALIGNED(ptr, 5)) /* 32 byte alignment */
34
+
35
+ static unsigned int simd_support = (unsigned int)(~0);
36
+ static unsigned int simd_huffman = 1;
37
+
38
+ /*
39
+ * Check what SIMD accelerations are supported.
40
+ *
41
+ * FIXME: This code is racy under a multi-threaded environment.
42
+ */
43
+ LOCAL(void)
44
+ init_simd(void)
45
+ {
46
+ #ifndef NO_GETENV
47
+ char *env = NULL;
48
+ #endif
49
+
50
+ if (simd_support != ~0U)
51
+ return;
52
+
53
+ simd_support = jpeg_simd_cpu_support();
54
+
55
+ #ifndef NO_GETENV
56
+ /* Force different settings through environment variables */
57
+ env = getenv("JSIMD_FORCEMMX");
58
+ if ((env != NULL) && (strcmp(env, "1") == 0))
59
+ simd_support &= JSIMD_MMX;
60
+ env = getenv("JSIMD_FORCE3DNOW");
61
+ if ((env != NULL) && (strcmp(env, "1") == 0))
62
+ simd_support &= JSIMD_3DNOW | JSIMD_MMX;
63
+ env = getenv("JSIMD_FORCESSE");
64
+ if ((env != NULL) && (strcmp(env, "1") == 0))
65
+ simd_support &= JSIMD_SSE | JSIMD_MMX;
66
+ env = getenv("JSIMD_FORCESSE2");
67
+ if ((env != NULL) && (strcmp(env, "1") == 0))
68
+ simd_support &= JSIMD_SSE2;
69
+ env = getenv("JSIMD_FORCEAVX2");
70
+ if ((env != NULL) && (strcmp(env, "1") == 0))
71
+ simd_support &= JSIMD_AVX2;
72
+ env = getenv("JSIMD_FORCENONE");
73
+ if ((env != NULL) && (strcmp(env, "1") == 0))
74
+ simd_support = 0;
75
+ env = getenv("JSIMD_NOHUFFENC");
76
+ if ((env != NULL) && (strcmp(env, "1") == 0))
77
+ simd_huffman = 0;
78
+ #endif
79
+ }
80
+
81
+ GLOBAL(int)
82
+ jsimd_can_rgb_ycc(void)
83
+ {
84
+ init_simd();
85
+
86
+ /* The code is optimised for these values only */
87
+ if (BITS_IN_JSAMPLE != 8)
88
+ return 0;
89
+ if (sizeof(JDIMENSION) != 4)
90
+ return 0;
91
+ if ((RGB_PIXELSIZE != 3) && (RGB_PIXELSIZE != 4))
92
+ return 0;
93
+
94
+ if ((simd_support & JSIMD_AVX2) &&
95
+ IS_ALIGNED_AVX(jconst_rgb_ycc_convert_avx2))
96
+ return 1;
97
+ if ((simd_support & JSIMD_SSE2) &&
98
+ IS_ALIGNED_SSE(jconst_rgb_ycc_convert_sse2))
99
+ return 1;
100
+ if (simd_support & JSIMD_MMX)
101
+ return 1;
102
+
103
+ return 0;
104
+ }
105
+
106
+ GLOBAL(int)
107
+ jsimd_can_rgb_gray(void)
108
+ {
109
+ init_simd();
110
+
111
+ /* The code is optimised for these values only */
112
+ if (BITS_IN_JSAMPLE != 8)
113
+ return 0;
114
+ if (sizeof(JDIMENSION) != 4)
115
+ return 0;
116
+ if ((RGB_PIXELSIZE != 3) && (RGB_PIXELSIZE != 4))
117
+ return 0;
118
+
119
+ if ((simd_support & JSIMD_AVX2) &&
120
+ IS_ALIGNED_AVX(jconst_rgb_gray_convert_avx2))
121
+ return 1;
122
+ if ((simd_support & JSIMD_SSE2) &&
123
+ IS_ALIGNED_SSE(jconst_rgb_gray_convert_sse2))
124
+ return 1;
125
+ if (simd_support & JSIMD_MMX)
126
+ return 1;
127
+
128
+ return 0;
129
+ }
130
+
131
+ GLOBAL(int)
132
+ jsimd_can_ycc_rgb(void)
133
+ {
134
+ init_simd();
135
+
136
+ /* The code is optimised for these values only */
137
+ if (BITS_IN_JSAMPLE != 8)
138
+ return 0;
139
+ if (sizeof(JDIMENSION) != 4)
140
+ return 0;
141
+ if ((RGB_PIXELSIZE != 3) && (RGB_PIXELSIZE != 4))
142
+ return 0;
143
+
144
+ if ((simd_support & JSIMD_AVX2) &&
145
+ IS_ALIGNED_AVX(jconst_ycc_rgb_convert_avx2))
146
+ return 1;
147
+ if ((simd_support & JSIMD_SSE2) &&
148
+ IS_ALIGNED_SSE(jconst_ycc_rgb_convert_sse2))
149
+ return 1;
150
+ if (simd_support & JSIMD_MMX)
151
+ return 1;
152
+
153
+ return 0;
154
+ }
155
+
156
+ GLOBAL(int)
157
+ jsimd_can_ycc_rgb565(void)
158
+ {
159
+ return 0;
160
+ }
161
+
162
+ GLOBAL(void)
163
+ jsimd_rgb_ycc_convert(j_compress_ptr cinfo, JSAMPARRAY input_buf,
164
+ JSAMPIMAGE output_buf, JDIMENSION output_row,
165
+ int num_rows)
166
+ {
167
+ void (*avx2fct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
168
+ void (*sse2fct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
169
+ void (*mmxfct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
170
+
171
+ switch (cinfo->in_color_space) {
172
+ case JCS_EXT_RGB:
173
+ avx2fct = jsimd_extrgb_ycc_convert_avx2;
174
+ sse2fct = jsimd_extrgb_ycc_convert_sse2;
175
+ mmxfct = jsimd_extrgb_ycc_convert_mmx;
176
+ break;
177
+ case JCS_EXT_RGBX:
178
+ case JCS_EXT_RGBA:
179
+ avx2fct = jsimd_extrgbx_ycc_convert_avx2;
180
+ sse2fct = jsimd_extrgbx_ycc_convert_sse2;
181
+ mmxfct = jsimd_extrgbx_ycc_convert_mmx;
182
+ break;
183
+ case JCS_EXT_BGR:
184
+ avx2fct = jsimd_extbgr_ycc_convert_avx2;
185
+ sse2fct = jsimd_extbgr_ycc_convert_sse2;
186
+ mmxfct = jsimd_extbgr_ycc_convert_mmx;
187
+ break;
188
+ case JCS_EXT_BGRX:
189
+ case JCS_EXT_BGRA:
190
+ avx2fct = jsimd_extbgrx_ycc_convert_avx2;
191
+ sse2fct = jsimd_extbgrx_ycc_convert_sse2;
192
+ mmxfct = jsimd_extbgrx_ycc_convert_mmx;
193
+ break;
194
+ case JCS_EXT_XBGR:
195
+ case JCS_EXT_ABGR:
196
+ avx2fct = jsimd_extxbgr_ycc_convert_avx2;
197
+ sse2fct = jsimd_extxbgr_ycc_convert_sse2;
198
+ mmxfct = jsimd_extxbgr_ycc_convert_mmx;
199
+ break;
200
+ case JCS_EXT_XRGB:
201
+ case JCS_EXT_ARGB:
202
+ avx2fct = jsimd_extxrgb_ycc_convert_avx2;
203
+ sse2fct = jsimd_extxrgb_ycc_convert_sse2;
204
+ mmxfct = jsimd_extxrgb_ycc_convert_mmx;
205
+ break;
206
+ default:
207
+ avx2fct = jsimd_rgb_ycc_convert_avx2;
208
+ sse2fct = jsimd_rgb_ycc_convert_sse2;
209
+ mmxfct = jsimd_rgb_ycc_convert_mmx;
210
+ break;
211
+ }
212
+
213
+ if (simd_support & JSIMD_AVX2)
214
+ avx2fct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
215
+ else if (simd_support & JSIMD_SSE2)
216
+ sse2fct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
217
+ else
218
+ mmxfct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
219
+ }
220
+
221
+ GLOBAL(void)
222
+ jsimd_rgb_gray_convert(j_compress_ptr cinfo, JSAMPARRAY input_buf,
223
+ JSAMPIMAGE output_buf, JDIMENSION output_row,
224
+ int num_rows)
225
+ {
226
+ void (*avx2fct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
227
+ void (*sse2fct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
228
+ void (*mmxfct) (JDIMENSION, JSAMPARRAY, JSAMPIMAGE, JDIMENSION, int);
229
+
230
+ switch (cinfo->in_color_space) {
231
+ case JCS_EXT_RGB:
232
+ avx2fct = jsimd_extrgb_gray_convert_avx2;
233
+ sse2fct = jsimd_extrgb_gray_convert_sse2;
234
+ mmxfct = jsimd_extrgb_gray_convert_mmx;
235
+ break;
236
+ case JCS_EXT_RGBX:
237
+ case JCS_EXT_RGBA:
238
+ avx2fct = jsimd_extrgbx_gray_convert_avx2;
239
+ sse2fct = jsimd_extrgbx_gray_convert_sse2;
240
+ mmxfct = jsimd_extrgbx_gray_convert_mmx;
241
+ break;
242
+ case JCS_EXT_BGR:
243
+ avx2fct = jsimd_extbgr_gray_convert_avx2;
244
+ sse2fct = jsimd_extbgr_gray_convert_sse2;
245
+ mmxfct = jsimd_extbgr_gray_convert_mmx;
246
+ break;
247
+ case JCS_EXT_BGRX:
248
+ case JCS_EXT_BGRA:
249
+ avx2fct = jsimd_extbgrx_gray_convert_avx2;
250
+ sse2fct = jsimd_extbgrx_gray_convert_sse2;
251
+ mmxfct = jsimd_extbgrx_gray_convert_mmx;
252
+ break;
253
+ case JCS_EXT_XBGR:
254
+ case JCS_EXT_ABGR:
255
+ avx2fct = jsimd_extxbgr_gray_convert_avx2;
256
+ sse2fct = jsimd_extxbgr_gray_convert_sse2;
257
+ mmxfct = jsimd_extxbgr_gray_convert_mmx;
258
+ break;
259
+ case JCS_EXT_XRGB:
260
+ case JCS_EXT_ARGB:
261
+ avx2fct = jsimd_extxrgb_gray_convert_avx2;
262
+ sse2fct = jsimd_extxrgb_gray_convert_sse2;
263
+ mmxfct = jsimd_extxrgb_gray_convert_mmx;
264
+ break;
265
+ default:
266
+ avx2fct = jsimd_rgb_gray_convert_avx2;
267
+ sse2fct = jsimd_rgb_gray_convert_sse2;
268
+ mmxfct = jsimd_rgb_gray_convert_mmx;
269
+ break;
270
+ }
271
+
272
+ if (simd_support & JSIMD_AVX2)
273
+ avx2fct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
274
+ else if (simd_support & JSIMD_SSE2)
275
+ sse2fct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
276
+ else
277
+ mmxfct(cinfo->image_width, input_buf, output_buf, output_row, num_rows);
278
+ }
279
+
280
+ GLOBAL(void)
281
+ jsimd_ycc_rgb_convert(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
282
+ JDIMENSION input_row, JSAMPARRAY output_buf,
283
+ int num_rows)
284
+ {
285
+ void (*avx2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY, int);
286
+ void (*sse2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY, int);
287
+ void (*mmxfct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY, int);
288
+
289
+ switch (cinfo->out_color_space) {
290
+ case JCS_EXT_RGB:
291
+ avx2fct = jsimd_ycc_extrgb_convert_avx2;
292
+ sse2fct = jsimd_ycc_extrgb_convert_sse2;
293
+ mmxfct = jsimd_ycc_extrgb_convert_mmx;
294
+ break;
295
+ case JCS_EXT_RGBX:
296
+ case JCS_EXT_RGBA:
297
+ avx2fct = jsimd_ycc_extrgbx_convert_avx2;
298
+ sse2fct = jsimd_ycc_extrgbx_convert_sse2;
299
+ mmxfct = jsimd_ycc_extrgbx_convert_mmx;
300
+ break;
301
+ case JCS_EXT_BGR:
302
+ avx2fct = jsimd_ycc_extbgr_convert_avx2;
303
+ sse2fct = jsimd_ycc_extbgr_convert_sse2;
304
+ mmxfct = jsimd_ycc_extbgr_convert_mmx;
305
+ break;
306
+ case JCS_EXT_BGRX:
307
+ case JCS_EXT_BGRA:
308
+ avx2fct = jsimd_ycc_extbgrx_convert_avx2;
309
+ sse2fct = jsimd_ycc_extbgrx_convert_sse2;
310
+ mmxfct = jsimd_ycc_extbgrx_convert_mmx;
311
+ break;
312
+ case JCS_EXT_XBGR:
313
+ case JCS_EXT_ABGR:
314
+ avx2fct = jsimd_ycc_extxbgr_convert_avx2;
315
+ sse2fct = jsimd_ycc_extxbgr_convert_sse2;
316
+ mmxfct = jsimd_ycc_extxbgr_convert_mmx;
317
+ break;
318
+ case JCS_EXT_XRGB:
319
+ case JCS_EXT_ARGB:
320
+ avx2fct = jsimd_ycc_extxrgb_convert_avx2;
321
+ sse2fct = jsimd_ycc_extxrgb_convert_sse2;
322
+ mmxfct = jsimd_ycc_extxrgb_convert_mmx;
323
+ break;
324
+ default:
325
+ avx2fct = jsimd_ycc_rgb_convert_avx2;
326
+ sse2fct = jsimd_ycc_rgb_convert_sse2;
327
+ mmxfct = jsimd_ycc_rgb_convert_mmx;
328
+ break;
329
+ }
330
+
331
+ if (simd_support & JSIMD_AVX2)
332
+ avx2fct(cinfo->output_width, input_buf, input_row, output_buf, num_rows);
333
+ else if (simd_support & JSIMD_SSE2)
334
+ sse2fct(cinfo->output_width, input_buf, input_row, output_buf, num_rows);
335
+ else
336
+ mmxfct(cinfo->output_width, input_buf, input_row, output_buf, num_rows);
337
+ }
338
+
339
+ GLOBAL(void)
340
+ jsimd_ycc_rgb565_convert(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
341
+ JDIMENSION input_row, JSAMPARRAY output_buf,
342
+ int num_rows)
343
+ {
344
+ }
345
+
346
+ GLOBAL(int)
347
+ jsimd_can_h2v2_downsample(void)
348
+ {
349
+ init_simd();
350
+
351
+ /* The code is optimised for these values only */
352
+ if (BITS_IN_JSAMPLE != 8)
353
+ return 0;
354
+ if (sizeof(JDIMENSION) != 4)
355
+ return 0;
356
+
357
+ if (simd_support & JSIMD_AVX2)
358
+ return 1;
359
+ if (simd_support & JSIMD_SSE2)
360
+ return 1;
361
+ if (simd_support & JSIMD_MMX)
362
+ return 1;
363
+
364
+ return 0;
365
+ }
366
+
367
+ GLOBAL(int)
368
+ jsimd_can_h2v1_downsample(void)
369
+ {
370
+ init_simd();
371
+
372
+ /* The code is optimised for these values only */
373
+ if (BITS_IN_JSAMPLE != 8)
374
+ return 0;
375
+ if (sizeof(JDIMENSION) != 4)
376
+ return 0;
377
+
378
+ if (simd_support & JSIMD_AVX2)
379
+ return 1;
380
+ if (simd_support & JSIMD_SSE2)
381
+ return 1;
382
+ if (simd_support & JSIMD_MMX)
383
+ return 1;
384
+
385
+ return 0;
386
+ }
387
+
388
+ GLOBAL(void)
389
+ jsimd_h2v2_downsample(j_compress_ptr cinfo, jpeg_component_info *compptr,
390
+ JSAMPARRAY input_data, JSAMPARRAY output_data)
391
+ {
392
+ if (simd_support & JSIMD_AVX2)
393
+ jsimd_h2v2_downsample_avx2(cinfo->image_width, cinfo->max_v_samp_factor,
394
+ compptr->v_samp_factor,
395
+ compptr->width_in_blocks, input_data,
396
+ output_data);
397
+ else if (simd_support & JSIMD_SSE2)
398
+ jsimd_h2v2_downsample_sse2(cinfo->image_width, cinfo->max_v_samp_factor,
399
+ compptr->v_samp_factor,
400
+ compptr->width_in_blocks, input_data,
401
+ output_data);
402
+ else
403
+ jsimd_h2v2_downsample_mmx(cinfo->image_width, cinfo->max_v_samp_factor,
404
+ compptr->v_samp_factor, compptr->width_in_blocks,
405
+ input_data, output_data);
406
+ }
407
+
408
+ GLOBAL(void)
409
+ jsimd_h2v1_downsample(j_compress_ptr cinfo, jpeg_component_info *compptr,
410
+ JSAMPARRAY input_data, JSAMPARRAY output_data)
411
+ {
412
+ if (simd_support & JSIMD_AVX2)
413
+ jsimd_h2v1_downsample_avx2(cinfo->image_width, cinfo->max_v_samp_factor,
414
+ compptr->v_samp_factor,
415
+ compptr->width_in_blocks, input_data,
416
+ output_data);
417
+ else if (simd_support & JSIMD_SSE2)
418
+ jsimd_h2v1_downsample_sse2(cinfo->image_width, cinfo->max_v_samp_factor,
419
+ compptr->v_samp_factor,
420
+ compptr->width_in_blocks, input_data,
421
+ output_data);
422
+ else
423
+ jsimd_h2v1_downsample_mmx(cinfo->image_width, cinfo->max_v_samp_factor,
424
+ compptr->v_samp_factor, compptr->width_in_blocks,
425
+ input_data, output_data);
426
+ }
427
+
428
+ GLOBAL(int)
429
+ jsimd_can_h2v2_upsample(void)
430
+ {
431
+ init_simd();
432
+
433
+ /* The code is optimised for these values only */
434
+ if (BITS_IN_JSAMPLE != 8)
435
+ return 0;
436
+ if (sizeof(JDIMENSION) != 4)
437
+ return 0;
438
+
439
+ if (simd_support & JSIMD_AVX2)
440
+ return 1;
441
+ if (simd_support & JSIMD_SSE2)
442
+ return 1;
443
+ if (simd_support & JSIMD_MMX)
444
+ return 1;
445
+
446
+ return 0;
447
+ }
448
+
449
+ GLOBAL(int)
450
+ jsimd_can_h2v1_upsample(void)
451
+ {
452
+ init_simd();
453
+
454
+ /* The code is optimised for these values only */
455
+ if (BITS_IN_JSAMPLE != 8)
456
+ return 0;
457
+ if (sizeof(JDIMENSION) != 4)
458
+ return 0;
459
+
460
+ if (simd_support & JSIMD_AVX2)
461
+ return 1;
462
+ if (simd_support & JSIMD_SSE2)
463
+ return 1;
464
+ if (simd_support & JSIMD_MMX)
465
+ return 1;
466
+
467
+ return 0;
468
+ }
469
+
470
+ GLOBAL(void)
471
+ jsimd_h2v2_upsample(j_decompress_ptr cinfo, jpeg_component_info *compptr,
472
+ JSAMPARRAY input_data, JSAMPARRAY *output_data_ptr)
473
+ {
474
+ if (simd_support & JSIMD_AVX2)
475
+ jsimd_h2v2_upsample_avx2(cinfo->max_v_samp_factor, cinfo->output_width,
476
+ input_data, output_data_ptr);
477
+ else if (simd_support & JSIMD_SSE2)
478
+ jsimd_h2v2_upsample_sse2(cinfo->max_v_samp_factor, cinfo->output_width,
479
+ input_data, output_data_ptr);
480
+ else
481
+ jsimd_h2v2_upsample_mmx(cinfo->max_v_samp_factor, cinfo->output_width,
482
+ input_data, output_data_ptr);
483
+ }
484
+
485
+ GLOBAL(void)
486
+ jsimd_h2v1_upsample(j_decompress_ptr cinfo, jpeg_component_info *compptr,
487
+ JSAMPARRAY input_data, JSAMPARRAY *output_data_ptr)
488
+ {
489
+ if (simd_support & JSIMD_AVX2)
490
+ jsimd_h2v1_upsample_avx2(cinfo->max_v_samp_factor, cinfo->output_width,
491
+ input_data, output_data_ptr);
492
+ else if (simd_support & JSIMD_SSE2)
493
+ jsimd_h2v1_upsample_sse2(cinfo->max_v_samp_factor, cinfo->output_width,
494
+ input_data, output_data_ptr);
495
+ else
496
+ jsimd_h2v1_upsample_mmx(cinfo->max_v_samp_factor, cinfo->output_width,
497
+ input_data, output_data_ptr);
498
+ }
499
+
500
+ GLOBAL(int)
501
+ jsimd_can_h2v2_fancy_upsample(void)
502
+ {
503
+ init_simd();
504
+
505
+ /* The code is optimised for these values only */
506
+ if (BITS_IN_JSAMPLE != 8)
507
+ return 0;
508
+ if (sizeof(JDIMENSION) != 4)
509
+ return 0;
510
+
511
+ if ((simd_support & JSIMD_AVX2) &&
512
+ IS_ALIGNED_AVX(jconst_fancy_upsample_avx2))
513
+ return 1;
514
+ if ((simd_support & JSIMD_SSE2) &&
515
+ IS_ALIGNED_SSE(jconst_fancy_upsample_sse2))
516
+ return 1;
517
+ if (simd_support & JSIMD_MMX)
518
+ return 1;
519
+
520
+ return 0;
521
+ }
522
+
523
+ GLOBAL(int)
524
+ jsimd_can_h2v1_fancy_upsample(void)
525
+ {
526
+ init_simd();
527
+
528
+ /* The code is optimised for these values only */
529
+ if (BITS_IN_JSAMPLE != 8)
530
+ return 0;
531
+ if (sizeof(JDIMENSION) != 4)
532
+ return 0;
533
+
534
+ if ((simd_support & JSIMD_AVX2) &&
535
+ IS_ALIGNED_AVX(jconst_fancy_upsample_avx2))
536
+ return 1;
537
+ if ((simd_support & JSIMD_SSE2) &&
538
+ IS_ALIGNED_SSE(jconst_fancy_upsample_sse2))
539
+ return 1;
540
+ if (simd_support & JSIMD_MMX)
541
+ return 1;
542
+
543
+ return 0;
544
+ }
545
+
546
+ GLOBAL(void)
547
+ jsimd_h2v2_fancy_upsample(j_decompress_ptr cinfo, jpeg_component_info *compptr,
548
+ JSAMPARRAY input_data, JSAMPARRAY *output_data_ptr)
549
+ {
550
+ if (simd_support & JSIMD_AVX2)
551
+ jsimd_h2v2_fancy_upsample_avx2(cinfo->max_v_samp_factor,
552
+ compptr->downsampled_width, input_data,
553
+ output_data_ptr);
554
+ else if (simd_support & JSIMD_SSE2)
555
+ jsimd_h2v2_fancy_upsample_sse2(cinfo->max_v_samp_factor,
556
+ compptr->downsampled_width, input_data,
557
+ output_data_ptr);
558
+ else
559
+ jsimd_h2v2_fancy_upsample_mmx(cinfo->max_v_samp_factor,
560
+ compptr->downsampled_width, input_data,
561
+ output_data_ptr);
562
+ }
563
+
564
+ GLOBAL(void)
565
+ jsimd_h2v1_fancy_upsample(j_decompress_ptr cinfo, jpeg_component_info *compptr,
566
+ JSAMPARRAY input_data, JSAMPARRAY *output_data_ptr)
567
+ {
568
+ if (simd_support & JSIMD_AVX2)
569
+ jsimd_h2v1_fancy_upsample_avx2(cinfo->max_v_samp_factor,
570
+ compptr->downsampled_width, input_data,
571
+ output_data_ptr);
572
+ else if (simd_support & JSIMD_SSE2)
573
+ jsimd_h2v1_fancy_upsample_sse2(cinfo->max_v_samp_factor,
574
+ compptr->downsampled_width, input_data,
575
+ output_data_ptr);
576
+ else
577
+ jsimd_h2v1_fancy_upsample_mmx(cinfo->max_v_samp_factor,
578
+ compptr->downsampled_width, input_data,
579
+ output_data_ptr);
580
+ }
581
+
582
+ GLOBAL(int)
583
+ jsimd_can_h2v2_merged_upsample(void)
584
+ {
585
+ init_simd();
586
+
587
+ /* The code is optimised for these values only */
588
+ if (BITS_IN_JSAMPLE != 8)
589
+ return 0;
590
+ if (sizeof(JDIMENSION) != 4)
591
+ return 0;
592
+
593
+ if ((simd_support & JSIMD_AVX2) &&
594
+ IS_ALIGNED_AVX(jconst_merged_upsample_avx2))
595
+ return 1;
596
+ if ((simd_support & JSIMD_SSE2) &&
597
+ IS_ALIGNED_SSE(jconst_merged_upsample_sse2))
598
+ return 1;
599
+ if (simd_support & JSIMD_MMX)
600
+ return 1;
601
+
602
+ return 0;
603
+ }
604
+
605
+ GLOBAL(int)
606
+ jsimd_can_h2v1_merged_upsample(void)
607
+ {
608
+ init_simd();
609
+
610
+ /* The code is optimised for these values only */
611
+ if (BITS_IN_JSAMPLE != 8)
612
+ return 0;
613
+ if (sizeof(JDIMENSION) != 4)
614
+ return 0;
615
+
616
+ if ((simd_support & JSIMD_AVX2) &&
617
+ IS_ALIGNED_AVX(jconst_merged_upsample_avx2))
618
+ return 1;
619
+ if ((simd_support & JSIMD_SSE2) &&
620
+ IS_ALIGNED_SSE(jconst_merged_upsample_sse2))
621
+ return 1;
622
+ if (simd_support & JSIMD_MMX)
623
+ return 1;
624
+
625
+ return 0;
626
+ }
627
+
628
+ GLOBAL(void)
629
+ jsimd_h2v2_merged_upsample(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
630
+ JDIMENSION in_row_group_ctr, JSAMPARRAY output_buf)
631
+ {
632
+ void (*avx2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
633
+ void (*sse2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
634
+ void (*mmxfct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
635
+
636
+ switch (cinfo->out_color_space) {
637
+ case JCS_EXT_RGB:
638
+ avx2fct = jsimd_h2v2_extrgb_merged_upsample_avx2;
639
+ sse2fct = jsimd_h2v2_extrgb_merged_upsample_sse2;
640
+ mmxfct = jsimd_h2v2_extrgb_merged_upsample_mmx;
641
+ break;
642
+ case JCS_EXT_RGBX:
643
+ case JCS_EXT_RGBA:
644
+ avx2fct = jsimd_h2v2_extrgbx_merged_upsample_avx2;
645
+ sse2fct = jsimd_h2v2_extrgbx_merged_upsample_sse2;
646
+ mmxfct = jsimd_h2v2_extrgbx_merged_upsample_mmx;
647
+ break;
648
+ case JCS_EXT_BGR:
649
+ avx2fct = jsimd_h2v2_extbgr_merged_upsample_avx2;
650
+ sse2fct = jsimd_h2v2_extbgr_merged_upsample_sse2;
651
+ mmxfct = jsimd_h2v2_extbgr_merged_upsample_mmx;
652
+ break;
653
+ case JCS_EXT_BGRX:
654
+ case JCS_EXT_BGRA:
655
+ avx2fct = jsimd_h2v2_extbgrx_merged_upsample_avx2;
656
+ sse2fct = jsimd_h2v2_extbgrx_merged_upsample_sse2;
657
+ mmxfct = jsimd_h2v2_extbgrx_merged_upsample_mmx;
658
+ break;
659
+ case JCS_EXT_XBGR:
660
+ case JCS_EXT_ABGR:
661
+ avx2fct = jsimd_h2v2_extxbgr_merged_upsample_avx2;
662
+ sse2fct = jsimd_h2v2_extxbgr_merged_upsample_sse2;
663
+ mmxfct = jsimd_h2v2_extxbgr_merged_upsample_mmx;
664
+ break;
665
+ case JCS_EXT_XRGB:
666
+ case JCS_EXT_ARGB:
667
+ avx2fct = jsimd_h2v2_extxrgb_merged_upsample_avx2;
668
+ sse2fct = jsimd_h2v2_extxrgb_merged_upsample_sse2;
669
+ mmxfct = jsimd_h2v2_extxrgb_merged_upsample_mmx;
670
+ break;
671
+ default:
672
+ avx2fct = jsimd_h2v2_merged_upsample_avx2;
673
+ sse2fct = jsimd_h2v2_merged_upsample_sse2;
674
+ mmxfct = jsimd_h2v2_merged_upsample_mmx;
675
+ break;
676
+ }
677
+
678
+ if (simd_support & JSIMD_AVX2)
679
+ avx2fct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
680
+ else if (simd_support & JSIMD_SSE2)
681
+ sse2fct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
682
+ else
683
+ mmxfct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
684
+ }
685
+
686
+ GLOBAL(void)
687
+ jsimd_h2v1_merged_upsample(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
688
+ JDIMENSION in_row_group_ctr, JSAMPARRAY output_buf)
689
+ {
690
+ void (*avx2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
691
+ void (*sse2fct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
692
+ void (*mmxfct) (JDIMENSION, JSAMPIMAGE, JDIMENSION, JSAMPARRAY);
693
+
694
+ switch (cinfo->out_color_space) {
695
+ case JCS_EXT_RGB:
696
+ avx2fct = jsimd_h2v1_extrgb_merged_upsample_avx2;
697
+ sse2fct = jsimd_h2v1_extrgb_merged_upsample_sse2;
698
+ mmxfct = jsimd_h2v1_extrgb_merged_upsample_mmx;
699
+ break;
700
+ case JCS_EXT_RGBX:
701
+ case JCS_EXT_RGBA:
702
+ avx2fct = jsimd_h2v1_extrgbx_merged_upsample_avx2;
703
+ sse2fct = jsimd_h2v1_extrgbx_merged_upsample_sse2;
704
+ mmxfct = jsimd_h2v1_extrgbx_merged_upsample_mmx;
705
+ break;
706
+ case JCS_EXT_BGR:
707
+ avx2fct = jsimd_h2v1_extbgr_merged_upsample_avx2;
708
+ sse2fct = jsimd_h2v1_extbgr_merged_upsample_sse2;
709
+ mmxfct = jsimd_h2v1_extbgr_merged_upsample_mmx;
710
+ break;
711
+ case JCS_EXT_BGRX:
712
+ case JCS_EXT_BGRA:
713
+ avx2fct = jsimd_h2v1_extbgrx_merged_upsample_avx2;
714
+ sse2fct = jsimd_h2v1_extbgrx_merged_upsample_sse2;
715
+ mmxfct = jsimd_h2v1_extbgrx_merged_upsample_mmx;
716
+ break;
717
+ case JCS_EXT_XBGR:
718
+ case JCS_EXT_ABGR:
719
+ avx2fct = jsimd_h2v1_extxbgr_merged_upsample_avx2;
720
+ sse2fct = jsimd_h2v1_extxbgr_merged_upsample_sse2;
721
+ mmxfct = jsimd_h2v1_extxbgr_merged_upsample_mmx;
722
+ break;
723
+ case JCS_EXT_XRGB:
724
+ case JCS_EXT_ARGB:
725
+ avx2fct = jsimd_h2v1_extxrgb_merged_upsample_avx2;
726
+ sse2fct = jsimd_h2v1_extxrgb_merged_upsample_sse2;
727
+ mmxfct = jsimd_h2v1_extxrgb_merged_upsample_mmx;
728
+ break;
729
+ default:
730
+ avx2fct = jsimd_h2v1_merged_upsample_avx2;
731
+ sse2fct = jsimd_h2v1_merged_upsample_sse2;
732
+ mmxfct = jsimd_h2v1_merged_upsample_mmx;
733
+ break;
734
+ }
735
+
736
+ if (simd_support & JSIMD_AVX2)
737
+ avx2fct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
738
+ else if (simd_support & JSIMD_SSE2)
739
+ sse2fct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
740
+ else
741
+ mmxfct(cinfo->output_width, input_buf, in_row_group_ctr, output_buf);
742
+ }
743
+
744
+ GLOBAL(int)
745
+ jsimd_can_convsamp(void)
746
+ {
747
+ init_simd();
748
+
749
+ /* The code is optimised for these values only */
750
+ if (DCTSIZE != 8)
751
+ return 0;
752
+ if (BITS_IN_JSAMPLE != 8)
753
+ return 0;
754
+ if (sizeof(JDIMENSION) != 4)
755
+ return 0;
756
+ if (sizeof(DCTELEM) != 2)
757
+ return 0;
758
+
759
+ if (simd_support & JSIMD_AVX2)
760
+ return 1;
761
+ if (simd_support & JSIMD_SSE2)
762
+ return 1;
763
+ if (simd_support & JSIMD_MMX)
764
+ return 1;
765
+
766
+ return 0;
767
+ }
768
+
769
+ GLOBAL(int)
770
+ jsimd_can_convsamp_float(void)
771
+ {
772
+ init_simd();
773
+
774
+ /* The code is optimised for these values only */
775
+ if (DCTSIZE != 8)
776
+ return 0;
777
+ if (BITS_IN_JSAMPLE != 8)
778
+ return 0;
779
+ if (sizeof(JDIMENSION) != 4)
780
+ return 0;
781
+ if (sizeof(FAST_FLOAT) != 4)
782
+ return 0;
783
+
784
+ if (simd_support & JSIMD_SSE2)
785
+ return 1;
786
+ if (simd_support & JSIMD_SSE)
787
+ return 1;
788
+ if (simd_support & JSIMD_3DNOW)
789
+ return 1;
790
+
791
+ return 0;
792
+ }
793
+
794
+ GLOBAL(void)
795
+ jsimd_convsamp(JSAMPARRAY sample_data, JDIMENSION start_col,
796
+ DCTELEM *workspace)
797
+ {
798
+ if (simd_support & JSIMD_AVX2)
799
+ jsimd_convsamp_avx2(sample_data, start_col, workspace);
800
+ else if (simd_support & JSIMD_SSE2)
801
+ jsimd_convsamp_sse2(sample_data, start_col, workspace);
802
+ else
803
+ jsimd_convsamp_mmx(sample_data, start_col, workspace);
804
+ }
805
+
806
+ GLOBAL(void)
807
+ jsimd_convsamp_float(JSAMPARRAY sample_data, JDIMENSION start_col,
808
+ FAST_FLOAT *workspace)
809
+ {
810
+ if (simd_support & JSIMD_SSE2)
811
+ jsimd_convsamp_float_sse2(sample_data, start_col, workspace);
812
+ else if (simd_support & JSIMD_SSE)
813
+ jsimd_convsamp_float_sse(sample_data, start_col, workspace);
814
+ else
815
+ jsimd_convsamp_float_3dnow(sample_data, start_col, workspace);
816
+ }
817
+
818
+ GLOBAL(int)
819
+ jsimd_can_fdct_islow(void)
820
+ {
821
+ init_simd();
822
+
823
+ /* The code is optimised for these values only */
824
+ if (DCTSIZE != 8)
825
+ return 0;
826
+ if (sizeof(DCTELEM) != 2)
827
+ return 0;
828
+
829
+ if ((simd_support & JSIMD_AVX2) && IS_ALIGNED_AVX(jconst_fdct_islow_avx2))
830
+ return 1;
831
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_fdct_islow_sse2))
832
+ return 1;
833
+ if (simd_support & JSIMD_MMX)
834
+ return 1;
835
+
836
+ return 0;
837
+ }
838
+
839
+ GLOBAL(int)
840
+ jsimd_can_fdct_ifast(void)
841
+ {
842
+ init_simd();
843
+
844
+ /* The code is optimised for these values only */
845
+ if (DCTSIZE != 8)
846
+ return 0;
847
+ if (sizeof(DCTELEM) != 2)
848
+ return 0;
849
+
850
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_fdct_ifast_sse2))
851
+ return 1;
852
+ if (simd_support & JSIMD_MMX)
853
+ return 1;
854
+
855
+ return 0;
856
+ }
857
+
858
+ GLOBAL(int)
859
+ jsimd_can_fdct_float(void)
860
+ {
861
+ init_simd();
862
+
863
+ /* The code is optimised for these values only */
864
+ if (DCTSIZE != 8)
865
+ return 0;
866
+ if (sizeof(FAST_FLOAT) != 4)
867
+ return 0;
868
+
869
+ if ((simd_support & JSIMD_SSE) && IS_ALIGNED_SSE(jconst_fdct_float_sse))
870
+ return 1;
871
+ if (simd_support & JSIMD_3DNOW)
872
+ return 1;
873
+
874
+ return 0;
875
+ }
876
+
877
+ GLOBAL(void)
878
+ jsimd_fdct_islow(DCTELEM *data)
879
+ {
880
+ if (simd_support & JSIMD_AVX2)
881
+ jsimd_fdct_islow_avx2(data);
882
+ else if (simd_support & JSIMD_SSE2)
883
+ jsimd_fdct_islow_sse2(data);
884
+ else
885
+ jsimd_fdct_islow_mmx(data);
886
+ }
887
+
888
+ GLOBAL(void)
889
+ jsimd_fdct_ifast(DCTELEM *data)
890
+ {
891
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_fdct_islow_sse2))
892
+ jsimd_fdct_ifast_sse2(data);
893
+ else
894
+ jsimd_fdct_ifast_mmx(data);
895
+ }
896
+
897
+ GLOBAL(void)
898
+ jsimd_fdct_float(FAST_FLOAT *data)
899
+ {
900
+ if ((simd_support & JSIMD_SSE) && IS_ALIGNED_SSE(jconst_fdct_float_sse))
901
+ jsimd_fdct_float_sse(data);
902
+ else if (simd_support & JSIMD_3DNOW)
903
+ jsimd_fdct_float_3dnow(data);
904
+ }
905
+
906
+ GLOBAL(int)
907
+ jsimd_can_quantize(void)
908
+ {
909
+ init_simd();
910
+
911
+ /* The code is optimised for these values only */
912
+ if (DCTSIZE != 8)
913
+ return 0;
914
+ if (sizeof(JCOEF) != 2)
915
+ return 0;
916
+ if (sizeof(DCTELEM) != 2)
917
+ return 0;
918
+
919
+ if (simd_support & JSIMD_AVX2)
920
+ return 1;
921
+ if (simd_support & JSIMD_SSE2)
922
+ return 1;
923
+ if (simd_support & JSIMD_MMX)
924
+ return 1;
925
+
926
+ return 0;
927
+ }
928
+
929
+ GLOBAL(int)
930
+ jsimd_can_quantize_float(void)
931
+ {
932
+ init_simd();
933
+
934
+ /* The code is optimised for these values only */
935
+ if (DCTSIZE != 8)
936
+ return 0;
937
+ if (sizeof(JCOEF) != 2)
938
+ return 0;
939
+ if (sizeof(FAST_FLOAT) != 4)
940
+ return 0;
941
+
942
+ if (simd_support & JSIMD_SSE2)
943
+ return 1;
944
+ if (simd_support & JSIMD_SSE)
945
+ return 1;
946
+ if (simd_support & JSIMD_3DNOW)
947
+ return 1;
948
+
949
+ return 0;
950
+ }
951
+
952
+ GLOBAL(void)
953
+ jsimd_quantize(JCOEFPTR coef_block, DCTELEM *divisors, DCTELEM *workspace)
954
+ {
955
+ if (simd_support & JSIMD_AVX2)
956
+ jsimd_quantize_avx2(coef_block, divisors, workspace);
957
+ else if (simd_support & JSIMD_SSE2)
958
+ jsimd_quantize_sse2(coef_block, divisors, workspace);
959
+ else
960
+ jsimd_quantize_mmx(coef_block, divisors, workspace);
961
+ }
962
+
963
+ GLOBAL(void)
964
+ jsimd_quantize_float(JCOEFPTR coef_block, FAST_FLOAT *divisors,
965
+ FAST_FLOAT *workspace)
966
+ {
967
+ if (simd_support & JSIMD_SSE2)
968
+ jsimd_quantize_float_sse2(coef_block, divisors, workspace);
969
+ else if (simd_support & JSIMD_SSE)
970
+ jsimd_quantize_float_sse(coef_block, divisors, workspace);
971
+ else
972
+ jsimd_quantize_float_3dnow(coef_block, divisors, workspace);
973
+ }
974
+
975
+ GLOBAL(int)
976
+ jsimd_can_idct_2x2(void)
977
+ {
978
+ init_simd();
979
+
980
+ /* The code is optimised for these values only */
981
+ if (DCTSIZE != 8)
982
+ return 0;
983
+ if (sizeof(JCOEF) != 2)
984
+ return 0;
985
+ if (BITS_IN_JSAMPLE != 8)
986
+ return 0;
987
+ if (sizeof(JDIMENSION) != 4)
988
+ return 0;
989
+ if (sizeof(ISLOW_MULT_TYPE) != 2)
990
+ return 0;
991
+
992
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_red_sse2))
993
+ return 1;
994
+ if (simd_support & JSIMD_MMX)
995
+ return 1;
996
+
997
+ return 0;
998
+ }
999
+
1000
+ GLOBAL(int)
1001
+ jsimd_can_idct_4x4(void)
1002
+ {
1003
+ init_simd();
1004
+
1005
+ /* The code is optimised for these values only */
1006
+ if (DCTSIZE != 8)
1007
+ return 0;
1008
+ if (sizeof(JCOEF) != 2)
1009
+ return 0;
1010
+ if (BITS_IN_JSAMPLE != 8)
1011
+ return 0;
1012
+ if (sizeof(JDIMENSION) != 4)
1013
+ return 0;
1014
+ if (sizeof(ISLOW_MULT_TYPE) != 2)
1015
+ return 0;
1016
+
1017
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_red_sse2))
1018
+ return 1;
1019
+ if (simd_support & JSIMD_MMX)
1020
+ return 1;
1021
+
1022
+ return 0;
1023
+ }
1024
+
1025
+ GLOBAL(void)
1026
+ jsimd_idct_2x2(j_decompress_ptr cinfo, jpeg_component_info *compptr,
1027
+ JCOEFPTR coef_block, JSAMPARRAY output_buf,
1028
+ JDIMENSION output_col)
1029
+ {
1030
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_red_sse2))
1031
+ jsimd_idct_2x2_sse2(compptr->dct_table, coef_block, output_buf,
1032
+ output_col);
1033
+ else
1034
+ jsimd_idct_2x2_mmx(compptr->dct_table, coef_block, output_buf, output_col);
1035
+ }
1036
+
1037
+ GLOBAL(void)
1038
+ jsimd_idct_4x4(j_decompress_ptr cinfo, jpeg_component_info *compptr,
1039
+ JCOEFPTR coef_block, JSAMPARRAY output_buf,
1040
+ JDIMENSION output_col)
1041
+ {
1042
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_red_sse2))
1043
+ jsimd_idct_4x4_sse2(compptr->dct_table, coef_block, output_buf,
1044
+ output_col);
1045
+ else
1046
+ jsimd_idct_4x4_mmx(compptr->dct_table, coef_block, output_buf, output_col);
1047
+ }
1048
+
1049
+ GLOBAL(int)
1050
+ jsimd_can_idct_islow(void)
1051
+ {
1052
+ init_simd();
1053
+
1054
+ /* The code is optimised for these values only */
1055
+ if (DCTSIZE != 8)
1056
+ return 0;
1057
+ if (sizeof(JCOEF) != 2)
1058
+ return 0;
1059
+ if (BITS_IN_JSAMPLE != 8)
1060
+ return 0;
1061
+ if (sizeof(JDIMENSION) != 4)
1062
+ return 0;
1063
+ if (sizeof(ISLOW_MULT_TYPE) != 2)
1064
+ return 0;
1065
+
1066
+ if ((simd_support & JSIMD_AVX2) && IS_ALIGNED_AVX(jconst_idct_islow_avx2))
1067
+ return 1;
1068
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_islow_sse2))
1069
+ return 1;
1070
+ if (simd_support & JSIMD_MMX)
1071
+ return 1;
1072
+
1073
+ return 0;
1074
+ }
1075
+
1076
+ GLOBAL(int)
1077
+ jsimd_can_idct_ifast(void)
1078
+ {
1079
+ init_simd();
1080
+
1081
+ /* The code is optimised for these values only */
1082
+ if (DCTSIZE != 8)
1083
+ return 0;
1084
+ if (sizeof(JCOEF) != 2)
1085
+ return 0;
1086
+ if (BITS_IN_JSAMPLE != 8)
1087
+ return 0;
1088
+ if (sizeof(JDIMENSION) != 4)
1089
+ return 0;
1090
+ if (sizeof(IFAST_MULT_TYPE) != 2)
1091
+ return 0;
1092
+ if (IFAST_SCALE_BITS != 2)
1093
+ return 0;
1094
+
1095
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_ifast_sse2))
1096
+ return 1;
1097
+ if (simd_support & JSIMD_MMX)
1098
+ return 1;
1099
+
1100
+ return 0;
1101
+ }
1102
+
1103
+ GLOBAL(int)
1104
+ jsimd_can_idct_float(void)
1105
+ {
1106
+ init_simd();
1107
+
1108
+ if (DCTSIZE != 8)
1109
+ return 0;
1110
+ if (sizeof(JCOEF) != 2)
1111
+ return 0;
1112
+ if (BITS_IN_JSAMPLE != 8)
1113
+ return 0;
1114
+ if (sizeof(JDIMENSION) != 4)
1115
+ return 0;
1116
+ if (sizeof(FAST_FLOAT) != 4)
1117
+ return 0;
1118
+ if (sizeof(FLOAT_MULT_TYPE) != 4)
1119
+ return 0;
1120
+
1121
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_float_sse2))
1122
+ return 1;
1123
+ if ((simd_support & JSIMD_SSE) && IS_ALIGNED_SSE(jconst_idct_float_sse))
1124
+ return 1;
1125
+ if (simd_support & JSIMD_3DNOW)
1126
+ return 1;
1127
+
1128
+ return 0;
1129
+ }
1130
+
1131
+ GLOBAL(void)
1132
+ jsimd_idct_islow(j_decompress_ptr cinfo, jpeg_component_info *compptr,
1133
+ JCOEFPTR coef_block, JSAMPARRAY output_buf,
1134
+ JDIMENSION output_col)
1135
+ {
1136
+ if (simd_support & JSIMD_AVX2)
1137
+ jsimd_idct_islow_avx2(compptr->dct_table, coef_block, output_buf,
1138
+ output_col);
1139
+ else if (simd_support & JSIMD_SSE2)
1140
+ jsimd_idct_islow_sse2(compptr->dct_table, coef_block, output_buf,
1141
+ output_col);
1142
+ else
1143
+ jsimd_idct_islow_mmx(compptr->dct_table, coef_block, output_buf,
1144
+ output_col);
1145
+ }
1146
+
1147
+ GLOBAL(void)
1148
+ jsimd_idct_ifast(j_decompress_ptr cinfo, jpeg_component_info *compptr,
1149
+ JCOEFPTR coef_block, JSAMPARRAY output_buf,
1150
+ JDIMENSION output_col)
1151
+ {
1152
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_ifast_sse2))
1153
+ jsimd_idct_ifast_sse2(compptr->dct_table, coef_block, output_buf,
1154
+ output_col);
1155
+ else
1156
+ jsimd_idct_ifast_mmx(compptr->dct_table, coef_block, output_buf,
1157
+ output_col);
1158
+ }
1159
+
1160
+ GLOBAL(void)
1161
+ jsimd_idct_float(j_decompress_ptr cinfo, jpeg_component_info *compptr,
1162
+ JCOEFPTR coef_block, JSAMPARRAY output_buf,
1163
+ JDIMENSION output_col)
1164
+ {
1165
+ if ((simd_support & JSIMD_SSE2) && IS_ALIGNED_SSE(jconst_idct_float_sse2))
1166
+ jsimd_idct_float_sse2(compptr->dct_table, coef_block, output_buf,
1167
+ output_col);
1168
+ else if ((simd_support & JSIMD_SSE) && IS_ALIGNED_SSE(jconst_idct_float_sse))
1169
+ jsimd_idct_float_sse(compptr->dct_table, coef_block, output_buf,
1170
+ output_col);
1171
+ else
1172
+ jsimd_idct_float_3dnow(compptr->dct_table, coef_block, output_buf,
1173
+ output_col);
1174
+ }
1175
+
1176
+ GLOBAL(int)
1177
+ jsimd_can_huff_encode_one_block(void)
1178
+ {
1179
+ init_simd();
1180
+
1181
+ if (DCTSIZE != 8)
1182
+ return 0;
1183
+ if (sizeof(JCOEF) != 2)
1184
+ return 0;
1185
+
1186
+ if ((simd_support & JSIMD_SSE2) && simd_huffman &&
1187
+ IS_ALIGNED_SSE(jconst_huff_encode_one_block))
1188
+ return 1;
1189
+
1190
+ return 0;
1191
+ }
1192
+
1193
+ GLOBAL(JOCTET *)
1194
+ jsimd_huff_encode_one_block(void *state, JOCTET *buffer, JCOEFPTR block,
1195
+ int last_dc_val, c_derived_tbl *dctbl,
1196
+ c_derived_tbl *actbl)
1197
+ {
1198
+ return jsimd_huff_encode_one_block_sse2(state, buffer, block, last_dc_val,
1199
+ dctbl, actbl);
1200
+ }
1201
+
1202
+ GLOBAL(int)
1203
+ jsimd_can_encode_mcu_AC_first_prepare(void)
1204
+ {
1205
+ init_simd();
1206
+
1207
+ if (DCTSIZE != 8)
1208
+ return 0;
1209
+ if (sizeof(JCOEF) != 2)
1210
+ return 0;
1211
+ if (SIZEOF_SIZE_T != 4)
1212
+ return 0;
1213
+ if (simd_support & JSIMD_SSE2)
1214
+ return 1;
1215
+
1216
+ return 0;
1217
+ }
1218
+
1219
+ GLOBAL(void)
1220
+ jsimd_encode_mcu_AC_first_prepare(const JCOEF *block,
1221
+ const int *jpeg_natural_order_start, int Sl,
1222
+ int Al, JCOEF *values, size_t *zerobits)
1223
+ {
1224
+ jsimd_encode_mcu_AC_first_prepare_sse2(block, jpeg_natural_order_start,
1225
+ Sl, Al, values, zerobits);
1226
+ }
1227
+
1228
+ GLOBAL(int)
1229
+ jsimd_can_encode_mcu_AC_refine_prepare(void)
1230
+ {
1231
+ init_simd();
1232
+
1233
+ if (DCTSIZE != 8)
1234
+ return 0;
1235
+ if (sizeof(JCOEF) != 2)
1236
+ return 0;
1237
+ if (SIZEOF_SIZE_T != 4)
1238
+ return 0;
1239
+ if (simd_support & JSIMD_SSE2)
1240
+ return 1;
1241
+
1242
+ return 0;
1243
+ }
1244
+
1245
+ GLOBAL(int)
1246
+ jsimd_encode_mcu_AC_refine_prepare(const JCOEF *block,
1247
+ const int *jpeg_natural_order_start, int Sl,
1248
+ int Al, JCOEF *absvalues, size_t *bits)
1249
+ {
1250
+ return jsimd_encode_mcu_AC_refine_prepare_sse2(block,
1251
+ jpeg_natural_order_start,
1252
+ Sl, Al, absvalues, bits);
1253
+ }