laag-libjpeg-turbo 1.5.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (444) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +57 -0
  3. data/LICENSE.txt +139 -0
  4. data/README.org +34 -0
  5. data/ext/laag/libjpeg-turbo/extconf.rb +16 -0
  6. data/laag-libjpeg-turbo.gemspec +20 -0
  7. data/lib/laag/libjpeg-turbo.rb +29 -0
  8. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/.gitignore +14 -0
  9. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/.travis.yml +131 -0
  10. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/BUILDING.md +964 -0
  11. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/CMakeLists.txt +962 -0
  12. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/ChangeLog.md +1151 -0
  13. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/LICENSE.md +139 -0
  14. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/Makefile.am +794 -0
  15. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/README.ijg +279 -0
  16. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/README.md +341 -0
  17. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/acinclude.m4 +287 -0
  18. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/appveyor.yml +57 -0
  19. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/bmp.c +341 -0
  20. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/bmp.h +42 -0
  21. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cderror.h +136 -0
  22. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cdjpeg.c +144 -0
  23. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cdjpeg.h +153 -0
  24. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/change.log +315 -0
  25. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/ci/keys.enc +0 -0
  26. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cjpeg.1 +351 -0
  27. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cjpeg.c +644 -0
  28. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cmakescripts/cmake_uninstall.cmake.in +24 -0
  29. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cmakescripts/testclean.cmake +39 -0
  30. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/coderules.txt +78 -0
  31. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/configure.ac +616 -0
  32. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/djpeg.1 +293 -0
  33. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/djpeg.c +782 -0
  34. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/annotated.html +104 -0
  35. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/bc_s.png +0 -0
  36. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/bdwn.png +0 -0
  37. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/classes.html +106 -0
  38. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/closed.png +0 -0
  39. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/doxygen-extra.css +3 -0
  40. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/doxygen.css +1184 -0
  41. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/doxygen.png +0 -0
  42. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/dynsections.js +97 -0
  43. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2blank.png +0 -0
  44. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2cl.png +0 -0
  45. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2doc.png +0 -0
  46. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2folderclosed.png +0 -0
  47. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2folderopen.png +0 -0
  48. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2lastnode.png +0 -0
  49. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2link.png +0 -0
  50. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2mlastnode.png +0 -0
  51. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2mnode.png +0 -0
  52. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2mo.png +0 -0
  53. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2node.png +0 -0
  54. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2ns.png +0 -0
  55. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2plastnode.png +0 -0
  56. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2pnode.png +0 -0
  57. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2splitbar.png +0 -0
  58. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2vertline.png +0 -0
  59. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/functions.html +134 -0
  60. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/functions_vars.html +134 -0
  61. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/group___turbo_j_p_e_g.html +2446 -0
  62. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/index.html +90 -0
  63. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/jquery.js +8 -0
  64. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/modules.html +95 -0
  65. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/nav_f.png +0 -0
  66. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/nav_g.png +0 -0
  67. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/nav_h.png +0 -0
  68. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/open.png +0 -0
  69. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_63.html +26 -0
  70. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_63.js +4 -0
  71. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_64.html +26 -0
  72. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_64.js +5 -0
  73. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_68.html +26 -0
  74. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_68.js +4 -0
  75. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_6e.html +26 -0
  76. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_6e.js +4 -0
  77. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_6f.html +26 -0
  78. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_6f.js +5 -0
  79. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_72.html +26 -0
  80. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_72.js +4 -0
  81. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_74.html +26 -0
  82. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_74.js +89 -0
  83. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_77.html +26 -0
  84. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_77.js +4 -0
  85. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_78.html +26 -0
  86. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_78.js +4 -0
  87. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_79.html +26 -0
  88. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_79.js +4 -0
  89. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/classes_74.html +26 -0
  90. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/classes_74.js +6 -0
  91. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/close.png +0 -0
  92. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/enums_74.html +26 -0
  93. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/enums_74.js +7 -0
  94. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/enumvalues_74.html +26 -0
  95. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/enumvalues_74.js +34 -0
  96. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/functions_74.html +26 -0
  97. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/functions_74.js +28 -0
  98. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/groups_74.html +26 -0
  99. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/groups_74.js +4 -0
  100. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/mag_sel.png +0 -0
  101. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/nomatches.html +12 -0
  102. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search.css +271 -0
  103. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search.js +809 -0
  104. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search_l.png +0 -0
  105. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search_m.png +0 -0
  106. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search_r.png +0 -0
  107. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/typedefs_74.html +26 -0
  108. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/typedefs_74.js +5 -0
  109. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_63.html +26 -0
  110. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_63.js +4 -0
  111. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_64.html +26 -0
  112. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_64.js +5 -0
  113. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_68.html +26 -0
  114. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_68.js +4 -0
  115. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_6e.html +26 -0
  116. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_6e.js +4 -0
  117. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_6f.html +26 -0
  118. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_6f.js +5 -0
  119. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_72.html +26 -0
  120. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_72.js +4 -0
  121. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_74.html +26 -0
  122. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_74.js +9 -0
  123. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_77.html +26 -0
  124. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_77.js +4 -0
  125. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_78.html +26 -0
  126. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_78.js +4 -0
  127. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_79.html +26 -0
  128. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_79.js +4 -0
  129. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/structtjregion.html +186 -0
  130. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/structtjscalingfactor.html +148 -0
  131. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/structtjtransform.html +212 -0
  132. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/sync_off.png +0 -0
  133. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/sync_on.png +0 -0
  134. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tab_a.png +0 -0
  135. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tab_b.png +0 -0
  136. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tab_h.png +0 -0
  137. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tab_s.png +0 -0
  138. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tabs.css +60 -0
  139. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doxygen-extra.css +3 -0
  140. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doxygen.config +16 -0
  141. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/example.c +433 -0
  142. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jaricom.c +156 -0
  143. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/CMakeLists.txt +57 -0
  144. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/MANIFEST.MF +2 -0
  145. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/Makefile.am +75 -0
  146. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/README +52 -0
  147. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/TJBench.java +926 -0
  148. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/TJExample.java +362 -0
  149. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/TJUnitTest.java +959 -0
  150. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/allclasses-frame.html +24 -0
  151. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/allclasses-noframe.html +24 -0
  152. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/constant-values.html +479 -0
  153. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/deprecated-list.html +248 -0
  154. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/help-doc.html +206 -0
  155. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/index-all.html +980 -0
  156. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/index.html +70 -0
  157. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJ.html +1254 -0
  158. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJCompressor.html +922 -0
  159. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJCustomFilter.html +237 -0
  160. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJDecompressor.html +1235 -0
  161. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJException.html +287 -0
  162. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJScalingFactor.html +333 -0
  163. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJTransform.html +706 -0
  164. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJTransformer.html +417 -0
  165. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/YUVImage.html +761 -0
  166. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/package-frame.html +31 -0
  167. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/package-summary.html +198 -0
  168. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/package-tree.html +156 -0
  169. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/overview-tree.html +160 -0
  170. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/package-list +1 -0
  171. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/resources/background.gif +0 -0
  172. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/resources/tab.gif +0 -0
  173. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/resources/titlebar.gif +0 -0
  174. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/resources/titlebar_end.gif +0 -0
  175. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/serialized-form.html +159 -0
  176. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/stylesheet.css +474 -0
  177. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJ.java +513 -0
  178. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJCompressor.java +658 -0
  179. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJCustomFilter.java +76 -0
  180. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJDecompressor.java +909 -0
  181. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJException.java +53 -0
  182. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJLoader.java.in +35 -0
  183. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJLoader.java.tmpl +59 -0
  184. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJScalingFactor.java +104 -0
  185. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJTransform.java +208 -0
  186. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJTransformer.java +163 -0
  187. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/YUVImage.java +443 -0
  188. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org_libjpegturbo_turbojpeg_TJ.h +129 -0
  189. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org_libjpegturbo_turbojpeg_TJCompressor.h +101 -0
  190. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org_libjpegturbo_turbojpeg_TJDecompressor.h +101 -0
  191. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org_libjpegturbo_turbojpeg_TJTransformer.h +29 -0
  192. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcapimin.c +295 -0
  193. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcapistd.c +162 -0
  194. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcarith.c +928 -0
  195. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jccoefct.c +449 -0
  196. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jccolext.c +148 -0
  197. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jccolor.c +719 -0
  198. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcdctmgr.c +721 -0
  199. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jchuff.c +1091 -0
  200. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jchuff.h +43 -0
  201. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcinit.c +77 -0
  202. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcmainct.c +162 -0
  203. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcmarker.c +665 -0
  204. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcmaster.c +639 -0
  205. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcomapi.c +109 -0
  206. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jconfig.h.in +73 -0
  207. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jconfig.txt +143 -0
  208. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jconfigint.h.in +17 -0
  209. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcparam.c +542 -0
  210. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcphuff.c +834 -0
  211. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcprepct.c +357 -0
  212. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcsample.c +539 -0
  213. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcstest.c +126 -0
  214. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jctrans.c +402 -0
  215. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdapimin.c +407 -0
  216. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdapistd.c +637 -0
  217. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdarith.c +769 -0
  218. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdatadst-tj.c +202 -0
  219. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdatadst.c +293 -0
  220. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdatasrc-tj.c +191 -0
  221. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdatasrc.c +295 -0
  222. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcoefct.c +693 -0
  223. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcoefct.h +82 -0
  224. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcol565.c +384 -0
  225. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcolext.c +143 -0
  226. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcolor.c +897 -0
  227. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdct.h +208 -0
  228. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jddctmgr.c +352 -0
  229. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdhuff.c +822 -0
  230. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdhuff.h +234 -0
  231. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdinput.c +405 -0
  232. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmainct.c +456 -0
  233. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmainct.h +71 -0
  234. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmarker.c +1377 -0
  235. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmaster.c +736 -0
  236. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmaster.h +28 -0
  237. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmerge.c +627 -0
  238. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmrg565.c +356 -0
  239. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmrgext.c +186 -0
  240. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdphuff.c +674 -0
  241. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdpostct.c +290 -0
  242. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdsample.c +517 -0
  243. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdsample.h +50 -0
  244. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdtrans.c +155 -0
  245. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jerror.c +251 -0
  246. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jerror.h +317 -0
  247. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jfdctflt.c +169 -0
  248. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jfdctfst.c +227 -0
  249. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jfdctint.c +286 -0
  250. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jidctflt.c +240 -0
  251. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jidctfst.c +371 -0
  252. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jidctint.c +2627 -0
  253. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jidctred.c +403 -0
  254. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jinclude.h +84 -0
  255. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jmemmgr.c +1183 -0
  256. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jmemnobs.c +115 -0
  257. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jmemsys.h +178 -0
  258. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jmorecfg.h +421 -0
  259. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpeg_nbits_table.h +4098 -0
  260. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpegcomp.h +31 -0
  261. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpegint.h +368 -0
  262. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpeglib.h +1122 -0
  263. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpegtran.1 +290 -0
  264. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpegtran.c +551 -0
  265. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jquant1.c +857 -0
  266. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jquant2.c +1282 -0
  267. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jsimd.h +93 -0
  268. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jsimd_none.c +404 -0
  269. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jsimddct.h +74 -0
  270. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jstdhuff.c +135 -0
  271. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jutils.c +133 -0
  272. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jversion.h +49 -0
  273. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/libjpeg.map.in +11 -0
  274. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/libjpeg.txt +3104 -0
  275. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/CMakeLists.txt +1 -0
  276. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/Makefile.am +4 -0
  277. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/md5.c +340 -0
  278. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/md5.h +49 -0
  279. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/md5cmp.c +60 -0
  280. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/md5hl.c +114 -0
  281. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdbmp.c +483 -0
  282. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdcolmap.c +254 -0
  283. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdgif.c +39 -0
  284. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdjpgcom.1 +63 -0
  285. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdjpgcom.c +510 -0
  286. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdppm.c +471 -0
  287. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdrle.c +389 -0
  288. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdswitch.c +424 -0
  289. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdtarga.c +503 -0
  290. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/Distribution.xml +24 -0
  291. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/License.rtf +20 -0
  292. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/ReadMe.txt +5 -0
  293. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/Welcome.rtf +17 -0
  294. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/deb-control.tmpl +31 -0
  295. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/libjpeg-turbo.nsi.in +162 -0
  296. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/libjpeg-turbo.spec.in +164 -0
  297. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/libjpeg.pc.in +10 -0
  298. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/libturbojpeg.pc.in +10 -0
  299. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/makecygwinpkg.in +42 -0
  300. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/makedpkg.in +82 -0
  301. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/makemacpkg.in +470 -0
  302. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/uninstall.in +112 -0
  303. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/sharedlib/CMakeLists.txt +73 -0
  304. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/CMakeLists.txt +81 -0
  305. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/Makefile.am +102 -0
  306. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolext-altivec.c +267 -0
  307. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolext-mmx.asm +476 -0
  308. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolext-sse2-64.asm +486 -0
  309. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolext-sse2.asm +503 -0
  310. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolor-altivec.c +104 -0
  311. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolor-mmx.asm +122 -0
  312. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolor-sse2-64.asm +121 -0
  313. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolor-sse2.asm +121 -0
  314. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgray-altivec.c +99 -0
  315. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgray-mmx.asm +115 -0
  316. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgray-sse2-64.asm +114 -0
  317. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgray-sse2.asm +114 -0
  318. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgryext-altivec.c +227 -0
  319. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgryext-mmx.asm +356 -0
  320. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgryext-sse2-64.asm +365 -0
  321. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgryext-sse2.asm +384 -0
  322. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jchuff-sse2-64.asm +360 -0
  323. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jchuff-sse2.asm +426 -0
  324. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcolsamp.inc +104 -0
  325. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample-altivec.c +158 -0
  326. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample-mmx.asm +323 -0
  327. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample-sse2-64.asm +329 -0
  328. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample-sse2.asm +350 -0
  329. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample.h +28 -0
  330. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolext-altivec.c +274 -0
  331. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolext-mmx.asm +404 -0
  332. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolext-sse2-64.asm +440 -0
  333. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolext-sse2.asm +459 -0
  334. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolor-altivec.c +96 -0
  335. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolor-mmx.asm +119 -0
  336. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolor-sse2-64.asm +119 -0
  337. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolor-sse2.asm +119 -0
  338. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdct.inc +27 -0
  339. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmerge-altivec.c +108 -0
  340. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmerge-mmx.asm +125 -0
  341. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmerge-sse2-64.asm +125 -0
  342. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmerge-sse2.asm +125 -0
  343. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmrgext-altivec.c +323 -0
  344. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmrgext-mmx.asm +463 -0
  345. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmrgext-sse2-64.asm +537 -0
  346. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmrgext-sse2.asm +518 -0
  347. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdsample-altivec.c +392 -0
  348. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdsample-mmx.asm +736 -0
  349. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdsample-sse2-64.asm +670 -0
  350. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdsample-sse2.asm +728 -0
  351. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctflt-3dn.asm +319 -0
  352. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctflt-sse-64.asm +357 -0
  353. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctflt-sse.asm +369 -0
  354. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctfst-altivec.c +156 -0
  355. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctfst-mmx.asm +396 -0
  356. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctfst-sse2-64.asm +391 -0
  357. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctfst-sse2.asm +403 -0
  358. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctint-altivec.c +262 -0
  359. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctint-mmx.asm +621 -0
  360. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctint-sse2-64.asm +621 -0
  361. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctint-sse2.asm +633 -0
  362. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctflt-3dn.asm +451 -0
  363. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctflt-sse.asm +571 -0
  364. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctflt-sse2-64.asm +482 -0
  365. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctflt-sse2.asm +497 -0
  366. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctfst-altivec.c +257 -0
  367. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctfst-mmx.asm +499 -0
  368. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctfst-sse2-64.asm +491 -0
  369. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctfst-sse2.asm +501 -0
  370. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctint-altivec.c +359 -0
  371. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctint-mmx.asm +851 -0
  372. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctint-sse2-64.asm +847 -0
  373. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctint-sse2.asm +858 -0
  374. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctred-mmx.asm +705 -0
  375. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctred-sse2-64.asm +575 -0
  376. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctred-sse2.asm +593 -0
  377. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jpeg_nbits_table.inc +4097 -0
  378. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquant-3dn.asm +232 -0
  379. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquant-mmx.asm +273 -0
  380. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquant-sse.asm +210 -0
  381. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquantf-sse2-64.asm +157 -0
  382. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquantf-sse2.asm +170 -0
  383. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquanti-altivec.c +252 -0
  384. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquanti-sse2-64.asm +186 -0
  385. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquanti-sse2.asm +199 -0
  386. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd.h +871 -0
  387. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_altivec.h +99 -0
  388. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_arm.c +728 -0
  389. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_arm64.c +803 -0
  390. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_arm64_neon.S +3425 -0
  391. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_arm_neon.S +2878 -0
  392. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_i386.c +1091 -0
  393. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_mips.c +1140 -0
  394. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_mips_dspr2.S +4486 -0
  395. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_mips_dspr2_asm.h +283 -0
  396. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_powerpc.c +852 -0
  397. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_x86_64.c +887 -0
  398. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimdcfg.inc.h +130 -0
  399. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimdcpu.asm +104 -0
  400. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimdext.inc +375 -0
  401. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/nasm_lt.sh +60 -0
  402. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/structure.txt +904 -0
  403. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/nightshot_iso_100.bmp +0 -0
  404. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/nightshot_iso_100.txt +25 -0
  405. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testimgari.jpg +0 -0
  406. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testimgint.jpg +0 -0
  407. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testorig.jpg +0 -0
  408. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testorig.ppm +4 -0
  409. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testorig12.jpg +0 -0
  410. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/vgl_5674_0098.bmp +0 -0
  411. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/vgl_6434_0018a.bmp +0 -0
  412. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/vgl_6548_0026a.bmp +0 -0
  413. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjbench.c +1010 -0
  414. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjbenchtest.in +252 -0
  415. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjbenchtest.java.in +207 -0
  416. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjexampletest.in +150 -0
  417. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjunittest.c +734 -0
  418. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjutil.c +66 -0
  419. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjutil.h +47 -0
  420. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/transupp.c +1626 -0
  421. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/transupp.h +207 -0
  422. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg-jni.c +1166 -0
  423. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg-mapfile +56 -0
  424. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg-mapfile.jni +92 -0
  425. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg.c +2175 -0
  426. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg.h +1545 -0
  427. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/usage.txt +635 -0
  428. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jconfig.h.in +51 -0
  429. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jconfigint.h.in +13 -0
  430. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg62-memsrcdst.def +106 -0
  431. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg62.def +104 -0
  432. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg7-memsrcdst.def +108 -0
  433. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg7.def +106 -0
  434. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg8.def +109 -0
  435. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jsimdcfg.inc +94 -0
  436. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wizard.txt +211 -0
  437. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrbmp.c +494 -0
  438. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrgif.c +413 -0
  439. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrjpgcom.1 +103 -0
  440. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrjpgcom.c +592 -0
  441. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrppm.c +280 -0
  442. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrrle.c +308 -0
  443. data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrtarga.c +261 -0
  444. metadata +509 -0
