image_pack 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (319) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG.md +18 -0
  3. data/LICENSE.txt +21 -0
  4. data/README.md +140 -0
  5. data/THIRD_PARTY_NOTICES.md +8 -0
  6. data/ext/image_pack/extconf.rb +515 -0
  7. data/ext/image_pack/image_pack.c +1618 -0
  8. data/ext/image_pack/vendor/.vendored +1 -0
  9. data/ext/image_pack/vendor/mozjpeg/BUILDING.txt +902 -0
  10. data/ext/image_pack/vendor/mozjpeg/CMakeLists.txt +1593 -0
  11. data/ext/image_pack/vendor/mozjpeg/LICENSE.md +132 -0
  12. data/ext/image_pack/vendor/mozjpeg/README-mozilla.txt +194 -0
  13. data/ext/image_pack/vendor/mozjpeg/README-turbo.txt +346 -0
  14. data/ext/image_pack/vendor/mozjpeg/README.ijg +258 -0
  15. data/ext/image_pack/vendor/mozjpeg/README.md +29 -0
  16. data/ext/image_pack/vendor/mozjpeg/cderror.h +128 -0
  17. data/ext/image_pack/vendor/mozjpeg/cdjpeg.c +156 -0
  18. data/ext/image_pack/vendor/mozjpeg/cdjpeg.h +171 -0
  19. data/ext/image_pack/vendor/mozjpeg/cjpeg.c +961 -0
  20. data/ext/image_pack/vendor/mozjpeg/cmyk.h +60 -0
  21. data/ext/image_pack/vendor/mozjpeg/coderules.txt +78 -0
  22. data/ext/image_pack/vendor/mozjpeg/croptest.in +95 -0
  23. data/ext/image_pack/vendor/mozjpeg/djpeg.c +855 -0
  24. data/ext/image_pack/vendor/mozjpeg/example.txt +464 -0
  25. data/ext/image_pack/vendor/mozjpeg/jaricom.c +157 -0
  26. data/ext/image_pack/vendor/mozjpeg/jcapimin.c +307 -0
  27. data/ext/image_pack/vendor/mozjpeg/jcapistd.c +168 -0
  28. data/ext/image_pack/vendor/mozjpeg/jcarith.c +972 -0
  29. data/ext/image_pack/vendor/mozjpeg/jccoefct.c +609 -0
  30. data/ext/image_pack/vendor/mozjpeg/jccolext.c +144 -0
  31. data/ext/image_pack/vendor/mozjpeg/jccolor.c +721 -0
  32. data/ext/image_pack/vendor/mozjpeg/jcdctmgr.c +1776 -0
  33. data/ext/image_pack/vendor/mozjpeg/jcext.c +219 -0
  34. data/ext/image_pack/vendor/mozjpeg/jchuff.c +1146 -0
  35. data/ext/image_pack/vendor/mozjpeg/jchuff.h +57 -0
  36. data/ext/image_pack/vendor/mozjpeg/jcicc.c +105 -0
  37. data/ext/image_pack/vendor/mozjpeg/jcinit.c +82 -0
  38. data/ext/image_pack/vendor/mozjpeg/jcmainct.c +162 -0
  39. data/ext/image_pack/vendor/mozjpeg/jcmarker.c +844 -0
  40. data/ext/image_pack/vendor/mozjpeg/jcmaster.c +958 -0
  41. data/ext/image_pack/vendor/mozjpeg/jcmaster.h +56 -0
  42. data/ext/image_pack/vendor/mozjpeg/jcomapi.c +109 -0
  43. data/ext/image_pack/vendor/mozjpeg/jconfig.h.in +37 -0
  44. data/ext/image_pack/vendor/mozjpeg/jconfig.txt +93 -0
  45. data/ext/image_pack/vendor/mozjpeg/jconfigint.h.in +44 -0
  46. data/ext/image_pack/vendor/mozjpeg/jcparam.c +991 -0
  47. data/ext/image_pack/vendor/mozjpeg/jcphuff.c +1123 -0
  48. data/ext/image_pack/vendor/mozjpeg/jcprepct.c +351 -0
  49. data/ext/image_pack/vendor/mozjpeg/jcsample.c +522 -0
  50. data/ext/image_pack/vendor/mozjpeg/jcstest.c +126 -0
  51. data/ext/image_pack/vendor/mozjpeg/jctrans.c +408 -0
  52. data/ext/image_pack/vendor/mozjpeg/jdapimin.c +407 -0
  53. data/ext/image_pack/vendor/mozjpeg/jdapistd.c +691 -0
  54. data/ext/image_pack/vendor/mozjpeg/jdarith.c +782 -0
  55. data/ext/image_pack/vendor/mozjpeg/jdatadst-tj.c +198 -0
  56. data/ext/image_pack/vendor/mozjpeg/jdatadst.c +299 -0
  57. data/ext/image_pack/vendor/mozjpeg/jdatasrc-tj.c +194 -0
  58. data/ext/image_pack/vendor/mozjpeg/jdatasrc.c +295 -0
  59. data/ext/image_pack/vendor/mozjpeg/jdcoefct.c +881 -0
  60. data/ext/image_pack/vendor/mozjpeg/jdcoefct.h +83 -0
  61. data/ext/image_pack/vendor/mozjpeg/jdcol565.c +384 -0
  62. data/ext/image_pack/vendor/mozjpeg/jdcolext.c +141 -0
  63. data/ext/image_pack/vendor/mozjpeg/jdcolor.c +881 -0
  64. data/ext/image_pack/vendor/mozjpeg/jdct.h +208 -0
  65. data/ext/image_pack/vendor/mozjpeg/jddctmgr.c +367 -0
  66. data/ext/image_pack/vendor/mozjpeg/jdhuff.c +834 -0
  67. data/ext/image_pack/vendor/mozjpeg/jdhuff.h +247 -0
  68. data/ext/image_pack/vendor/mozjpeg/jdicc.c +167 -0
  69. data/ext/image_pack/vendor/mozjpeg/jdinput.c +408 -0
  70. data/ext/image_pack/vendor/mozjpeg/jdmainct.c +460 -0
  71. data/ext/image_pack/vendor/mozjpeg/jdmainct.h +71 -0
  72. data/ext/image_pack/vendor/mozjpeg/jdmarker.c +1374 -0
  73. data/ext/image_pack/vendor/mozjpeg/jdmaster.c +727 -0
  74. data/ext/image_pack/vendor/mozjpeg/jdmaster.h +33 -0
  75. data/ext/image_pack/vendor/mozjpeg/jdmerge.c +587 -0
  76. data/ext/image_pack/vendor/mozjpeg/jdmerge.h +47 -0
  77. data/ext/image_pack/vendor/mozjpeg/jdmrg565.c +354 -0
  78. data/ext/image_pack/vendor/mozjpeg/jdmrgext.c +184 -0
  79. data/ext/image_pack/vendor/mozjpeg/jdphuff.c +679 -0
  80. data/ext/image_pack/vendor/mozjpeg/jdpostct.c +294 -0
  81. data/ext/image_pack/vendor/mozjpeg/jdsample.c +524 -0
  82. data/ext/image_pack/vendor/mozjpeg/jdsample.h +50 -0
  83. data/ext/image_pack/vendor/mozjpeg/jdtrans.c +156 -0
  84. data/ext/image_pack/vendor/mozjpeg/jerror.c +251 -0
  85. data/ext/image_pack/vendor/mozjpeg/jerror.h +335 -0
  86. data/ext/image_pack/vendor/mozjpeg/jfdctflt.c +169 -0
  87. data/ext/image_pack/vendor/mozjpeg/jfdctfst.c +227 -0
  88. data/ext/image_pack/vendor/mozjpeg/jfdctint.c +288 -0
  89. data/ext/image_pack/vendor/mozjpeg/jidctflt.c +240 -0
  90. data/ext/image_pack/vendor/mozjpeg/jidctfst.c +371 -0
  91. data/ext/image_pack/vendor/mozjpeg/jidctint.c +2627 -0
  92. data/ext/image_pack/vendor/mozjpeg/jidctred.c +409 -0
  93. data/ext/image_pack/vendor/mozjpeg/jinclude.h +147 -0
  94. data/ext/image_pack/vendor/mozjpeg/jmemmgr.c +1180 -0
  95. data/ext/image_pack/vendor/mozjpeg/jmemnobs.c +110 -0
  96. data/ext/image_pack/vendor/mozjpeg/jmemsys.h +178 -0
  97. data/ext/image_pack/vendor/mozjpeg/jmorecfg.h +382 -0
  98. data/ext/image_pack/vendor/mozjpeg/jpeg_nbits_table.h +4098 -0
  99. data/ext/image_pack/vendor/mozjpeg/jpegcomp.h +32 -0
  100. data/ext/image_pack/vendor/mozjpeg/jpegint.h +453 -0
  101. data/ext/image_pack/vendor/mozjpeg/jpeglib.h +1211 -0
  102. data/ext/image_pack/vendor/mozjpeg/jpegtran.c +827 -0
  103. data/ext/image_pack/vendor/mozjpeg/jpegyuv.c +172 -0
  104. data/ext/image_pack/vendor/mozjpeg/jquant1.c +856 -0
  105. data/ext/image_pack/vendor/mozjpeg/jquant2.c +1286 -0
  106. data/ext/image_pack/vendor/mozjpeg/jsimd.h +123 -0
  107. data/ext/image_pack/vendor/mozjpeg/jsimd_none.c +431 -0
  108. data/ext/image_pack/vendor/mozjpeg/jsimddct.h +70 -0
  109. data/ext/image_pack/vendor/mozjpeg/jstdhuff.c +144 -0
  110. data/ext/image_pack/vendor/mozjpeg/jutils.c +133 -0
  111. data/ext/image_pack/vendor/mozjpeg/jversion.h.in +56 -0
  112. data/ext/image_pack/vendor/mozjpeg/libjpeg.map.in +11 -0
  113. data/ext/image_pack/vendor/mozjpeg/libjpeg.txt +3150 -0
  114. data/ext/image_pack/vendor/mozjpeg/rdbmp.c +690 -0
  115. data/ext/image_pack/vendor/mozjpeg/rdcolmap.c +253 -0
  116. data/ext/image_pack/vendor/mozjpeg/rdgif.c +720 -0
  117. data/ext/image_pack/vendor/mozjpeg/rdjpeg.c +160 -0
  118. data/ext/image_pack/vendor/mozjpeg/rdjpgcom.c +494 -0
  119. data/ext/image_pack/vendor/mozjpeg/rdpng.c +194 -0
  120. data/ext/image_pack/vendor/mozjpeg/rdppm.c +781 -0
  121. data/ext/image_pack/vendor/mozjpeg/rdswitch.c +642 -0
  122. data/ext/image_pack/vendor/mozjpeg/rdtarga.c +508 -0
  123. data/ext/image_pack/vendor/mozjpeg/simd/arm/aarch32/jccolext-neon.c +148 -0
  124. data/ext/image_pack/vendor/mozjpeg/simd/arm/aarch32/jchuff-neon.c +334 -0
  125. data/ext/image_pack/vendor/mozjpeg/simd/arm/aarch32/jsimd.c +976 -0
  126. data/ext/image_pack/vendor/mozjpeg/simd/arm/aarch32/jsimd_neon.S +1200 -0
  127. data/ext/image_pack/vendor/mozjpeg/simd/arm/aarch64/jccolext-neon.c +316 -0
  128. data/ext/image_pack/vendor/mozjpeg/simd/arm/aarch64/jchuff-neon.c +411 -0
  129. data/ext/image_pack/vendor/mozjpeg/simd/arm/aarch64/jsimd.c +1053 -0
  130. data/ext/image_pack/vendor/mozjpeg/simd/arm/aarch64/jsimd_neon.S +2254 -0
  131. data/ext/image_pack/vendor/mozjpeg/simd/arm/align.h +28 -0
  132. data/ext/image_pack/vendor/mozjpeg/simd/arm/jccolor-neon.c +160 -0
  133. data/ext/image_pack/vendor/mozjpeg/simd/arm/jcgray-neon.c +120 -0
  134. data/ext/image_pack/vendor/mozjpeg/simd/arm/jcgryext-neon.c +106 -0
  135. data/ext/image_pack/vendor/mozjpeg/simd/arm/jchuff.h +131 -0
  136. data/ext/image_pack/vendor/mozjpeg/simd/arm/jcphuff-neon.c +623 -0
  137. data/ext/image_pack/vendor/mozjpeg/simd/arm/jcsample-neon.c +192 -0
  138. data/ext/image_pack/vendor/mozjpeg/simd/arm/jdcolext-neon.c +374 -0
  139. data/ext/image_pack/vendor/mozjpeg/simd/arm/jdcolor-neon.c +141 -0
  140. data/ext/image_pack/vendor/mozjpeg/simd/arm/jdmerge-neon.c +144 -0
  141. data/ext/image_pack/vendor/mozjpeg/simd/arm/jdmrgext-neon.c +723 -0
  142. data/ext/image_pack/vendor/mozjpeg/simd/arm/jdsample-neon.c +569 -0
  143. data/ext/image_pack/vendor/mozjpeg/simd/arm/jfdctfst-neon.c +214 -0
  144. data/ext/image_pack/vendor/mozjpeg/simd/arm/jfdctint-neon.c +376 -0
  145. data/ext/image_pack/vendor/mozjpeg/simd/arm/jidctfst-neon.c +472 -0
  146. data/ext/image_pack/vendor/mozjpeg/simd/arm/jidctint-neon.c +801 -0
  147. data/ext/image_pack/vendor/mozjpeg/simd/arm/jidctred-neon.c +486 -0
  148. data/ext/image_pack/vendor/mozjpeg/simd/arm/jquanti-neon.c +193 -0
  149. data/ext/image_pack/vendor/mozjpeg/simd/arm/neon-compat.h +26 -0
  150. data/ext/image_pack/vendor/mozjpeg/simd/arm/neon-compat.h.in +37 -0
  151. data/ext/image_pack/vendor/mozjpeg/simd/i386/jccolext-avx2.asm +578 -0
  152. data/ext/image_pack/vendor/mozjpeg/simd/i386/jccolext-mmx.asm +476 -0
  153. data/ext/image_pack/vendor/mozjpeg/simd/i386/jccolext-sse2.asm +503 -0
  154. data/ext/image_pack/vendor/mozjpeg/simd/i386/jccolor-avx2.asm +121 -0
  155. data/ext/image_pack/vendor/mozjpeg/simd/i386/jccolor-mmx.asm +121 -0
  156. data/ext/image_pack/vendor/mozjpeg/simd/i386/jccolor-sse2.asm +120 -0
  157. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcgray-avx2.asm +113 -0
  158. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcgray-mmx.asm +113 -0
  159. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcgray-sse2.asm +112 -0
  160. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcgryext-avx2.asm +457 -0
  161. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcgryext-mmx.asm +355 -0
  162. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcgryext-sse2.asm +382 -0
  163. data/ext/image_pack/vendor/mozjpeg/simd/i386/jchuff-sse2.asm +761 -0
  164. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcphuff-sse2.asm +662 -0
  165. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcsample-avx2.asm +388 -0
  166. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcsample-mmx.asm +324 -0
  167. data/ext/image_pack/vendor/mozjpeg/simd/i386/jcsample-sse2.asm +351 -0
  168. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdcolext-avx2.asm +515 -0
  169. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdcolext-mmx.asm +404 -0
  170. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdcolext-sse2.asm +458 -0
  171. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdcolor-avx2.asm +118 -0
  172. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdcolor-mmx.asm +117 -0
  173. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdcolor-sse2.asm +117 -0
  174. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdmerge-avx2.asm +136 -0
  175. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdmerge-mmx.asm +123 -0
  176. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdmerge-sse2.asm +135 -0
  177. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdmrgext-avx2.asm +575 -0
  178. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdmrgext-mmx.asm +460 -0
  179. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdmrgext-sse2.asm +517 -0
  180. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdsample-avx2.asm +760 -0
  181. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdsample-mmx.asm +731 -0
  182. data/ext/image_pack/vendor/mozjpeg/simd/i386/jdsample-sse2.asm +724 -0
  183. data/ext/image_pack/vendor/mozjpeg/simd/i386/jfdctflt-3dn.asm +318 -0
  184. data/ext/image_pack/vendor/mozjpeg/simd/i386/jfdctflt-sse.asm +369 -0
  185. data/ext/image_pack/vendor/mozjpeg/simd/i386/jfdctfst-mmx.asm +395 -0
  186. data/ext/image_pack/vendor/mozjpeg/simd/i386/jfdctfst-sse2.asm +403 -0
  187. data/ext/image_pack/vendor/mozjpeg/simd/i386/jfdctint-avx2.asm +331 -0
  188. data/ext/image_pack/vendor/mozjpeg/simd/i386/jfdctint-mmx.asm +620 -0
  189. data/ext/image_pack/vendor/mozjpeg/simd/i386/jfdctint-sse2.asm +633 -0
  190. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctflt-3dn.asm +451 -0
  191. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctflt-sse.asm +571 -0
  192. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctflt-sse2.asm +497 -0
  193. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctfst-mmx.asm +499 -0
  194. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctfst-sse2.asm +501 -0
  195. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctint-avx2.asm +453 -0
  196. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctint-mmx.asm +851 -0
  197. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctint-sse2.asm +858 -0
  198. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctred-mmx.asm +704 -0
  199. data/ext/image_pack/vendor/mozjpeg/simd/i386/jidctred-sse2.asm +592 -0
  200. data/ext/image_pack/vendor/mozjpeg/simd/i386/jquant-3dn.asm +230 -0
  201. data/ext/image_pack/vendor/mozjpeg/simd/i386/jquant-mmx.asm +276 -0
  202. data/ext/image_pack/vendor/mozjpeg/simd/i386/jquant-sse.asm +208 -0
  203. data/ext/image_pack/vendor/mozjpeg/simd/i386/jquantf-sse2.asm +168 -0
  204. data/ext/image_pack/vendor/mozjpeg/simd/i386/jquanti-avx2.asm +188 -0
  205. data/ext/image_pack/vendor/mozjpeg/simd/i386/jquanti-sse2.asm +201 -0
  206. data/ext/image_pack/vendor/mozjpeg/simd/i386/jsimd.c +1312 -0
  207. data/ext/image_pack/vendor/mozjpeg/simd/i386/jsimdcpu.asm +135 -0
  208. data/ext/image_pack/vendor/mozjpeg/simd/jsimd.h +1258 -0
  209. data/ext/image_pack/vendor/mozjpeg/simd/mips/jsimd.c +1143 -0
  210. data/ext/image_pack/vendor/mozjpeg/simd/mips/jsimd_dspr2.S +4543 -0
  211. data/ext/image_pack/vendor/mozjpeg/simd/mips/jsimd_dspr2_asm.h +292 -0
  212. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jccolext-mmi.c +455 -0
  213. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jccolor-mmi.c +148 -0
  214. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jcgray-mmi.c +132 -0
  215. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jcgryext-mmi.c +374 -0
  216. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jcsample-mmi.c +98 -0
  217. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jcsample.h +28 -0
  218. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jdcolext-mmi.c +415 -0
  219. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jdcolor-mmi.c +139 -0
  220. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jdmerge-mmi.c +149 -0
  221. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jdmrgext-mmi.c +615 -0
  222. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jdsample-mmi.c +304 -0
  223. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jfdctfst-mmi.c +255 -0
  224. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jfdctint-mmi.c +398 -0
  225. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jidctfst-mmi.c +395 -0
  226. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jidctint-mmi.c +571 -0
  227. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jquanti-mmi.c +124 -0
  228. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jsimd.c +866 -0
  229. data/ext/image_pack/vendor/mozjpeg/simd/mips64/jsimd_mmi.h +69 -0
  230. data/ext/image_pack/vendor/mozjpeg/simd/mips64/loongson-mmintrin.h +1334 -0
  231. data/ext/image_pack/vendor/mozjpeg/simd/nasm/jcolsamp.inc +135 -0
  232. data/ext/image_pack/vendor/mozjpeg/simd/nasm/jdct.inc +31 -0
  233. data/ext/image_pack/vendor/mozjpeg/simd/nasm/jsimdcfg.inc +93 -0
  234. data/ext/image_pack/vendor/mozjpeg/simd/nasm/jsimdcfg.inc.h +133 -0
  235. data/ext/image_pack/vendor/mozjpeg/simd/nasm/jsimdext.inc +520 -0
  236. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jccolext-altivec.c +269 -0
  237. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jccolor-altivec.c +116 -0
  238. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jcgray-altivec.c +111 -0
  239. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jcgryext-altivec.c +228 -0
  240. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jcsample-altivec.c +159 -0
  241. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jcsample.h +28 -0
  242. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jdcolext-altivec.c +276 -0
  243. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jdcolor-altivec.c +106 -0
  244. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jdmerge-altivec.c +130 -0
  245. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jdmrgext-altivec.c +329 -0
  246. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jdsample-altivec.c +400 -0
  247. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jfdctfst-altivec.c +154 -0
  248. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jfdctint-altivec.c +258 -0
  249. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jidctfst-altivec.c +255 -0
  250. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jidctint-altivec.c +357 -0
  251. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jquanti-altivec.c +250 -0
  252. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jsimd.c +884 -0
  253. data/ext/image_pack/vendor/mozjpeg/simd/powerpc/jsimd_altivec.h +98 -0
  254. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jccolext-avx2.asm +559 -0
  255. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jccolext-sse2.asm +484 -0
  256. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jccolor-avx2.asm +121 -0
  257. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jccolor-sse2.asm +120 -0
  258. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jcgray-avx2.asm +113 -0
  259. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jcgray-sse2.asm +112 -0
  260. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jcgryext-avx2.asm +438 -0
  261. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jcgryext-sse2.asm +363 -0
  262. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jchuff-sse2.asm +583 -0
  263. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jcphuff-sse2.asm +639 -0
  264. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jcsample-avx2.asm +367 -0
  265. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jcsample-sse2.asm +330 -0
  266. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdcolext-avx2.asm +496 -0
  267. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdcolext-sse2.asm +439 -0
  268. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdcolor-avx2.asm +118 -0
  269. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdcolor-sse2.asm +117 -0
  270. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdmerge-avx2.asm +136 -0
  271. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdmerge-sse2.asm +135 -0
  272. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdmrgext-avx2.asm +596 -0
  273. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdmrgext-sse2.asm +538 -0
  274. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdsample-avx2.asm +696 -0
  275. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jdsample-sse2.asm +665 -0
  276. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jfdctflt-sse.asm +355 -0
  277. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jfdctfst-sse2.asm +389 -0
  278. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jfdctint-avx2.asm +320 -0
  279. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jfdctint-sse2.asm +619 -0
  280. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jidctflt-sse2.asm +482 -0
  281. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jidctfst-sse2.asm +491 -0
  282. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jidctint-avx2.asm +418 -0
  283. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jidctint-sse2.asm +847 -0
  284. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jidctred-sse2.asm +574 -0
  285. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jquantf-sse2.asm +155 -0
  286. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jquanti-avx2.asm +163 -0
  287. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jquanti-sse2.asm +188 -0
  288. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jsimd.c +1110 -0
  289. data/ext/image_pack/vendor/mozjpeg/simd/x86_64/jsimdcpu.asm +86 -0
  290. data/ext/image_pack/vendor/mozjpeg/strtest.c +170 -0
  291. data/ext/image_pack/vendor/mozjpeg/structure.txt +900 -0
  292. data/ext/image_pack/vendor/mozjpeg/tjbench.c +1044 -0
  293. data/ext/image_pack/vendor/mozjpeg/tjbenchtest.in +256 -0
  294. data/ext/image_pack/vendor/mozjpeg/tjbenchtest.java.in +215 -0
  295. data/ext/image_pack/vendor/mozjpeg/tjexample.c +406 -0
  296. data/ext/image_pack/vendor/mozjpeg/tjexampletest.in +149 -0
  297. data/ext/image_pack/vendor/mozjpeg/tjexampletest.java.in +151 -0
  298. data/ext/image_pack/vendor/mozjpeg/tjunittest.c +961 -0
  299. data/ext/image_pack/vendor/mozjpeg/tjutil.c +70 -0
  300. data/ext/image_pack/vendor/mozjpeg/tjutil.h +53 -0
  301. data/ext/image_pack/vendor/mozjpeg/transupp.c +2373 -0
  302. data/ext/image_pack/vendor/mozjpeg/transupp.h +243 -0
  303. data/ext/image_pack/vendor/mozjpeg/turbojpeg-jni.c +1259 -0
  304. data/ext/image_pack/vendor/mozjpeg/turbojpeg.c +2320 -0
  305. data/ext/image_pack/vendor/mozjpeg/turbojpeg.h +1784 -0
  306. data/ext/image_pack/vendor/mozjpeg/usage.txt +679 -0
  307. data/ext/image_pack/vendor/mozjpeg/wizard.txt +220 -0
  308. data/ext/image_pack/vendor/mozjpeg/wrbmp.c +552 -0
  309. data/ext/image_pack/vendor/mozjpeg/wrgif.c +580 -0
  310. data/ext/image_pack/vendor/mozjpeg/wrjpgcom.c +577 -0
  311. data/ext/image_pack/vendor/mozjpeg/wrppm.c +366 -0
  312. data/ext/image_pack/vendor/mozjpeg/wrtarga.c +258 -0
  313. data/ext/image_pack/vendor/mozjpeg/yuvjpeg.c +268 -0
  314. data/lib/image_pack/backend.rb +8 -0
  315. data/lib/image_pack/configuration.rb +23 -0
  316. data/lib/image_pack/errors.rb +13 -0
  317. data/lib/image_pack/version.rb +5 -0
  318. data/lib/image_pack.rb +208 -0
  319. metadata +433 -0
