jdcolor-sse2.asm 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. ;
  2. ; jdcolor.asm - colorspace conversion (SSE2)
  3. ;
  4. ; Copyright 2009 Pierre Ossman <[email protected]> for Cendio AB
  5. ; Copyright (C) 2009, D. R. Commander.
  6. ;
  7. ; Based on the x86 SIMD extension for IJG JPEG library
  8. ; Copyright (C) 1999-2006, MIYASAKA Masaru.
  9. ; For conditions of distribution and use, see copyright notice in jsimdext.inc
  10. ;
  11. ; This file should be assembled with NASM (Netwide Assembler),
  12. ; can *not* be assembled with Microsoft's MASM or any compatible
  13. ; assembler (including Borland's Turbo Assembler).
  14. ; NASM is available from http://nasm.sourceforge.net/ or
  15. ; http://sourceforge.net/project/showfiles.php?group_id=6208
  16. ;
  17. ; [TAB8]
  18. %include "jsimdext.inc"
  19. ; --------------------------------------------------------------------------
  20. %define SCALEBITS 16
  21. F_0_344 equ 22554 ; FIX(0.34414)
  22. F_0_714 equ 46802 ; FIX(0.71414)
  23. F_1_402 equ 91881 ; FIX(1.40200)
  24. F_1_772 equ 116130 ; FIX(1.77200)
  25. F_0_402 equ (F_1_402 - 65536) ; FIX(1.40200) - FIX(1)
  26. F_0_285 equ ( 65536 - F_0_714) ; FIX(1) - FIX(0.71414)
  27. F_0_228 equ (131072 - F_1_772) ; FIX(2) - FIX(1.77200)
  28. ; --------------------------------------------------------------------------
  29. SECTION SEG_CONST
  30. alignz 16
  31. global EXTN(jconst_ycc_rgb_convert_sse2)
  32. EXTN(jconst_ycc_rgb_convert_sse2):
  33. PW_F0402 times 8 dw F_0_402
  34. PW_MF0228 times 8 dw -F_0_228
  35. PW_MF0344_F0285 times 4 dw -F_0_344, F_0_285
  36. PW_ONE times 8 dw 1
  37. PD_ONEHALF times 4 dd 1 << (SCALEBITS-1)
  38. alignz 16
  39. ; --------------------------------------------------------------------------
  40. SECTION SEG_TEXT
  41. BITS 32
  42. %include "jdcolext-sse2.asm"
  43. %undef RGB_RED
  44. %undef RGB_GREEN
  45. %undef RGB_BLUE
  46. %undef RGB_PIXELSIZE
  47. %define RGB_RED EXT_RGB_RED
  48. %define RGB_GREEN EXT_RGB_GREEN
  49. %define RGB_BLUE EXT_RGB_BLUE
  50. %define RGB_PIXELSIZE EXT_RGB_PIXELSIZE
  51. %define jsimd_ycc_rgb_convert_sse2 jsimd_ycc_extrgb_convert_sse2
  52. %include "jdcolext-sse2.asm"
  53. %undef RGB_RED
  54. %undef RGB_GREEN
  55. %undef RGB_BLUE
  56. %undef RGB_PIXELSIZE
  57. %define RGB_RED EXT_RGBX_RED
  58. %define RGB_GREEN EXT_RGBX_GREEN
  59. %define RGB_BLUE EXT_RGBX_BLUE
  60. %define RGB_PIXELSIZE EXT_RGBX_PIXELSIZE
  61. %define jsimd_ycc_rgb_convert_sse2 jsimd_ycc_extrgbx_convert_sse2
  62. %include "jdcolext-sse2.asm"
  63. %undef RGB_RED
  64. %undef RGB_GREEN
  65. %undef RGB_BLUE
  66. %undef RGB_PIXELSIZE
  67. %define RGB_RED EXT_BGR_RED
  68. %define RGB_GREEN EXT_BGR_GREEN
  69. %define RGB_BLUE EXT_BGR_BLUE
  70. %define RGB_PIXELSIZE EXT_BGR_PIXELSIZE
  71. %define jsimd_ycc_rgb_convert_sse2 jsimd_ycc_extbgr_convert_sse2
  72. %include "jdcolext-sse2.asm"
  73. %undef RGB_RED
  74. %undef RGB_GREEN
  75. %undef RGB_BLUE
  76. %undef RGB_PIXELSIZE
  77. %define RGB_RED EXT_BGRX_RED
  78. %define RGB_GREEN EXT_BGRX_GREEN
  79. %define RGB_BLUE EXT_BGRX_BLUE
  80. %define RGB_PIXELSIZE EXT_BGRX_PIXELSIZE
  81. %define jsimd_ycc_rgb_convert_sse2 jsimd_ycc_extbgrx_convert_sse2
  82. %include "jdcolext-sse2.asm"
  83. %undef RGB_RED
  84. %undef RGB_GREEN
  85. %undef RGB_BLUE
  86. %undef RGB_PIXELSIZE
  87. %define RGB_RED EXT_XBGR_RED
  88. %define RGB_GREEN EXT_XBGR_GREEN
  89. %define RGB_BLUE EXT_XBGR_BLUE
  90. %define RGB_PIXELSIZE EXT_XBGR_PIXELSIZE
  91. %define jsimd_ycc_rgb_convert_sse2 jsimd_ycc_extxbgr_convert_sse2
  92. %include "jdcolext-sse2.asm"
  93. %undef RGB_RED
  94. %undef RGB_GREEN
  95. %undef RGB_BLUE
  96. %undef RGB_PIXELSIZE
  97. %define RGB_RED EXT_XRGB_RED
  98. %define RGB_GREEN EXT_XRGB_GREEN
  99. %define RGB_BLUE EXT_XRGB_BLUE
  100. %define RGB_PIXELSIZE EXT_XRGB_PIXELSIZE
  101. %define jsimd_ycc_rgb_convert_sse2 jsimd_ycc_extxrgb_convert_sse2
  102. %include "jdcolext-sse2.asm"