@@ -0,0 +1,392 @@
1
+ /*
2
+ * AltiVec optimizations for libjpeg-turbo
3
+ *
4
+ * Copyright (C) 2015, D. R. Commander. All Rights Reserved.
5
+ *
6
+ * This software is provided 'as-is', without any express or implied
7
+ * warranty. In no event will the authors be held liable for any damages
8
+ * arising from the use of this software.
9
+ *
10
+ * Permission is granted to anyone to use this software for any purpose,
11
+ * including commercial applications, and to alter it and redistribute it
12
+ * freely, subject to the following restrictions:
13
+ *
14
+ * 1. The origin of this software must not be misrepresented; you must not
15
+ * claim that you wrote the original software. If you use this software
16
+ * in a product, an acknowledgment in the product documentation would be
17
+ * appreciated but is not required.
18
+ * 2. Altered source versions must be plainly marked as such, and must not be
19
+ * misrepresented as being the original software.
20
+ * 3. This notice may not be removed or altered from any source distribution.
21
+ */
22
+
23
+ /* CHROMA UPSAMPLING */
24
+
25
+ #include "jsimd_altivec.h"
26
+
27
+
28
+ void
29
+ jsimd_h2v1_fancy_upsample_altivec (int max_v_samp_factor,
30
+ JDIMENSION downsampled_width,
31
+ JSAMPARRAY input_data,
32
+ JSAMPARRAY *output_data_ptr)
33
+ {
34
+ JSAMPARRAY output_data = *output_data_ptr;
35
+ JSAMPROW inptr, outptr;
36
+ int inrow, incol;
37
+
38
+ __vector unsigned char this0, last0, p_last0, next0 = {0}, p_next0,
39
+ out;
40
+ __vector short this0e, this0o, this0l, this0h, last0l, last0h,
41
+ next0l, next0h, outle, outhe, outlo, outho;
42
+
43
+ /* Constants */
44
+ __vector unsigned char pb_zero = { __16X(0) }, pb_three = { __16X(3) },
45
+ last_index_col0 = {0,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14},
46
+ last_index = {15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30},
47
+ next_index = {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16},
48
+ next_index_lastcol = {1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,15},
49
+ #if __BIG_ENDIAN__
50
+ merge_pack_index = {1,17,3,19,5,21,7,23,9,25,11,27,13,29,15,31};
51
+ #else
52
+ merge_pack_index = {0,16,2,18,4,20,6,22,8,24,10,26,12,28,14,30};
53
+ #endif
54
+ __vector short pw_one = { __8X(1) }, pw_two = { __8X(2) };
55
+
56
+ for (inrow = 0; inrow < max_v_samp_factor; inrow++) {
57
+ inptr = input_data[inrow];
58
+ outptr = output_data[inrow];
59
+
60
+ if (downsampled_width & 15)
61
+ inptr[downsampled_width] = inptr[downsampled_width - 1];
62
+
63
+ this0 = vec_ld(0, inptr);
64
+ p_last0 = vec_perm(this0, this0, last_index_col0);
65
+ last0 = this0;
66
+
67
+ for (incol = downsampled_width; incol > 0;
68
+ incol -= 16, inptr += 16, outptr += 32) {
69
+
70
+ if (downsampled_width - incol > 0) {
71
+ p_last0 = vec_perm(last0, this0, last_index);
72
+ last0 = this0;
73
+ }
74
+
75
+ if (incol <= 16)
76
+ p_next0 = vec_perm(this0, this0, next_index_lastcol);
77
+ else {
78
+ next0 = vec_ld(16, inptr);
79
+ p_next0 = vec_perm(this0, next0, next_index);
80
+ }
81
+
82
+ this0e = (__vector short)vec_mule(this0, pb_three);
83
+ this0o = (__vector short)vec_mulo(this0, pb_three);
84
+ this0l = vec_mergeh(this0e, this0o);
85
+ this0h = vec_mergel(this0e, this0o);
86
+
87
+ last0l = (__vector short)VEC_UNPACKHU(p_last0);
88
+ last0h = (__vector short)VEC_UNPACKLU(p_last0);
89
+ last0l = vec_add(last0l, pw_one);
90
+
91
+ next0l = (__vector short)VEC_UNPACKHU(p_next0);
92
+ next0h = (__vector short)VEC_UNPACKLU(p_next0);
93
+ next0l = vec_add(next0l, pw_two);
94
+
95
+ outle = vec_add(this0l, last0l);
96
+ outlo = vec_add(this0l, next0l);
97
+ outle = vec_sr(outle, (__vector unsigned short)pw_two);
98
+ outlo = vec_sr(outlo, (__vector unsigned short)pw_two);
99
+
100
+ out = vec_perm((__vector unsigned char)outle,
101
+ (__vector unsigned char)outlo, merge_pack_index);
102
+ vec_st(out, 0, outptr);
103
+
104
+ if (incol > 8) {
105
+ last0h = vec_add(last0h, pw_one);
106
+ next0h = vec_add(next0h, pw_two);
107
+
108
+ outhe = vec_add(this0h, last0h);
109
+ outho = vec_add(this0h, next0h);
110
+ outhe = vec_sr(outhe, (__vector unsigned short)pw_two);
111
+ outho = vec_sr(outho, (__vector unsigned short)pw_two);
112
+
113
+ out = vec_perm((__vector unsigned char)outhe,
114
+ (__vector unsigned char)outho, merge_pack_index);
115
+ vec_st(out, 16, outptr);
116
+ }
117
+
118
+ this0 = next0;
119
+ }
120
+ }
121
+ }
122
+
123
+
124
+ void
125
+ jsimd_h2v2_fancy_upsample_altivec (int max_v_samp_factor,
126
+ JDIMENSION downsampled_width,
127
+ JSAMPARRAY input_data,
128
+ JSAMPARRAY *output_data_ptr)
129
+ {
130
+ JSAMPARRAY output_data = *output_data_ptr;
131
+ JSAMPROW inptr_1, inptr0, inptr1, outptr0, outptr1;
132
+ int inrow, outrow, incol;
133
+
134
+ __vector unsigned char this_1, this0, this1, out;
135
+ __vector short this_1l, this_1h, this0l, this0h, this1l, this1h,
136
+ lastcolsum_1h, lastcolsum1h,
137
+ p_lastcolsum_1l, p_lastcolsum_1h, p_lastcolsum1l, p_lastcolsum1h,
138
+ thiscolsum_1l, thiscolsum_1h, thiscolsum1l, thiscolsum1h,
139
+ nextcolsum_1l = {0}, nextcolsum_1h = {0},
140
+ nextcolsum1l = {0}, nextcolsum1h = {0},
141
+ p_nextcolsum_1l, p_nextcolsum_1h, p_nextcolsum1l, p_nextcolsum1h,
142
+ tmpl, tmph, outle, outhe, outlo, outho;
143
+
144
+ /* Constants */
145
+ __vector unsigned char pb_zero = { __16X(0) },
146
+ last_index_col0 = {0,1,0,1,2,3,4,5,6,7,8,9,10,11,12,13},
147
+ last_index={14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29},
148
+ next_index = {2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17},
149
+ next_index_lastcol = {2,3,4,5,6,7,8,9,10,11,12,13,14,15,14,15},
150
+ #if __BIG_ENDIAN__
151
+ merge_pack_index = {1,17,3,19,5,21,7,23,9,25,11,27,13,29,15,31};
152
+ #else
153
+ merge_pack_index = {0,16,2,18,4,20,6,22,8,24,10,26,12,28,14,30};
154
+ #endif
155
+ __vector short pw_zero = { __8X(0) }, pw_three = { __8X(3) },
156
+ pw_seven = { __8X(7) }, pw_eight = { __8X(8) };
157
+ __vector unsigned short pw_four = { __8X(4) };
158
+
159
+ for (inrow = 0, outrow = 0; outrow < max_v_samp_factor; inrow++) {
160
+
161
+ inptr_1 = input_data[inrow - 1];
162
+ inptr0 = input_data[inrow];
163
+ inptr1 = input_data[inrow + 1];
164
+ outptr0 = output_data[outrow++];
165
+ outptr1 = output_data[outrow++];
166
+
167
+ if (downsampled_width & 15) {
168
+ inptr_1[downsampled_width] = inptr_1[downsampled_width - 1];
169
+ inptr0[downsampled_width] = inptr0[downsampled_width - 1];
170
+ inptr1[downsampled_width] = inptr1[downsampled_width - 1];
171
+ }
172
+
173
+ this0 = vec_ld(0, inptr0);
174
+ this0l = (__vector short)VEC_UNPACKHU(this0);
175
+ this0h = (__vector short)VEC_UNPACKLU(this0);
176
+ this0l = vec_mladd(this0l, pw_three, pw_zero);
177
+ this0h = vec_mladd(this0h, pw_three, pw_zero);
178
+
179
+ this_1 = vec_ld(0, inptr_1);
180
+ this_1l = (__vector short)VEC_UNPACKHU(this_1);
181
+ this_1h = (__vector short)VEC_UNPACKLU(this_1);
182
+ thiscolsum_1l = vec_add(this0l, this_1l);
183
+ thiscolsum_1h = vec_add(this0h, this_1h);
184
+ lastcolsum_1h = thiscolsum_1h;
185
+ p_lastcolsum_1l = vec_perm(thiscolsum_1l, thiscolsum_1l, last_index_col0);
186
+ p_lastcolsum_1h = vec_perm(thiscolsum_1l, thiscolsum_1h, last_index);
187
+
188
+ this1 = vec_ld(0, inptr1);
189
+ this1l = (__vector short)VEC_UNPACKHU(this1);
190
+ this1h = (__vector short)VEC_UNPACKLU(this1);
191
+ thiscolsum1l = vec_add(this0l, this1l);
192
+ thiscolsum1h = vec_add(this0h, this1h);
193
+ lastcolsum1h = thiscolsum1h;
194
+ p_lastcolsum1l = vec_perm(thiscolsum1l, thiscolsum1l, last_index_col0);
195
+ p_lastcolsum1h = vec_perm(thiscolsum1l, thiscolsum1h, last_index);
196
+
197
+ for (incol = downsampled_width; incol > 0;
198
+ incol -= 16, inptr_1 += 16, inptr0 += 16, inptr1 += 16,
199
+ outptr0 += 32, outptr1 += 32) {
200
+
201
+ if (downsampled_width - incol > 0) {
202
+ p_lastcolsum_1l = vec_perm(lastcolsum_1h, thiscolsum_1l, last_index);
203
+ p_lastcolsum_1h = vec_perm(thiscolsum_1l, thiscolsum_1h, last_index);
204
+ p_lastcolsum1l = vec_perm(lastcolsum1h, thiscolsum1l, last_index);
205
+ p_lastcolsum1h = vec_perm(thiscolsum1l, thiscolsum1h, last_index);
206
+ lastcolsum_1h = thiscolsum_1h; lastcolsum1h = thiscolsum1h;
207
+ }
208
+
209
+ if (incol <= 16) {
210
+ p_nextcolsum_1l = vec_perm(thiscolsum_1l, thiscolsum_1h, next_index);
211
+ p_nextcolsum_1h = vec_perm(thiscolsum_1h, thiscolsum_1h,
212
+ next_index_lastcol);
213
+ p_nextcolsum1l = vec_perm(thiscolsum1l, thiscolsum1h, next_index);
214
+ p_nextcolsum1h = vec_perm(thiscolsum1h, thiscolsum1h,
215
+ next_index_lastcol);
216
+ } else {
217
+ this0 = vec_ld(16, inptr0);
218
+ this0l = (__vector short)VEC_UNPACKHU(this0);
219
+ this0h = (__vector short)VEC_UNPACKLU(this0);
220
+ this0l = vec_mladd(this0l, pw_three, pw_zero);
221
+ this0h = vec_mladd(this0h, pw_three, pw_zero);
222
+
223
+ this_1 = vec_ld(16, inptr_1);
224
+ this_1l = (__vector short)VEC_UNPACKHU(this_1);
225
+ this_1h = (__vector short)VEC_UNPACKLU(this_1);
226
+ nextcolsum_1l = vec_add(this0l, this_1l);
227
+ nextcolsum_1h = vec_add(this0h, this_1h);
228
+ p_nextcolsum_1l = vec_perm(thiscolsum_1l, thiscolsum_1h, next_index);
229
+ p_nextcolsum_1h = vec_perm(thiscolsum_1h, nextcolsum_1l, next_index);
230
+
231
+ this1 = vec_ld(16, inptr1);
232
+ this1l = (__vector short)VEC_UNPACKHU(this1);
233
+ this1h = (__vector short)VEC_UNPACKLU(this1);
234
+ nextcolsum1l = vec_add(this0l, this1l);
235
+ nextcolsum1h = vec_add(this0h, this1h);
236
+ p_nextcolsum1l = vec_perm(thiscolsum1l, thiscolsum1h, next_index);
237
+ p_nextcolsum1h = vec_perm(thiscolsum1h, nextcolsum1l, next_index);
238
+ }
239
+
240
+ /* Process the upper row */
241
+
242
+ tmpl = vec_mladd(thiscolsum_1l, pw_three, pw_zero);
243
+ outle = vec_add(tmpl, p_lastcolsum_1l);
244
+ outle = vec_add(outle, pw_eight);
245
+ outle = vec_sr(outle, pw_four);
246
+
247
+ outlo = vec_add(tmpl, p_nextcolsum_1l);
248
+ outlo = vec_add(outlo, pw_seven);
249
+ outlo = vec_sr(outlo, pw_four);
250
+
251
+ out = vec_perm((__vector unsigned char)outle,
252
+ (__vector unsigned char)outlo, merge_pack_index);
253
+ vec_st(out, 0, outptr0);
254
+
255
+ if (incol > 8) {
256
+ tmph = vec_mladd(thiscolsum_1h, pw_three, pw_zero);
257
+ outhe = vec_add(tmph, p_lastcolsum_1h);
258
+ outhe = vec_add(outhe, pw_eight);
259
+ outhe = vec_sr(outhe, pw_four);
260
+
261
+ outho = vec_add(tmph, p_nextcolsum_1h);
262
+ outho = vec_add(outho, pw_seven);
263
+ outho = vec_sr(outho, pw_four);
264
+
265
+ out = vec_perm((__vector unsigned char)outhe,
266
+ (__vector unsigned char)outho, merge_pack_index);
267
+ vec_st(out, 16, outptr0);
268
+ }
269
+
270
+ /* Process the lower row */
271
+
272
+ tmpl = vec_mladd(thiscolsum1l, pw_three, pw_zero);
273
+ outle = vec_add(tmpl, p_lastcolsum1l);
274
+ outle = vec_add(outle, pw_eight);
275
+ outle = vec_sr(outle, pw_four);
276
+
277
+ outlo = vec_add(tmpl, p_nextcolsum1l);
278
+ outlo = vec_add(outlo, pw_seven);
279
+ outlo = vec_sr(outlo, pw_four);
280
+
281
+ out = vec_perm((__vector unsigned char)outle,
282
+ (__vector unsigned char)outlo, merge_pack_index);
283
+ vec_st(out, 0, outptr1);
284
+
285
+ if (incol > 8) {
286
+ tmph = vec_mladd(thiscolsum1h, pw_three, pw_zero);
287
+ outhe = vec_add(tmph, p_lastcolsum1h);
288
+ outhe = vec_add(outhe, pw_eight);
289
+ outhe = vec_sr(outhe, pw_four);
290
+
291
+ outho = vec_add(tmph, p_nextcolsum1h);
292
+ outho = vec_add(outho, pw_seven);
293
+ outho = vec_sr(outho, pw_four);
294
+
295
+ out = vec_perm((__vector unsigned char)outhe,
296
+ (__vector unsigned char)outho, merge_pack_index);
297
+ vec_st(out, 16, outptr1);
298
+ }
299
+
300
+ thiscolsum_1l = nextcolsum_1l; thiscolsum_1h = nextcolsum_1h;
301
+ thiscolsum1l = nextcolsum1l; thiscolsum1h = nextcolsum1h;
302
+ }
303
+ }
304
+ }
305
+
306
+
307
+ /* These are rarely used (mainly just for decompressing YCCK images) */
308
+
309
+ void
310
+ jsimd_h2v1_upsample_altivec (int max_v_samp_factor,
311
+ JDIMENSION output_width,
312
+ JSAMPARRAY input_data,
313
+ JSAMPARRAY *output_data_ptr)
314
+ {
315
+ JSAMPARRAY output_data = *output_data_ptr;
316
+ JSAMPROW inptr, outptr;
317
+ int inrow, incol;
318
+
319
+ __vector unsigned char in, inl, inh;
320
+
321
+ for (inrow = 0; inrow < max_v_samp_factor; inrow++) {
322
+ inptr = input_data[inrow];
323
+ outptr = output_data[inrow];
324
+
325
+ for (incol = (output_width + 31) & (~31); incol > 0;
326
+ incol -= 64, inptr += 32, outptr += 64) {
327
+
328
+ in = vec_ld(0, inptr);
329
+ inl = vec_mergeh(in, in);
330
+ inh = vec_mergel(in, in);
331
+
332
+ vec_st(inl, 0, outptr);
333
+ vec_st(inh, 16, outptr);
334
+
335
+ if (incol > 32) {
336
+ in = vec_ld(16, inptr);
337
+ inl = vec_mergeh(in, in);
338
+ inh = vec_mergel(in, in);
339
+
340
+ vec_st(inl, 32, outptr);
341
+ vec_st(inh, 48, outptr);
342
+ }
343
+ }
344
+ }
345
+ }
346
+
347
+
348
+ void
349
+ jsimd_h2v2_upsample_altivec (int max_v_samp_factor,
350
+ JDIMENSION output_width,
351
+ JSAMPARRAY input_data,
352
+ JSAMPARRAY *output_data_ptr)
353
+ {
354
+ JSAMPARRAY output_data = *output_data_ptr;
355
+ JSAMPROW inptr, outptr0, outptr1;
356
+ int inrow, outrow, incol;
357
+
358
+ __vector unsigned char in, inl, inh;
359
+
360
+ for (inrow = 0, outrow = 0; outrow < max_v_samp_factor; inrow++) {
361
+
362
+ inptr = input_data[inrow];
363
+ outptr0 = output_data[outrow++];
364
+ outptr1 = output_data[outrow++];
365
+
366
+ for (incol = (output_width + 31) & (~31); incol > 0;
367
+ incol -= 64, inptr += 32, outptr0 += 64, outptr1 += 64) {
368
+
369
+ in = vec_ld(0, inptr);
370
+ inl = vec_mergeh(in, in);
371
+ inh = vec_mergel(in, in);
372
+
373
+ vec_st(inl, 0, outptr0);
374
+ vec_st(inl, 0, outptr1);
375
+
376
+ vec_st(inh, 16, outptr0);
377
+ vec_st(inh, 16, outptr1);
378
+
379
+ if (incol > 32) {
380
+ in = vec_ld(16, inptr);
381
+ inl = vec_mergeh(in, in);
382
+ inh = vec_mergel(in, in);
383
+
384
+ vec_st(inl, 32, outptr0);
385
+ vec_st(inl, 32, outptr1);
386
+
387
+ vec_st(inh, 48, outptr0);
388
+ vec_st(inh, 48, outptr1);
389
+ }
390
+ }
391
+ }
392
+ }
@@ -0,0 +1,736 @@
1
+ ;
2
+ ; jdsample.asm - upsampling (MMX)
3
+ ;
4
+ ; Copyright 2009 Pierre Ossman <ossman@cendio.se> for Cendio AB
5
+ ;
6
+ ; Based on the x86 SIMD extension for IJG JPEG library
7
+ ; Copyright (C) 1999-2006, MIYASAKA Masaru.
8
+ ; For conditions of distribution and use, see copyright notice in jsimdext.inc
9
+ ;
10
+ ; This file should be assembled with NASM (Netwide Assembler),
11
+ ; can *not* be assembled with Microsoft's MASM or any compatible
12
+ ; assembler (including Borland's Turbo Assembler).
13
+ ; NASM is available from http://nasm.sourceforge.net/ or
14
+ ; http://sourceforge.net/project/showfiles.php?group_id=6208
15
+ ;
16
+ ; [TAB8]
17
+
18
+ %include "jsimdext.inc"
19
+
20
+ ; --------------------------------------------------------------------------
21
+ SECTION SEG_CONST
22
+
23
+ alignz 16
24
+ global EXTN(jconst_fancy_upsample_mmx)
25
+
26
+ EXTN(jconst_fancy_upsample_mmx):
27
+
28
+ PW_ONE times 4 dw 1
29
+ PW_TWO times 4 dw 2
30
+ PW_THREE times 4 dw 3
31
+ PW_SEVEN times 4 dw 7
32
+ PW_EIGHT times 4 dw 8
33
+
34
+ alignz 16
35
+
36
+ ; --------------------------------------------------------------------------
37
+ SECTION SEG_TEXT
38
+ BITS 32
39
+ ;
40
+ ; Fancy processing for the common case of 2:1 horizontal and 1:1 vertical.
41
+ ;
42
+ ; The upsampling algorithm is linear interpolation between pixel centers,
43
+ ; also known as a "triangle filter". This is a good compromise between
44
+ ; speed and visual quality. The centers of the output pixels are 1/4 and 3/4
45
+ ; of the way between input pixel centers.
46
+ ;
47
+ ; GLOBAL(void)
48
+ ; jsimd_h2v1_fancy_upsample_mmx (int max_v_samp_factor,
49
+ ; JDIMENSION downsampled_width,
50
+ ; JSAMPARRAY input_data,
51
+ ; JSAMPARRAY *output_data_ptr);
52
+ ;
53
+
54
+ %define max_v_samp(b) (b)+8 ; int max_v_samp_factor
55
+ %define downsamp_width(b) (b)+12 ; JDIMENSION downsampled_width
56
+ %define input_data(b) (b)+16 ; JSAMPARRAY input_data
57
+ %define output_data_ptr(b) (b)+20 ; JSAMPARRAY *output_data_ptr
58
+
59
+ align 16
60
+ global EXTN(jsimd_h2v1_fancy_upsample_mmx)
61
+
62
+ EXTN(jsimd_h2v1_fancy_upsample_mmx):
63
+ push ebp
64
+ mov ebp,esp
65
+ pushpic ebx
66
+ ; push ecx ; need not be preserved
67
+ ; push edx ; need not be preserved
68
+ push esi
69
+ push edi
70
+
71
+ get_GOT ebx ; get GOT address
72
+
73
+ mov eax, JDIMENSION [downsamp_width(ebp)] ; colctr
74
+ test eax,eax
75
+ jz near .return
76
+
77
+ mov ecx, INT [max_v_samp(ebp)] ; rowctr
78
+ test ecx,ecx
79
+ jz near .return
80
+
81
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
82
+ mov edi, POINTER [output_data_ptr(ebp)]
83
+ mov edi, JSAMPARRAY [edi] ; output_data
84
+ alignx 16,7
85
+ .rowloop:
86
+ push eax ; colctr
87
+ push edi
88
+ push esi
89
+
90
+ mov esi, JSAMPROW [esi] ; inptr
91
+ mov edi, JSAMPROW [edi] ; outptr
92
+
93
+ test eax, SIZEOF_MMWORD-1
94
+ jz short .skip
95
+ mov dl, JSAMPLE [esi+(eax-1)*SIZEOF_JSAMPLE]
96
+ mov JSAMPLE [esi+eax*SIZEOF_JSAMPLE], dl ; insert a dummy sample
97
+ .skip:
98
+ pxor mm0,mm0 ; mm0=(all 0's)
99
+ pcmpeqb mm7,mm7
100
+ psrlq mm7,(SIZEOF_MMWORD-1)*BYTE_BIT
101
+ pand mm7, MMWORD [esi+0*SIZEOF_MMWORD]
102
+
103
+ add eax, byte SIZEOF_MMWORD-1
104
+ and eax, byte -SIZEOF_MMWORD
105
+ cmp eax, byte SIZEOF_MMWORD
106
+ ja short .columnloop
107
+ alignx 16,7
108
+
109
+ .columnloop_last:
110
+ pcmpeqb mm6,mm6
111
+ psllq mm6,(SIZEOF_MMWORD-1)*BYTE_BIT
112
+ pand mm6, MMWORD [esi+0*SIZEOF_MMWORD]
113
+ jmp short .upsample
114
+ alignx 16,7
115
+
116
+ .columnloop:
117
+ movq mm6, MMWORD [esi+1*SIZEOF_MMWORD]
118
+ psllq mm6,(SIZEOF_MMWORD-1)*BYTE_BIT
119
+
120
+ .upsample:
121
+ movq mm1, MMWORD [esi+0*SIZEOF_MMWORD]
122
+ movq mm2,mm1
123
+ movq mm3,mm1 ; mm1=( 0 1 2 3 4 5 6 7)
124
+ psllq mm2,BYTE_BIT ; mm2=( - 0 1 2 3 4 5 6)
125
+ psrlq mm3,BYTE_BIT ; mm3=( 1 2 3 4 5 6 7 -)
126
+
127
+ por mm2,mm7 ; mm2=(-1 0 1 2 3 4 5 6)
128
+ por mm3,mm6 ; mm3=( 1 2 3 4 5 6 7 8)
129
+
130
+ movq mm7,mm1
131
+ psrlq mm7,(SIZEOF_MMWORD-1)*BYTE_BIT ; mm7=( 7 - - - - - - -)
132
+
133
+ movq mm4,mm1
134
+ punpcklbw mm1,mm0 ; mm1=( 0 1 2 3)
135
+ punpckhbw mm4,mm0 ; mm4=( 4 5 6 7)
136
+ movq mm5,mm2
137
+ punpcklbw mm2,mm0 ; mm2=(-1 0 1 2)
138
+ punpckhbw mm5,mm0 ; mm5=( 3 4 5 6)
139
+ movq mm6,mm3
140
+ punpcklbw mm3,mm0 ; mm3=( 1 2 3 4)
141
+ punpckhbw mm6,mm0 ; mm6=( 5 6 7 8)
142
+
143
+ pmullw mm1,[GOTOFF(ebx,PW_THREE)]
144
+ pmullw mm4,[GOTOFF(ebx,PW_THREE)]
145
+ paddw mm2,[GOTOFF(ebx,PW_ONE)]
146
+ paddw mm5,[GOTOFF(ebx,PW_ONE)]
147
+ paddw mm3,[GOTOFF(ebx,PW_TWO)]
148
+ paddw mm6,[GOTOFF(ebx,PW_TWO)]
149
+
150
+ paddw mm2,mm1
151
+ paddw mm5,mm4
152
+ psrlw mm2,2 ; mm2=OutLE=( 0 2 4 6)
153
+ psrlw mm5,2 ; mm5=OutHE=( 8 10 12 14)
154
+ paddw mm3,mm1
155
+ paddw mm6,mm4
156
+ psrlw mm3,2 ; mm3=OutLO=( 1 3 5 7)
157
+ psrlw mm6,2 ; mm6=OutHO=( 9 11 13 15)
158
+
159
+ psllw mm3,BYTE_BIT
160
+ psllw mm6,BYTE_BIT
161
+ por mm2,mm3 ; mm2=OutL=( 0 1 2 3 4 5 6 7)
162
+ por mm5,mm6 ; mm5=OutH=( 8 9 10 11 12 13 14 15)
163
+
164
+ movq MMWORD [edi+0*SIZEOF_MMWORD], mm2
165
+ movq MMWORD [edi+1*SIZEOF_MMWORD], mm5
166
+
167
+ sub eax, byte SIZEOF_MMWORD
168
+ add esi, byte 1*SIZEOF_MMWORD ; inptr
169
+ add edi, byte 2*SIZEOF_MMWORD ; outptr
170
+ cmp eax, byte SIZEOF_MMWORD
171
+ ja near .columnloop
172
+ test eax,eax
173
+ jnz near .columnloop_last
174
+
175
+ pop esi
176
+ pop edi
177
+ pop eax
178
+
179
+ add esi, byte SIZEOF_JSAMPROW ; input_data
180
+ add edi, byte SIZEOF_JSAMPROW ; output_data
181
+ dec ecx ; rowctr
182
+ jg near .rowloop
183
+
184
+ emms ; empty MMX state
185
+
186
+ .return:
187
+ pop edi
188
+ pop esi
189
+ ; pop edx ; need not be preserved
190
+ ; pop ecx ; need not be preserved
191
+ poppic ebx
192
+ pop ebp
193
+ ret
194
+
195
+ ; --------------------------------------------------------------------------
196
+ ;
197
+ ; Fancy processing for the common case of 2:1 horizontal and 2:1 vertical.
198
+ ; Again a triangle filter; see comments for h2v1 case, above.
199
+ ;
200
+ ; GLOBAL(void)
201
+ ; jsimd_h2v2_fancy_upsample_mmx (int max_v_samp_factor,
202
+ ; JDIMENSION downsampled_width,
203
+ ; JSAMPARRAY input_data,
204
+ ; JSAMPARRAY *output_data_ptr);
205
+ ;
206
+
207
+ %define max_v_samp(b) (b)+8 ; int max_v_samp_factor
208
+ %define downsamp_width(b) (b)+12 ; JDIMENSION downsampled_width
209
+ %define input_data(b) (b)+16 ; JSAMPARRAY input_data
210
+ %define output_data_ptr(b) (b)+20 ; JSAMPARRAY *output_data_ptr
211
+
212
+ %define original_ebp ebp+0
213
+ %define wk(i) ebp-(WK_NUM-(i))*SIZEOF_MMWORD ; mmword wk[WK_NUM]
214
+ %define WK_NUM 4
215
+ %define gotptr wk(0)-SIZEOF_POINTER ; void *gotptr
216
+
217
+ align 16
218
+ global EXTN(jsimd_h2v2_fancy_upsample_mmx)
219
+
220
+ EXTN(jsimd_h2v2_fancy_upsample_mmx):
221
+ push ebp
222
+ mov eax,esp ; eax = original ebp
223
+ sub esp, byte 4
224
+ and esp, byte (-SIZEOF_MMWORD) ; align to 64 bits
225
+ mov [esp],eax
226
+ mov ebp,esp ; ebp = aligned ebp
227
+ lea esp, [wk(0)]
228
+ pushpic eax ; make a room for GOT address
229
+ push ebx
230
+ ; push ecx ; need not be preserved
231
+ ; push edx ; need not be preserved
232
+ push esi
233
+ push edi
234
+
235
+ get_GOT ebx ; get GOT address
236
+ movpic POINTER [gotptr], ebx ; save GOT address
237
+
238
+ mov edx,eax ; edx = original ebp
239
+ mov eax, JDIMENSION [downsamp_width(edx)] ; colctr
240
+ test eax,eax
241
+ jz near .return
242
+
243
+ mov ecx, INT [max_v_samp(edx)] ; rowctr
244
+ test ecx,ecx
245
+ jz near .return
246
+
247
+ mov esi, JSAMPARRAY [input_data(edx)] ; input_data
248
+ mov edi, POINTER [output_data_ptr(edx)]
249
+ mov edi, JSAMPARRAY [edi] ; output_data
250
+ alignx 16,7
251
+ .rowloop:
252
+ push eax ; colctr
253
+ push ecx
254
+ push edi
255
+ push esi
256
+
257
+ mov ecx, JSAMPROW [esi-1*SIZEOF_JSAMPROW] ; inptr1(above)
258
+ mov ebx, JSAMPROW [esi+0*SIZEOF_JSAMPROW] ; inptr0
259
+ mov esi, JSAMPROW [esi+1*SIZEOF_JSAMPROW] ; inptr1(below)
260
+ mov edx, JSAMPROW [edi+0*SIZEOF_JSAMPROW] ; outptr0
261
+ mov edi, JSAMPROW [edi+1*SIZEOF_JSAMPROW] ; outptr1
262
+
263
+ test eax, SIZEOF_MMWORD-1
264
+ jz short .skip
265
+ push edx
266
+ mov dl, JSAMPLE [ecx+(eax-1)*SIZEOF_JSAMPLE]
267
+ mov JSAMPLE [ecx+eax*SIZEOF_JSAMPLE], dl
268
+ mov dl, JSAMPLE [ebx+(eax-1)*SIZEOF_JSAMPLE]
269
+ mov JSAMPLE [ebx+eax*SIZEOF_JSAMPLE], dl
270
+ mov dl, JSAMPLE [esi+(eax-1)*SIZEOF_JSAMPLE]
271
+ mov JSAMPLE [esi+eax*SIZEOF_JSAMPLE], dl ; insert a dummy sample
272
+ pop edx
273
+ .skip:
274
+ ; -- process the first column block
275
+
276
+ movq mm0, MMWORD [ebx+0*SIZEOF_MMWORD] ; mm0=row[ 0][0]
277
+ movq mm1, MMWORD [ecx+0*SIZEOF_MMWORD] ; mm1=row[-1][0]
278
+ movq mm2, MMWORD [esi+0*SIZEOF_MMWORD] ; mm2=row[+1][0]
279
+
280
+ pushpic ebx
281
+ movpic ebx, POINTER [gotptr] ; load GOT address
282
+
283
+ pxor mm3,mm3 ; mm3=(all 0's)
284
+ movq mm4,mm0
285
+ punpcklbw mm0,mm3 ; mm0=row[ 0][0]( 0 1 2 3)
286
+ punpckhbw mm4,mm3 ; mm4=row[ 0][0]( 4 5 6 7)
287
+ movq mm5,mm1
288
+ punpcklbw mm1,mm3 ; mm1=row[-1][0]( 0 1 2 3)
289
+ punpckhbw mm5,mm3 ; mm5=row[-1][0]( 4 5 6 7)
290
+ movq mm6,mm2
291
+ punpcklbw mm2,mm3 ; mm2=row[+1][0]( 0 1 2 3)
292
+ punpckhbw mm6,mm3 ; mm6=row[+1][0]( 4 5 6 7)
293
+
294
+ pmullw mm0,[GOTOFF(ebx,PW_THREE)]
295
+ pmullw mm4,[GOTOFF(ebx,PW_THREE)]
296
+
297
+ pcmpeqb mm7,mm7
298
+ psrlq mm7,(SIZEOF_MMWORD-2)*BYTE_BIT
299
+
300
+ paddw mm1,mm0 ; mm1=Int0L=( 0 1 2 3)
301
+ paddw mm5,mm4 ; mm5=Int0H=( 4 5 6 7)
302
+ paddw mm2,mm0 ; mm2=Int1L=( 0 1 2 3)
303
+ paddw mm6,mm4 ; mm6=Int1H=( 4 5 6 7)
304
+
305
+ movq MMWORD [edx+0*SIZEOF_MMWORD], mm1 ; temporarily save
306
+ movq MMWORD [edx+1*SIZEOF_MMWORD], mm5 ; the intermediate data
307
+ movq MMWORD [edi+0*SIZEOF_MMWORD], mm2
308
+ movq MMWORD [edi+1*SIZEOF_MMWORD], mm6
309
+
310
+ pand mm1,mm7 ; mm1=( 0 - - -)
311
+ pand mm2,mm7 ; mm2=( 0 - - -)
312
+
313
+ movq MMWORD [wk(0)], mm1
314
+ movq MMWORD [wk(1)], mm2
315
+
316
+ poppic ebx
317
+
318
+ add eax, byte SIZEOF_MMWORD-1
319
+ and eax, byte -SIZEOF_MMWORD
320
+ cmp eax, byte SIZEOF_MMWORD
321
+ ja short .columnloop
322
+ alignx 16,7
323
+
324
+ .columnloop_last:
325
+ ; -- process the last column block
326
+
327
+ pushpic ebx
328
+ movpic ebx, POINTER [gotptr] ; load GOT address
329
+
330
+ pcmpeqb mm1,mm1
331
+ psllq mm1,(SIZEOF_MMWORD-2)*BYTE_BIT
332
+ movq mm2,mm1
333
+
334
+ pand mm1, MMWORD [edx+1*SIZEOF_MMWORD] ; mm1=( - - - 7)
335
+ pand mm2, MMWORD [edi+1*SIZEOF_MMWORD] ; mm2=( - - - 7)
336
+
337
+ movq MMWORD [wk(2)], mm1
338
+ movq MMWORD [wk(3)], mm2
339
+
340
+ jmp short .upsample
341
+ alignx 16,7
342
+
343
+ .columnloop:
344
+ ; -- process the next column block
345
+
346
+ movq mm0, MMWORD [ebx+1*SIZEOF_MMWORD] ; mm0=row[ 0][1]
347
+ movq mm1, MMWORD [ecx+1*SIZEOF_MMWORD] ; mm1=row[-1][1]
348
+ movq mm2, MMWORD [esi+1*SIZEOF_MMWORD] ; mm2=row[+1][1]
349
+
350
+ pushpic ebx
351
+ movpic ebx, POINTER [gotptr] ; load GOT address
352
+
353
+ pxor mm3,mm3 ; mm3=(all 0's)
354
+ movq mm4,mm0
355
+ punpcklbw mm0,mm3 ; mm0=row[ 0][1]( 0 1 2 3)
356
+ punpckhbw mm4,mm3 ; mm4=row[ 0][1]( 4 5 6 7)
357
+ movq mm5,mm1
358
+ punpcklbw mm1,mm3 ; mm1=row[-1][1]( 0 1 2 3)
359
+ punpckhbw mm5,mm3 ; mm5=row[-1][1]( 4 5 6 7)
360
+ movq mm6,mm2
361
+ punpcklbw mm2,mm3 ; mm2=row[+1][1]( 0 1 2 3)
362
+ punpckhbw mm6,mm3 ; mm6=row[+1][1]( 4 5 6 7)
363
+
364
+ pmullw mm0,[GOTOFF(ebx,PW_THREE)]
365
+ pmullw mm4,[GOTOFF(ebx,PW_THREE)]
366
+
367
+ paddw mm1,mm0 ; mm1=Int0L=( 0 1 2 3)
368
+ paddw mm5,mm4 ; mm5=Int0H=( 4 5 6 7)
369
+ paddw mm2,mm0 ; mm2=Int1L=( 0 1 2 3)
370
+ paddw mm6,mm4 ; mm6=Int1H=( 4 5 6 7)
371
+
372
+ movq MMWORD [edx+2*SIZEOF_MMWORD], mm1 ; temporarily save
373
+ movq MMWORD [edx+3*SIZEOF_MMWORD], mm5 ; the intermediate data
374
+ movq MMWORD [edi+2*SIZEOF_MMWORD], mm2
375
+ movq MMWORD [edi+3*SIZEOF_MMWORD], mm6
376
+
377
+ psllq mm1,(SIZEOF_MMWORD-2)*BYTE_BIT ; mm1=( - - - 0)
378
+ psllq mm2,(SIZEOF_MMWORD-2)*BYTE_BIT ; mm2=( - - - 0)
379
+
380
+ movq MMWORD [wk(2)], mm1
381
+ movq MMWORD [wk(3)], mm2
382
+
383
+ .upsample:
384
+ ; -- process the upper row
385
+
386
+ movq mm7, MMWORD [edx+0*SIZEOF_MMWORD] ; mm7=Int0L=( 0 1 2 3)
387
+ movq mm3, MMWORD [edx+1*SIZEOF_MMWORD] ; mm3=Int0H=( 4 5 6 7)
388
+
389
+ movq mm0,mm7
390
+ movq mm4,mm3
391
+ psrlq mm0,2*BYTE_BIT ; mm0=( 1 2 3 -)
392
+ psllq mm4,(SIZEOF_MMWORD-2)*BYTE_BIT ; mm4=( - - - 4)
393
+ movq mm5,mm7
394
+ movq mm6,mm3
395
+ psrlq mm5,(SIZEOF_MMWORD-2)*BYTE_BIT ; mm5=( 3 - - -)
396
+ psllq mm6,2*BYTE_BIT ; mm6=( - 4 5 6)
397
+
398
+ por mm0,mm4 ; mm0=( 1 2 3 4)
399
+ por mm5,mm6 ; mm5=( 3 4 5 6)
400
+
401
+ movq mm1,mm7
402
+ movq mm2,mm3
403
+ psllq mm1,2*BYTE_BIT ; mm1=( - 0 1 2)
404
+ psrlq mm2,2*BYTE_BIT ; mm2=( 5 6 7 -)
405
+ movq mm4,mm3
406
+ psrlq mm4,(SIZEOF_MMWORD-2)*BYTE_BIT ; mm4=( 7 - - -)
407
+
408
+ por mm1, MMWORD [wk(0)] ; mm1=(-1 0 1 2)
409
+ por mm2, MMWORD [wk(2)] ; mm2=( 5 6 7 8)
410
+
411
+ movq MMWORD [wk(0)], mm4
412
+
413
+ pmullw mm7,[GOTOFF(ebx,PW_THREE)]
414
+ pmullw mm3,[GOTOFF(ebx,PW_THREE)]
415
+ paddw mm1,[GOTOFF(ebx,PW_EIGHT)]
416
+ paddw mm5,[GOTOFF(ebx,PW_EIGHT)]
417
+ paddw mm0,[GOTOFF(ebx,PW_SEVEN)]
418
+ paddw mm2,[GOTOFF(ebx,PW_SEVEN)]
419
+
420
+ paddw mm1,mm7
421
+ paddw mm5,mm3
422
+ psrlw mm1,4 ; mm1=Out0LE=( 0 2 4 6)
423
+ psrlw mm5,4 ; mm5=Out0HE=( 8 10 12 14)
424
+ paddw mm0,mm7
425
+ paddw mm2,mm3
426
+ psrlw mm0,4 ; mm0=Out0LO=( 1 3 5 7)
427
+ psrlw mm2,4 ; mm2=Out0HO=( 9 11 13 15)
428
+
429
+ psllw mm0,BYTE_BIT
430
+ psllw mm2,BYTE_BIT
431
+ por mm1,mm0 ; mm1=Out0L=( 0 1 2 3 4 5 6 7)
432
+ por mm5,mm2 ; mm5=Out0H=( 8 9 10 11 12 13 14 15)
433
+
434
+ movq MMWORD [edx+0*SIZEOF_MMWORD], mm1
435
+ movq MMWORD [edx+1*SIZEOF_MMWORD], mm5
436
+
437
+ ; -- process the lower row
438
+
439
+ movq mm6, MMWORD [edi+0*SIZEOF_MMWORD] ; mm6=Int1L=( 0 1 2 3)
440
+ movq mm4, MMWORD [edi+1*SIZEOF_MMWORD] ; mm4=Int1H=( 4 5 6 7)
441
+
442
+ movq mm7,mm6
443
+ movq mm3,mm4
444
+ psrlq mm7,2*BYTE_BIT ; mm7=( 1 2 3 -)
445
+ psllq mm3,(SIZEOF_MMWORD-2)*BYTE_BIT ; mm3=( - - - 4)
446
+ movq mm0,mm6
447
+ movq mm2,mm4
448
+ psrlq mm0,(SIZEOF_MMWORD-2)*BYTE_BIT ; mm0=( 3 - - -)
449
+ psllq mm2,2*BYTE_BIT ; mm2=( - 4 5 6)
450
+
451
+ por mm7,mm3 ; mm7=( 1 2 3 4)
452
+ por mm0,mm2 ; mm0=( 3 4 5 6)
453
+
454
+ movq mm1,mm6
455
+ movq mm5,mm4
456
+ psllq mm1,2*BYTE_BIT ; mm1=( - 0 1 2)
457
+ psrlq mm5,2*BYTE_BIT ; mm5=( 5 6 7 -)
458
+ movq mm3,mm4
459
+ psrlq mm3,(SIZEOF_MMWORD-2)*BYTE_BIT ; mm3=( 7 - - -)
460
+
461
+ por mm1, MMWORD [wk(1)] ; mm1=(-1 0 1 2)
462
+ por mm5, MMWORD [wk(3)] ; mm5=( 5 6 7 8)
463
+
464
+ movq MMWORD [wk(1)], mm3
465
+
466
+ pmullw mm6,[GOTOFF(ebx,PW_THREE)]
467
+ pmullw mm4,[GOTOFF(ebx,PW_THREE)]
468
+ paddw mm1,[GOTOFF(ebx,PW_EIGHT)]
469
+ paddw mm0,[GOTOFF(ebx,PW_EIGHT)]
470
+ paddw mm7,[GOTOFF(ebx,PW_SEVEN)]
471
+ paddw mm5,[GOTOFF(ebx,PW_SEVEN)]
472
+
473
+ paddw mm1,mm6
474
+ paddw mm0,mm4
475
+ psrlw mm1,4 ; mm1=Out1LE=( 0 2 4 6)
476
+ psrlw mm0,4 ; mm0=Out1HE=( 8 10 12 14)
477
+ paddw mm7,mm6
478
+ paddw mm5,mm4
479
+ psrlw mm7,4 ; mm7=Out1LO=( 1 3 5 7)
480
+ psrlw mm5,4 ; mm5=Out1HO=( 9 11 13 15)
481
+
482
+ psllw mm7,BYTE_BIT
483
+ psllw mm5,BYTE_BIT
484
+ por mm1,mm7 ; mm1=Out1L=( 0 1 2 3 4 5 6 7)
485
+ por mm0,mm5 ; mm0=Out1H=( 8 9 10 11 12 13 14 15)
486
+
487
+ movq MMWORD [edi+0*SIZEOF_MMWORD], mm1
488
+ movq MMWORD [edi+1*SIZEOF_MMWORD], mm0
489
+
490
+ poppic ebx
491
+
492
+ sub eax, byte SIZEOF_MMWORD
493
+ add ecx, byte 1*SIZEOF_MMWORD ; inptr1(above)
494
+ add ebx, byte 1*SIZEOF_MMWORD ; inptr0
495
+ add esi, byte 1*SIZEOF_MMWORD ; inptr1(below)
496
+ add edx, byte 2*SIZEOF_MMWORD ; outptr0
497
+ add edi, byte 2*SIZEOF_MMWORD ; outptr1
498
+ cmp eax, byte SIZEOF_MMWORD
499
+ ja near .columnloop
500
+ test eax,eax
501
+ jnz near .columnloop_last
502
+
503
+ pop esi
504
+ pop edi
505
+ pop ecx
506
+ pop eax
507
+
508
+ add esi, byte 1*SIZEOF_JSAMPROW ; input_data
509
+ add edi, byte 2*SIZEOF_JSAMPROW ; output_data
510
+ sub ecx, byte 2 ; rowctr
511
+ jg near .rowloop
512
+
513
+ emms ; empty MMX state
514
+
515
+ .return:
516
+ pop edi
517
+ pop esi
518
+ ; pop edx ; need not be preserved
519
+ ; pop ecx ; need not be preserved
520
+ pop ebx
521
+ mov esp,ebp ; esp <- aligned ebp
522
+ pop esp ; esp <- original ebp
523
+ pop ebp
524
+ ret
525
+
526
+ ; --------------------------------------------------------------------------
527
+ ;
528
+ ; Fast processing for the common case of 2:1 horizontal and 1:1 vertical.
529
+ ; It's still a box filter.
530
+ ;
531
+ ; GLOBAL(void)
532
+ ; jsimd_h2v1_upsample_mmx (int max_v_samp_factor,
533
+ ; JDIMENSION output_width,
534
+ ; JSAMPARRAY input_data,
535
+ ; JSAMPARRAY *output_data_ptr);
536
+ ;
537
+
538
+ %define max_v_samp(b) (b)+8 ; int max_v_samp_factor
539
+ %define output_width(b) (b)+12 ; JDIMENSION output_width
540
+ %define input_data(b) (b)+16 ; JSAMPARRAY input_data
541
+ %define output_data_ptr(b) (b)+20 ; JSAMPARRAY *output_data_ptr
542
+
543
+ align 16
544
+ global EXTN(jsimd_h2v1_upsample_mmx)
545
+
546
+ EXTN(jsimd_h2v1_upsample_mmx):
547
+ push ebp
548
+ mov ebp,esp
549
+ ; push ebx ; unused
550
+ ; push ecx ; need not be preserved
551
+ ; push edx ; need not be preserved
552
+ push esi
553
+ push edi
554
+
555
+ mov edx, JDIMENSION [output_width(ebp)]
556
+ add edx, byte (2*SIZEOF_MMWORD)-1
557
+ and edx, byte -(2*SIZEOF_MMWORD)
558
+ jz short .return
559
+
560
+ mov ecx, INT [max_v_samp(ebp)] ; rowctr
561
+ test ecx,ecx
562
+ jz short .return
563
+
564
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
565
+ mov edi, POINTER [output_data_ptr(ebp)]
566
+ mov edi, JSAMPARRAY [edi] ; output_data
567
+ alignx 16,7
568
+ .rowloop:
569
+ push edi
570
+ push esi
571
+
572
+ mov esi, JSAMPROW [esi] ; inptr
573
+ mov edi, JSAMPROW [edi] ; outptr
574
+ mov eax,edx ; colctr
575
+ alignx 16,7
576
+ .columnloop:
577
+
578
+ movq mm0, MMWORD [esi+0*SIZEOF_MMWORD]
579
+
580
+ movq mm1,mm0
581
+ punpcklbw mm0,mm0
582
+ punpckhbw mm1,mm1
583
+
584
+ movq MMWORD [edi+0*SIZEOF_MMWORD], mm0
585
+ movq MMWORD [edi+1*SIZEOF_MMWORD], mm1
586
+
587
+ sub eax, byte 2*SIZEOF_MMWORD
588
+ jz short .nextrow
589
+
590
+ movq mm2, MMWORD [esi+1*SIZEOF_MMWORD]
591
+
592
+ movq mm3,mm2
593
+ punpcklbw mm2,mm2
594
+ punpckhbw mm3,mm3
595
+
596
+ movq MMWORD [edi+2*SIZEOF_MMWORD], mm2
597
+ movq MMWORD [edi+3*SIZEOF_MMWORD], mm3
598
+
599
+ sub eax, byte 2*SIZEOF_MMWORD
600
+ jz short .nextrow
601
+
602
+ add esi, byte 2*SIZEOF_MMWORD ; inptr
603
+ add edi, byte 4*SIZEOF_MMWORD ; outptr
604
+ jmp short .columnloop
605
+ alignx 16,7
606
+
607
+ .nextrow:
608
+ pop esi
609
+ pop edi
610
+
611
+ add esi, byte SIZEOF_JSAMPROW ; input_data
612
+ add edi, byte SIZEOF_JSAMPROW ; output_data
613
+ dec ecx ; rowctr
614
+ jg short .rowloop
615
+
616
+ emms ; empty MMX state
617
+
618
+ .return:
619
+ pop edi
620
+ pop esi
621
+ ; pop edx ; need not be preserved
622
+ ; pop ecx ; need not be preserved
623
+ ; pop ebx ; unused
624
+ pop ebp
625
+ ret
626
+
627
+ ; --------------------------------------------------------------------------
628
+ ;
629
+ ; Fast processing for the common case of 2:1 horizontal and 2:1 vertical.
630
+ ; It's still a box filter.
631
+ ;
632
+ ; GLOBAL(void)
633
+ ; jsimd_h2v2_upsample_mmx (int max_v_samp_factor,
634
+ ; JDIMENSION output_width,
635
+ ; JSAMPARRAY input_data,
636
+ ; JSAMPARRAY *output_data_ptr);
637
+ ;
638
+
639
+ %define max_v_samp(b) (b)+8 ; int max_v_samp_factor
640
+ %define output_width(b) (b)+12 ; JDIMENSION output_width
641
+ %define input_data(b) (b)+16 ; JSAMPARRAY input_data
642
+ %define output_data_ptr(b) (b)+20 ; JSAMPARRAY *output_data_ptr
643
+
644
+ align 16
645
+ global EXTN(jsimd_h2v2_upsample_mmx)
646
+
647
+ EXTN(jsimd_h2v2_upsample_mmx):
648
+ push ebp
649
+ mov ebp,esp
650
+ push ebx
651
+ ; push ecx ; need not be preserved
652
+ ; push edx ; need not be preserved
653
+ push esi
654
+ push edi
655
+
656
+ mov edx, JDIMENSION [output_width(ebp)]
657
+ add edx, byte (2*SIZEOF_MMWORD)-1
658
+ and edx, byte -(2*SIZEOF_MMWORD)
659
+ jz near .return
660
+
661
+ mov ecx, INT [max_v_samp(ebp)] ; rowctr
662
+ test ecx,ecx
663
+ jz short .return
664
+
665
+ mov esi, JSAMPARRAY [input_data(ebp)] ; input_data
666
+ mov edi, POINTER [output_data_ptr(ebp)]
667
+ mov edi, JSAMPARRAY [edi] ; output_data
668
+ alignx 16,7
669
+ .rowloop:
670
+ push edi
671
+ push esi
672
+
673
+ mov esi, JSAMPROW [esi] ; inptr
674
+ mov ebx, JSAMPROW [edi+0*SIZEOF_JSAMPROW] ; outptr0
675
+ mov edi, JSAMPROW [edi+1*SIZEOF_JSAMPROW] ; outptr1
676
+ mov eax,edx ; colctr
677
+ alignx 16,7
678
+ .columnloop:
679
+
680
+ movq mm0, MMWORD [esi+0*SIZEOF_MMWORD]
681
+
682
+ movq mm1,mm0
683
+ punpcklbw mm0,mm0
684
+ punpckhbw mm1,mm1
685
+
686
+ movq MMWORD [ebx+0*SIZEOF_MMWORD], mm0
687
+ movq MMWORD [ebx+1*SIZEOF_MMWORD], mm1
688
+ movq MMWORD [edi+0*SIZEOF_MMWORD], mm0
689
+ movq MMWORD [edi+1*SIZEOF_MMWORD], mm1
690
+
691
+ sub eax, byte 2*SIZEOF_MMWORD
692
+ jz short .nextrow
693
+
694
+ movq mm2, MMWORD [esi+1*SIZEOF_MMWORD]
695
+
696
+ movq mm3,mm2
697
+ punpcklbw mm2,mm2
698
+ punpckhbw mm3,mm3
699
+
700
+ movq MMWORD [ebx+2*SIZEOF_MMWORD], mm2
701
+ movq MMWORD [ebx+3*SIZEOF_MMWORD], mm3
702
+ movq MMWORD [edi+2*SIZEOF_MMWORD], mm2
703
+ movq MMWORD [edi+3*SIZEOF_MMWORD], mm3
704
+
705
+ sub eax, byte 2*SIZEOF_MMWORD
706
+ jz short .nextrow
707
+
708
+ add esi, byte 2*SIZEOF_MMWORD ; inptr
709
+ add ebx, byte 4*SIZEOF_MMWORD ; outptr0
710
+ add edi, byte 4*SIZEOF_MMWORD ; outptr1
711
+ jmp short .columnloop
712
+ alignx 16,7
713
+
714
+ .nextrow:
715
+ pop esi
716
+ pop edi
717
+
718
+ add esi, byte 1*SIZEOF_JSAMPROW ; input_data
719
+ add edi, byte 2*SIZEOF_JSAMPROW ; output_data
720
+ sub ecx, byte 2 ; rowctr
721
+ jg short .rowloop
722
+
723
+ emms ; empty MMX state
724
+
725
+ .return:
726
+ pop edi
727
+ pop esi
728
+ ; pop edx ; need not be preserved
729
+ ; pop ecx ; need not be preserved
730
+ pop ebx
731
+ pop ebp
732
+ ret
733
+
734
+ ; For some reason, the OS X linker does not honor the request to align the
735
+ ; segment unless we do this.
736
+ align 16