@@ -0,0 +1,354 @@
1
+ /*
2
+ * jdmrg565.c
3
+ *
4
+ * This file was part of the Independent JPEG Group's software:
5
+ * Copyright (C) 1994-1996, Thomas G. Lane.
6
+ * libjpeg-turbo Modifications:
7
+ * Copyright (C) 2013, Linaro Limited.
8
+ * Copyright (C) 2014-2015, 2018, 2020, D. R. Commander.
9
+ * For conditions of distribution and use, see the accompanying README.ijg
10
+ * file.
11
+ *
12
+ * This file contains code for merged upsampling/color conversion.
13
+ */
14
+
15
+
16
+ INLINE
17
+ LOCAL(void)
18
+ h2v1_merged_upsample_565_internal(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
19
+ JDIMENSION in_row_group_ctr,
20
+ JSAMPARRAY output_buf)
21
+ {
22
+ my_merged_upsample_ptr upsample = (my_merged_upsample_ptr)cinfo->upsample;
23
+ register int y, cred, cgreen, cblue;
24
+ int cb, cr;
25
+ register JSAMPROW outptr;
26
+ JSAMPROW inptr0, inptr1, inptr2;
27
+ JDIMENSION col;
28
+ /* copy these pointers into registers if possible */
29
+ register JSAMPLE *range_limit = cinfo->sample_range_limit;
30
+ int *Crrtab = upsample->Cr_r_tab;
31
+ int *Cbbtab = upsample->Cb_b_tab;
32
+ JLONG *Crgtab = upsample->Cr_g_tab;
33
+ JLONG *Cbgtab = upsample->Cb_g_tab;
34
+ unsigned int r, g, b;
35
+ JLONG rgb;
36
+ SHIFT_TEMPS
37
+
38
+ inptr0 = input_buf[0][in_row_group_ctr];
39
+ inptr1 = input_buf[1][in_row_group_ctr];
40
+ inptr2 = input_buf[2][in_row_group_ctr];
41
+ outptr = output_buf[0];
42
+
43
+ /* Loop for each pair of output pixels */
44
+ for (col = cinfo->output_width >> 1; col > 0; col--) {
45
+ /* Do the chroma part of the calculation */
46
+ cb = *inptr1++;
47
+ cr = *inptr2++;
48
+ cred = Crrtab[cr];
49
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
50
+ cblue = Cbbtab[cb];
51
+
52
+ /* Fetch 2 Y values and emit 2 pixels */
53
+ y = *inptr0++;
54
+ r = range_limit[y + cred];
55
+ g = range_limit[y + cgreen];
56
+ b = range_limit[y + cblue];
57
+ rgb = PACK_SHORT_565(r, g, b);
58
+
59
+ y = *inptr0++;
60
+ r = range_limit[y + cred];
61
+ g = range_limit[y + cgreen];
62
+ b = range_limit[y + cblue];
63
+ rgb = PACK_TWO_PIXELS(rgb, PACK_SHORT_565(r, g, b));
64
+
65
+ WRITE_TWO_PIXELS(outptr, rgb);
66
+ outptr += 4;
67
+ }
68
+
69
+ /* If image width is odd, do the last output column separately */
70
+ if (cinfo->output_width & 1) {
71
+ cb = *inptr1;
72
+ cr = *inptr2;
73
+ cred = Crrtab[cr];
74
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
75
+ cblue = Cbbtab[cb];
76
+ y = *inptr0;
77
+ r = range_limit[y + cred];
78
+ g = range_limit[y + cgreen];
79
+ b = range_limit[y + cblue];
80
+ rgb = PACK_SHORT_565(r, g, b);
81
+ *(INT16 *)outptr = (INT16)rgb;
82
+ }
83
+ }
84
+
85
+
86
+ INLINE
87
+ LOCAL(void)
88
+ h2v1_merged_upsample_565D_internal(j_decompress_ptr cinfo,
89
+ JSAMPIMAGE input_buf,
90
+ JDIMENSION in_row_group_ctr,
91
+ JSAMPARRAY output_buf)
92
+ {
93
+ my_merged_upsample_ptr upsample = (my_merged_upsample_ptr)cinfo->upsample;
94
+ register int y, cred, cgreen, cblue;
95
+ int cb, cr;
96
+ register JSAMPROW outptr;
97
+ JSAMPROW inptr0, inptr1, inptr2;
98
+ JDIMENSION col;
99
+ /* copy these pointers into registers if possible */
100
+ register JSAMPLE *range_limit = cinfo->sample_range_limit;
101
+ int *Crrtab = upsample->Cr_r_tab;
102
+ int *Cbbtab = upsample->Cb_b_tab;
103
+ JLONG *Crgtab = upsample->Cr_g_tab;
104
+ JLONG *Cbgtab = upsample->Cb_g_tab;
105
+ JLONG d0 = dither_matrix[cinfo->output_scanline & DITHER_MASK];
106
+ unsigned int r, g, b;
107
+ JLONG rgb;
108
+ SHIFT_TEMPS
109
+
110
+ inptr0 = input_buf[0][in_row_group_ctr];
111
+ inptr1 = input_buf[1][in_row_group_ctr];
112
+ inptr2 = input_buf[2][in_row_group_ctr];
113
+ outptr = output_buf[0];
114
+
115
+ /* Loop for each pair of output pixels */
116
+ for (col = cinfo->output_width >> 1; col > 0; col--) {
117
+ /* Do the chroma part of the calculation */
118
+ cb = *inptr1++;
119
+ cr = *inptr2++;
120
+ cred = Crrtab[cr];
121
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
122
+ cblue = Cbbtab[cb];
123
+
124
+ /* Fetch 2 Y values and emit 2 pixels */
125
+ y = *inptr0++;
126
+ r = range_limit[DITHER_565_R(y + cred, d0)];
127
+ g = range_limit[DITHER_565_G(y + cgreen, d0)];
128
+ b = range_limit[DITHER_565_B(y + cblue, d0)];
129
+ d0 = DITHER_ROTATE(d0);
130
+ rgb = PACK_SHORT_565(r, g, b);
131
+
132
+ y = *inptr0++;
133
+ r = range_limit[DITHER_565_R(y + cred, d0)];
134
+ g = range_limit[DITHER_565_G(y + cgreen, d0)];
135
+ b = range_limit[DITHER_565_B(y + cblue, d0)];
136
+ d0 = DITHER_ROTATE(d0);
137
+ rgb = PACK_TWO_PIXELS(rgb, PACK_SHORT_565(r, g, b));
138
+
139
+ WRITE_TWO_PIXELS(outptr, rgb);
140
+ outptr += 4;
141
+ }
142
+
143
+ /* If image width is odd, do the last output column separately */
144
+ if (cinfo->output_width & 1) {
145
+ cb = *inptr1;
146
+ cr = *inptr2;
147
+ cred = Crrtab[cr];
148
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
149
+ cblue = Cbbtab[cb];
150
+ y = *inptr0;
151
+ r = range_limit[DITHER_565_R(y + cred, d0)];
152
+ g = range_limit[DITHER_565_G(y + cgreen, d0)];
153
+ b = range_limit[DITHER_565_B(y + cblue, d0)];
154
+ rgb = PACK_SHORT_565(r, g, b);
155
+ *(INT16 *)outptr = (INT16)rgb;
156
+ }
157
+ }
158
+
159
+
160
+ INLINE
161
+ LOCAL(void)
162
+ h2v2_merged_upsample_565_internal(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
163
+ JDIMENSION in_row_group_ctr,
164
+ JSAMPARRAY output_buf)
165
+ {
166
+ my_merged_upsample_ptr upsample = (my_merged_upsample_ptr)cinfo->upsample;
167
+ register int y, cred, cgreen, cblue;
168
+ int cb, cr;
169
+ register JSAMPROW outptr0, outptr1;
170
+ JSAMPROW inptr00, inptr01, inptr1, inptr2;
171
+ JDIMENSION col;
172
+ /* copy these pointers into registers if possible */
173
+ register JSAMPLE *range_limit = cinfo->sample_range_limit;
174
+ int *Crrtab = upsample->Cr_r_tab;
175
+ int *Cbbtab = upsample->Cb_b_tab;
176
+ JLONG *Crgtab = upsample->Cr_g_tab;
177
+ JLONG *Cbgtab = upsample->Cb_g_tab;
178
+ unsigned int r, g, b;
179
+ JLONG rgb;
180
+ SHIFT_TEMPS
181
+
182
+ inptr00 = input_buf[0][in_row_group_ctr * 2];
183
+ inptr01 = input_buf[0][in_row_group_ctr * 2 + 1];
184
+ inptr1 = input_buf[1][in_row_group_ctr];
185
+ inptr2 = input_buf[2][in_row_group_ctr];
186
+ outptr0 = output_buf[0];
187
+ outptr1 = output_buf[1];
188
+
189
+ /* Loop for each group of output pixels */
190
+ for (col = cinfo->output_width >> 1; col > 0; col--) {
191
+ /* Do the chroma part of the calculation */
192
+ cb = *inptr1++;
193
+ cr = *inptr2++;
194
+ cred = Crrtab[cr];
195
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
196
+ cblue = Cbbtab[cb];
197
+
198
+ /* Fetch 4 Y values and emit 4 pixels */
199
+ y = *inptr00++;
200
+ r = range_limit[y + cred];
201
+ g = range_limit[y + cgreen];
202
+ b = range_limit[y + cblue];
203
+ rgb = PACK_SHORT_565(r, g, b);
204
+
205
+ y = *inptr00++;
206
+ r = range_limit[y + cred];
207
+ g = range_limit[y + cgreen];
208
+ b = range_limit[y + cblue];
209
+ rgb = PACK_TWO_PIXELS(rgb, PACK_SHORT_565(r, g, b));
210
+
211
+ WRITE_TWO_PIXELS(outptr0, rgb);
212
+ outptr0 += 4;
213
+
214
+ y = *inptr01++;
215
+ r = range_limit[y + cred];
216
+ g = range_limit[y + cgreen];
217
+ b = range_limit[y + cblue];
218
+ rgb = PACK_SHORT_565(r, g, b);
219
+
220
+ y = *inptr01++;
221
+ r = range_limit[y + cred];
222
+ g = range_limit[y + cgreen];
223
+ b = range_limit[y + cblue];
224
+ rgb = PACK_TWO_PIXELS(rgb, PACK_SHORT_565(r, g, b));
225
+
226
+ WRITE_TWO_PIXELS(outptr1, rgb);
227
+ outptr1 += 4;
228
+ }
229
+
230
+ /* If image width is odd, do the last output column separately */
231
+ if (cinfo->output_width & 1) {
232
+ cb = *inptr1;
233
+ cr = *inptr2;
234
+ cred = Crrtab[cr];
235
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
236
+ cblue = Cbbtab[cb];
237
+
238
+ y = *inptr00;
239
+ r = range_limit[y + cred];
240
+ g = range_limit[y + cgreen];
241
+ b = range_limit[y + cblue];
242
+ rgb = PACK_SHORT_565(r, g, b);
243
+ *(INT16 *)outptr0 = (INT16)rgb;
244
+
245
+ y = *inptr01;
246
+ r = range_limit[y + cred];
247
+ g = range_limit[y + cgreen];
248
+ b = range_limit[y + cblue];
249
+ rgb = PACK_SHORT_565(r, g, b);
250
+ *(INT16 *)outptr1 = (INT16)rgb;
251
+ }
252
+ }
253
+
254
+
255
+ INLINE
256
+ LOCAL(void)
257
+ h2v2_merged_upsample_565D_internal(j_decompress_ptr cinfo,
258
+ JSAMPIMAGE input_buf,
259
+ JDIMENSION in_row_group_ctr,
260
+ JSAMPARRAY output_buf)
261
+ {
262
+ my_merged_upsample_ptr upsample = (my_merged_upsample_ptr)cinfo->upsample;
263
+ register int y, cred, cgreen, cblue;
264
+ int cb, cr;
265
+ register JSAMPROW outptr0, outptr1;
266
+ JSAMPROW inptr00, inptr01, inptr1, inptr2;
267
+ JDIMENSION col;
268
+ /* copy these pointers into registers if possible */
269
+ register JSAMPLE *range_limit = cinfo->sample_range_limit;
270
+ int *Crrtab = upsample->Cr_r_tab;
271
+ int *Cbbtab = upsample->Cb_b_tab;
272
+ JLONG *Crgtab = upsample->Cr_g_tab;
273
+ JLONG *Cbgtab = upsample->Cb_g_tab;
274
+ JLONG d0 = dither_matrix[cinfo->output_scanline & DITHER_MASK];
275
+ JLONG d1 = dither_matrix[(cinfo->output_scanline + 1) & DITHER_MASK];
276
+ unsigned int r, g, b;
277
+ JLONG rgb;
278
+ SHIFT_TEMPS
279
+
280
+ inptr00 = input_buf[0][in_row_group_ctr * 2];
281
+ inptr01 = input_buf[0][in_row_group_ctr * 2 + 1];
282
+ inptr1 = input_buf[1][in_row_group_ctr];
283
+ inptr2 = input_buf[2][in_row_group_ctr];
284
+ outptr0 = output_buf[0];
285
+ outptr1 = output_buf[1];
286
+
287
+ /* Loop for each group of output pixels */
288
+ for (col = cinfo->output_width >> 1; col > 0; col--) {
289
+ /* Do the chroma part of the calculation */
290
+ cb = *inptr1++;
291
+ cr = *inptr2++;
292
+ cred = Crrtab[cr];
293
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
294
+ cblue = Cbbtab[cb];
295
+
296
+ /* Fetch 4 Y values and emit 4 pixels */
297
+ y = *inptr00++;
298
+ r = range_limit[DITHER_565_R(y + cred, d0)];
299
+ g = range_limit[DITHER_565_G(y + cgreen, d0)];
300
+ b = range_limit[DITHER_565_B(y + cblue, d0)];
301
+ d0 = DITHER_ROTATE(d0);
302
+ rgb = PACK_SHORT_565(r, g, b);
303
+
304
+ y = *inptr00++;
305
+ r = range_limit[DITHER_565_R(y + cred, d0)];
306
+ g = range_limit[DITHER_565_G(y + cgreen, d0)];
307
+ b = range_limit[DITHER_565_B(y + cblue, d0)];
308
+ d0 = DITHER_ROTATE(d0);
309
+ rgb = PACK_TWO_PIXELS(rgb, PACK_SHORT_565(r, g, b));
310
+
311
+ WRITE_TWO_PIXELS(outptr0, rgb);
312
+ outptr0 += 4;
313
+
314
+ y = *inptr01++;
315
+ r = range_limit[DITHER_565_R(y + cred, d1)];
316
+ g = range_limit[DITHER_565_G(y + cgreen, d1)];
317
+ b = range_limit[DITHER_565_B(y + cblue, d1)];
318
+ d1 = DITHER_ROTATE(d1);
319
+ rgb = PACK_SHORT_565(r, g, b);
320
+
321
+ y = *inptr01++;
322
+ r = range_limit[DITHER_565_R(y + cred, d1)];
323
+ g = range_limit[DITHER_565_G(y + cgreen, d1)];
324
+ b = range_limit[DITHER_565_B(y + cblue, d1)];
325
+ d1 = DITHER_ROTATE(d1);
326
+ rgb = PACK_TWO_PIXELS(rgb, PACK_SHORT_565(r, g, b));
327
+
328
+ WRITE_TWO_PIXELS(outptr1, rgb);
329
+ outptr1 += 4;
330
+ }
331
+
332
+ /* If image width is odd, do the last output column separately */
333
+ if (cinfo->output_width & 1) {
334
+ cb = *inptr1;
335
+ cr = *inptr2;
336
+ cred = Crrtab[cr];
337
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
338
+ cblue = Cbbtab[cb];
339
+
340
+ y = *inptr00;
341
+ r = range_limit[DITHER_565_R(y + cred, d0)];
342
+ g = range_limit[DITHER_565_G(y + cgreen, d0)];
343
+ b = range_limit[DITHER_565_B(y + cblue, d0)];
344
+ rgb = PACK_SHORT_565(r, g, b);
345
+ *(INT16 *)outptr0 = (INT16)rgb;
346
+
347
+ y = *inptr01;
348
+ r = range_limit[DITHER_565_R(y + cred, d1)];
349
+ g = range_limit[DITHER_565_G(y + cgreen, d1)];
350
+ b = range_limit[DITHER_565_B(y + cblue, d1)];
351
+ rgb = PACK_SHORT_565(r, g, b);
352
+ *(INT16 *)outptr1 = (INT16)rgb;
353
+ }
354
+ }
@@ -0,0 +1,184 @@
1
+ /*
2
+ * jdmrgext.c
3
+ *
4
+ * This file was part of the Independent JPEG Group's software:
5
+ * Copyright (C) 1994-1996, Thomas G. Lane.
6
+ * libjpeg-turbo Modifications:
7
+ * Copyright (C) 2011, 2015, 2020, 2023, D. R. Commander.
8
+ * For conditions of distribution and use, see the accompanying README.ijg
9
+ * file.
10
+ *
11
+ * This file contains code for merged upsampling/color conversion.
12
+ */
13
+
14
+
15
+ /* This file is included by jdmerge.c */
16
+
17
+
18
+ /*
19
+ * Upsample and color convert for the case of 2:1 horizontal and 1:1 vertical.
20
+ */
21
+
22
+ INLINE
23
+ LOCAL(void)
24
+ h2v1_merged_upsample_internal(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
25
+ JDIMENSION in_row_group_ctr,
26
+ JSAMPARRAY output_buf)
27
+ {
28
+ my_merged_upsample_ptr upsample = (my_merged_upsample_ptr)cinfo->upsample;
29
+ register int y, cred, cgreen, cblue;
30
+ int cb, cr;
31
+ register JSAMPROW outptr;
32
+ JSAMPROW inptr0, inptr1, inptr2;
33
+ JDIMENSION col;
34
+ /* copy these pointers into registers if possible */
35
+ register JSAMPLE *range_limit = cinfo->sample_range_limit;
36
+ int *Crrtab = upsample->Cr_r_tab;
37
+ int *Cbbtab = upsample->Cb_b_tab;
38
+ JLONG *Crgtab = upsample->Cr_g_tab;
39
+ JLONG *Cbgtab = upsample->Cb_g_tab;
40
+ SHIFT_TEMPS
41
+
42
+ inptr0 = input_buf[0][in_row_group_ctr];
43
+ inptr1 = input_buf[1][in_row_group_ctr];
44
+ inptr2 = input_buf[2][in_row_group_ctr];
45
+ outptr = output_buf[0];
46
+ /* Loop for each pair of output pixels */
47
+ for (col = cinfo->output_width >> 1; col > 0; col--) {
48
+ /* Do the chroma part of the calculation */
49
+ cb = *inptr1++;
50
+ cr = *inptr2++;
51
+ cred = Crrtab[cr];
52
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
53
+ cblue = Cbbtab[cb];
54
+ /* Fetch 2 Y values and emit 2 pixels */
55
+ y = *inptr0++;
56
+ outptr[RGB_RED] = range_limit[y + cred];
57
+ outptr[RGB_GREEN] = range_limit[y + cgreen];
58
+ outptr[RGB_BLUE] = range_limit[y + cblue];
59
+ #ifdef RGB_ALPHA
60
+ outptr[RGB_ALPHA] = MAXJSAMPLE;
61
+ #endif
62
+ outptr += RGB_PIXELSIZE;
63
+ y = *inptr0++;
64
+ outptr[RGB_RED] = range_limit[y + cred];
65
+ outptr[RGB_GREEN] = range_limit[y + cgreen];
66
+ outptr[RGB_BLUE] = range_limit[y + cblue];
67
+ #ifdef RGB_ALPHA
68
+ outptr[RGB_ALPHA] = MAXJSAMPLE;
69
+ #endif
70
+ outptr += RGB_PIXELSIZE;
71
+ }
72
+ /* If image width is odd, do the last output column separately */
73
+ if (cinfo->output_width & 1) {
74
+ cb = *inptr1;
75
+ cr = *inptr2;
76
+ cred = Crrtab[cr];
77
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
78
+ cblue = Cbbtab[cb];
79
+ y = *inptr0;
80
+ outptr[RGB_RED] = range_limit[y + cred];
81
+ outptr[RGB_GREEN] = range_limit[y + cgreen];
82
+ outptr[RGB_BLUE] = range_limit[y + cblue];
83
+ #ifdef RGB_ALPHA
84
+ outptr[RGB_ALPHA] = MAXJSAMPLE;
85
+ #endif
86
+ }
87
+ }
88
+
89
+
90
+ /*
91
+ * Upsample and color convert for the case of 2:1 horizontal and 2:1 vertical.
92
+ */
93
+
94
+ INLINE
95
+ LOCAL(void)
96
+ h2v2_merged_upsample_internal(j_decompress_ptr cinfo, JSAMPIMAGE input_buf,
97
+ JDIMENSION in_row_group_ctr,
98
+ JSAMPARRAY output_buf)
99
+ {
100
+ my_merged_upsample_ptr upsample = (my_merged_upsample_ptr)cinfo->upsample;
101
+ register int y, cred, cgreen, cblue;
102
+ int cb, cr;
103
+ register JSAMPROW outptr0, outptr1;
104
+ JSAMPROW inptr00, inptr01, inptr1, inptr2;
105
+ JDIMENSION col;
106
+ /* copy these pointers into registers if possible */
107
+ register JSAMPLE *range_limit = cinfo->sample_range_limit;
108
+ int *Crrtab = upsample->Cr_r_tab;
109
+ int *Cbbtab = upsample->Cb_b_tab;
110
+ JLONG *Crgtab = upsample->Cr_g_tab;
111
+ JLONG *Cbgtab = upsample->Cb_g_tab;
112
+ SHIFT_TEMPS
113
+
114
+ inptr00 = input_buf[0][in_row_group_ctr * 2];
115
+ inptr01 = input_buf[0][in_row_group_ctr * 2 + 1];
116
+ inptr1 = input_buf[1][in_row_group_ctr];
117
+ inptr2 = input_buf[2][in_row_group_ctr];
118
+ outptr0 = output_buf[0];
119
+ outptr1 = output_buf[1];
120
+ /* Loop for each group of output pixels */
121
+ for (col = cinfo->output_width >> 1; col > 0; col--) {
122
+ /* Do the chroma part of the calculation */
123
+ cb = *inptr1++;
124
+ cr = *inptr2++;
125
+ cred = Crrtab[cr];
126
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
127
+ cblue = Cbbtab[cb];
128
+ /* Fetch 4 Y values and emit 4 pixels */
129
+ y = *inptr00++;
130
+ outptr0[RGB_RED] = range_limit[y + cred];
131
+ outptr0[RGB_GREEN] = range_limit[y + cgreen];
132
+ outptr0[RGB_BLUE] = range_limit[y + cblue];
133
+ #ifdef RGB_ALPHA
134
+ outptr0[RGB_ALPHA] = MAXJSAMPLE;
135
+ #endif
136
+ outptr0 += RGB_PIXELSIZE;
137
+ y = *inptr00++;
138
+ outptr0[RGB_RED] = range_limit[y + cred];
139
+ outptr0[RGB_GREEN] = range_limit[y + cgreen];
140
+ outptr0[RGB_BLUE] = range_limit[y + cblue];
141
+ #ifdef RGB_ALPHA
142
+ outptr0[RGB_ALPHA] = MAXJSAMPLE;
143
+ #endif
144
+ outptr0 += RGB_PIXELSIZE;
145
+ y = *inptr01++;
146
+ outptr1[RGB_RED] = range_limit[y + cred];
147
+ outptr1[RGB_GREEN] = range_limit[y + cgreen];
148
+ outptr1[RGB_BLUE] = range_limit[y + cblue];
149
+ #ifdef RGB_ALPHA
150
+ outptr1[RGB_ALPHA] = MAXJSAMPLE;
151
+ #endif
152
+ outptr1 += RGB_PIXELSIZE;
153
+ y = *inptr01++;
154
+ outptr1[RGB_RED] = range_limit[y + cred];
155
+ outptr1[RGB_GREEN] = range_limit[y + cgreen];
156
+ outptr1[RGB_BLUE] = range_limit[y + cblue];
157
+ #ifdef RGB_ALPHA
158
+ outptr1[RGB_ALPHA] = MAXJSAMPLE;
159
+ #endif
160
+ outptr1 += RGB_PIXELSIZE;
161
+ }
162
+ /* If image width is odd, do the last output column separately */
163
+ if (cinfo->output_width & 1) {
164
+ cb = *inptr1;
165
+ cr = *inptr2;
166
+ cred = Crrtab[cr];
167
+ cgreen = (int)RIGHT_SHIFT(Cbgtab[cb] + Crgtab[cr], SCALEBITS);
168
+ cblue = Cbbtab[cb];
169
+ y = *inptr00;
170
+ outptr0[RGB_RED] = range_limit[y + cred];
171
+ outptr0[RGB_GREEN] = range_limit[y + cgreen];
172
+ outptr0[RGB_BLUE] = range_limit[y + cblue];
173
+ #ifdef RGB_ALPHA
174
+ outptr0[RGB_ALPHA] = MAXJSAMPLE;
175
+ #endif
176
+ y = *inptr01;
177
+ outptr1[RGB_RED] = range_limit[y + cred];
178
+ outptr1[RGB_GREEN] = range_limit[y + cgreen];
179
+ outptr1[RGB_BLUE] = range_limit[y + cblue];
180
+ #ifdef RGB_ALPHA
181
+ outptr1[RGB_ALPHA] = MAXJSAMPLE;
182
+ #endif
183
+ }
184
+ }