laag-libjpeg-turbo 1.5.3.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +57 -0
- data/LICENSE.txt +139 -0
- data/README.org +34 -0
- data/ext/laag/libjpeg-turbo/extconf.rb +16 -0
- data/laag-libjpeg-turbo.gemspec +20 -0
- data/lib/laag/libjpeg-turbo.rb +29 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/.gitignore +14 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/.travis.yml +131 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/BUILDING.md +964 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/CMakeLists.txt +962 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/ChangeLog.md +1151 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/LICENSE.md +139 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/Makefile.am +794 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/README.ijg +279 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/README.md +341 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/acinclude.m4 +287 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/appveyor.yml +57 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/bmp.c +341 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/bmp.h +42 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cderror.h +136 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cdjpeg.c +144 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cdjpeg.h +153 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/change.log +315 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/ci/keys.enc +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cjpeg.1 +351 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cjpeg.c +644 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cmakescripts/cmake_uninstall.cmake.in +24 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/cmakescripts/testclean.cmake +39 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/coderules.txt +78 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/configure.ac +616 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/djpeg.1 +293 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/djpeg.c +782 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/annotated.html +104 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/bc_s.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/bdwn.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/classes.html +106 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/closed.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/doxygen-extra.css +3 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/doxygen.css +1184 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/doxygen.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/dynsections.js +97 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2blank.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2cl.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2doc.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2folderclosed.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2folderopen.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2lastnode.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2link.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2mlastnode.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2mnode.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2mo.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2node.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2ns.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2plastnode.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2pnode.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2splitbar.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/ftv2vertline.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/functions.html +134 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/functions_vars.html +134 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/group___turbo_j_p_e_g.html +2446 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/index.html +90 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/jquery.js +8 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/modules.html +95 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/nav_f.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/nav_g.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/nav_h.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/open.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_63.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_63.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_64.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_64.js +5 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_68.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_68.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_6e.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_6e.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_6f.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_6f.js +5 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_72.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_72.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_74.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_74.js +89 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_77.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_77.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_78.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_78.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_79.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/all_79.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/classes_74.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/classes_74.js +6 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/close.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/enums_74.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/enums_74.js +7 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/enumvalues_74.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/enumvalues_74.js +34 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/functions_74.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/functions_74.js +28 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/groups_74.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/groups_74.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/mag_sel.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/nomatches.html +12 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search.css +271 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search.js +809 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search_l.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search_m.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/search_r.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/typedefs_74.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/typedefs_74.js +5 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_63.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_63.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_64.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_64.js +5 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_68.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_68.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_6e.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_6e.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_6f.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_6f.js +5 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_72.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_72.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_74.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_74.js +9 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_77.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_77.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_78.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_78.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_79.html +26 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/search/variables_79.js +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/structtjregion.html +186 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/structtjscalingfactor.html +148 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/structtjtransform.html +212 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/sync_off.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/sync_on.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tab_a.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tab_b.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tab_h.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tab_s.png +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doc/html/tabs.css +60 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doxygen-extra.css +3 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/doxygen.config +16 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/example.c +433 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jaricom.c +156 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/CMakeLists.txt +57 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/MANIFEST.MF +2 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/Makefile.am +75 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/README +52 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/TJBench.java +926 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/TJExample.java +362 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/TJUnitTest.java +959 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/allclasses-frame.html +24 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/allclasses-noframe.html +24 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/constant-values.html +479 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/deprecated-list.html +248 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/help-doc.html +206 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/index-all.html +980 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/index.html +70 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJ.html +1254 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJCompressor.html +922 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJCustomFilter.html +237 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJDecompressor.html +1235 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJException.html +287 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJScalingFactor.html +333 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJTransform.html +706 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/TJTransformer.html +417 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/YUVImage.html +761 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/package-frame.html +31 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/package-summary.html +198 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/org/libjpegturbo/turbojpeg/package-tree.html +156 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/overview-tree.html +160 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/package-list +1 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/resources/background.gif +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/resources/tab.gif +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/resources/titlebar.gif +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/resources/titlebar_end.gif +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/serialized-form.html +159 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/doc/stylesheet.css +474 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJ.java +513 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJCompressor.java +658 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJCustomFilter.java +76 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJDecompressor.java +909 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJException.java +53 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJLoader.java.in +35 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJLoader.java.tmpl +59 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJScalingFactor.java +104 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJTransform.java +208 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/TJTransformer.java +163 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org/libjpegturbo/turbojpeg/YUVImage.java +443 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org_libjpegturbo_turbojpeg_TJ.h +129 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org_libjpegturbo_turbojpeg_TJCompressor.h +101 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org_libjpegturbo_turbojpeg_TJDecompressor.h +101 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/java/org_libjpegturbo_turbojpeg_TJTransformer.h +29 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcapimin.c +295 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcapistd.c +162 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcarith.c +928 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jccoefct.c +449 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jccolext.c +148 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jccolor.c +719 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcdctmgr.c +721 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jchuff.c +1091 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jchuff.h +43 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcinit.c +77 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcmainct.c +162 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcmarker.c +665 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcmaster.c +639 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcomapi.c +109 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jconfig.h.in +73 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jconfig.txt +143 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jconfigint.h.in +17 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcparam.c +542 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcphuff.c +834 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcprepct.c +357 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcsample.c +539 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jcstest.c +126 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jctrans.c +402 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdapimin.c +407 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdapistd.c +637 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdarith.c +769 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdatadst-tj.c +202 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdatadst.c +293 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdatasrc-tj.c +191 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdatasrc.c +295 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcoefct.c +693 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcoefct.h +82 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcol565.c +384 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcolext.c +143 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdcolor.c +897 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdct.h +208 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jddctmgr.c +352 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdhuff.c +822 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdhuff.h +234 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdinput.c +405 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmainct.c +456 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmainct.h +71 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmarker.c +1377 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmaster.c +736 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmaster.h +28 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmerge.c +627 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmrg565.c +356 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdmrgext.c +186 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdphuff.c +674 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdpostct.c +290 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdsample.c +517 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdsample.h +50 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jdtrans.c +155 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jerror.c +251 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jerror.h +317 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jfdctflt.c +169 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jfdctfst.c +227 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jfdctint.c +286 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jidctflt.c +240 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jidctfst.c +371 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jidctint.c +2627 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jidctred.c +403 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jinclude.h +84 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jmemmgr.c +1183 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jmemnobs.c +115 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jmemsys.h +178 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jmorecfg.h +421 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpeg_nbits_table.h +4098 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpegcomp.h +31 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpegint.h +368 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpeglib.h +1122 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpegtran.1 +290 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jpegtran.c +551 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jquant1.c +857 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jquant2.c +1282 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jsimd.h +93 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jsimd_none.c +404 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jsimddct.h +74 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jstdhuff.c +135 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jutils.c +133 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/jversion.h +49 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/libjpeg.map.in +11 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/libjpeg.txt +3104 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/CMakeLists.txt +1 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/Makefile.am +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/md5.c +340 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/md5.h +49 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/md5cmp.c +60 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/md5/md5hl.c +114 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdbmp.c +483 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdcolmap.c +254 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdgif.c +39 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdjpgcom.1 +63 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdjpgcom.c +510 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdppm.c +471 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdrle.c +389 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdswitch.c +424 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/rdtarga.c +503 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/Distribution.xml +24 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/License.rtf +20 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/ReadMe.txt +5 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/Welcome.rtf +17 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/deb-control.tmpl +31 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/libjpeg-turbo.nsi.in +162 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/libjpeg-turbo.spec.in +164 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/libjpeg.pc.in +10 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/libturbojpeg.pc.in +10 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/makecygwinpkg.in +42 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/makedpkg.in +82 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/makemacpkg.in +470 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/release/uninstall.in +112 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/sharedlib/CMakeLists.txt +73 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/CMakeLists.txt +81 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/Makefile.am +102 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolext-altivec.c +267 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolext-mmx.asm +476 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolext-sse2-64.asm +486 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolext-sse2.asm +503 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolor-altivec.c +104 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolor-mmx.asm +122 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolor-sse2-64.asm +121 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jccolor-sse2.asm +121 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgray-altivec.c +99 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgray-mmx.asm +115 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgray-sse2-64.asm +114 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgray-sse2.asm +114 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgryext-altivec.c +227 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgryext-mmx.asm +356 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgryext-sse2-64.asm +365 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcgryext-sse2.asm +384 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jchuff-sse2-64.asm +360 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jchuff-sse2.asm +426 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcolsamp.inc +104 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample-altivec.c +158 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample-mmx.asm +323 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample-sse2-64.asm +329 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample-sse2.asm +350 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jcsample.h +28 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolext-altivec.c +274 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolext-mmx.asm +404 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolext-sse2-64.asm +440 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolext-sse2.asm +459 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolor-altivec.c +96 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolor-mmx.asm +119 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolor-sse2-64.asm +119 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdcolor-sse2.asm +119 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdct.inc +27 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmerge-altivec.c +108 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmerge-mmx.asm +125 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmerge-sse2-64.asm +125 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmerge-sse2.asm +125 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmrgext-altivec.c +323 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmrgext-mmx.asm +463 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmrgext-sse2-64.asm +537 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdmrgext-sse2.asm +518 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdsample-altivec.c +392 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdsample-mmx.asm +736 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdsample-sse2-64.asm +670 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jdsample-sse2.asm +728 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctflt-3dn.asm +319 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctflt-sse-64.asm +357 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctflt-sse.asm +369 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctfst-altivec.c +156 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctfst-mmx.asm +396 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctfst-sse2-64.asm +391 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctfst-sse2.asm +403 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctint-altivec.c +262 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctint-mmx.asm +621 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctint-sse2-64.asm +621 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jfdctint-sse2.asm +633 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctflt-3dn.asm +451 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctflt-sse.asm +571 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctflt-sse2-64.asm +482 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctflt-sse2.asm +497 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctfst-altivec.c +257 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctfst-mmx.asm +499 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctfst-sse2-64.asm +491 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctfst-sse2.asm +501 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctint-altivec.c +359 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctint-mmx.asm +851 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctint-sse2-64.asm +847 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctint-sse2.asm +858 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctred-mmx.asm +705 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctred-sse2-64.asm +575 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jidctred-sse2.asm +593 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jpeg_nbits_table.inc +4097 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquant-3dn.asm +232 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquant-mmx.asm +273 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquant-sse.asm +210 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquantf-sse2-64.asm +157 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquantf-sse2.asm +170 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquanti-altivec.c +252 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquanti-sse2-64.asm +186 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jquanti-sse2.asm +199 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd.h +871 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_altivec.h +99 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_arm.c +728 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_arm64.c +803 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_arm64_neon.S +3425 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_arm_neon.S +2878 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_i386.c +1091 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_mips.c +1140 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_mips_dspr2.S +4486 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_mips_dspr2_asm.h +283 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_powerpc.c +852 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimd_x86_64.c +887 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimdcfg.inc.h +130 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimdcpu.asm +104 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/jsimdext.inc +375 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/simd/nasm_lt.sh +60 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/structure.txt +904 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/nightshot_iso_100.bmp +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/nightshot_iso_100.txt +25 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testimgari.jpg +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testimgint.jpg +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testorig.jpg +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testorig.ppm +4 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/testorig12.jpg +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/vgl_5674_0098.bmp +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/vgl_6434_0018a.bmp +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/testimages/vgl_6548_0026a.bmp +0 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjbench.c +1010 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjbenchtest.in +252 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjbenchtest.java.in +207 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjexampletest.in +150 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjunittest.c +734 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjutil.c +66 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/tjutil.h +47 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/transupp.c +1626 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/transupp.h +207 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg-jni.c +1166 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg-mapfile +56 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg-mapfile.jni +92 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg.c +2175 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/turbojpeg.h +1545 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/usage.txt +635 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jconfig.h.in +51 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jconfigint.h.in +13 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg62-memsrcdst.def +106 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg62.def +104 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg7-memsrcdst.def +108 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg7.def +106 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jpeg8.def +109 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/win/jsimdcfg.inc +94 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wizard.txt +211 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrbmp.c +494 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrgif.c +413 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrjpgcom.1 +103 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrjpgcom.c +592 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrppm.c +280 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrrle.c +308 -0
- data/vendor/github.com/libjpeg-turbo/libjpeg-turbo/wrtarga.c +261 -0
- 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
|