summaryrefslogtreecommitdiff
path: root/src/blitter/32bpp_sse4.hpp
diff options
context:
space:
mode:
authorrubidium <rubidium@openttd.org>2014-01-13 18:09:21 +0000
committerrubidium <rubidium@openttd.org>2014-01-13 18:09:21 +0000
commitf5f4f8a4b3a25b0746133a4b13ad2d14e6f2eca9 (patch)
treebe115c472809301f3e35b33a659225aff2640758 /src/blitter/32bpp_sse4.hpp
parent3a44e22b1a52704c92ca0a25b2c71d032540f8ea (diff)
downloadopenttd-f5f4f8a4b3a25b0746133a4b13ad2d14e6f2eca9.tar.xz
(svn r26257) -Codechange: replace most of the SSE macros by functions
Diffstat (limited to 'src/blitter/32bpp_sse4.hpp')
-rw-r--r--src/blitter/32bpp_sse4.hpp33
1 files changed, 3 insertions, 30 deletions
diff --git a/src/blitter/32bpp_sse4.hpp b/src/blitter/32bpp_sse4.hpp
index f8a563b85..7a3332d87 100644
--- a/src/blitter/32bpp_sse4.hpp
+++ b/src/blitter/32bpp_sse4.hpp
@@ -14,41 +14,14 @@
#ifdef WITH_SSE
-#include "32bpp_ssse3.hpp"
-#include "smmintrin.h"
-
-#undef EXTR32
-#define EXTR32(m_from, m_rank) _mm_extract_epi32((*(um128i*) &m_from).m128i, m_rank)
-#undef INSR32
-#define INSR32(m_val, m_into, m_rank) (*(um128i*) &m_into).m128i = _mm_insert_epi32((*(um128i*) &m_into).m128i, m_val, m_rank)
-
-IGNORE_UNINITIALIZED_WARNING_START
-#ifdef _SQ64
- #undef INSR64
- #define INSR64(m_val, m_into, m_rank) (*(um128i*) &m_into).m128i = _mm_insert_epi64((*(um128i*) &m_into).m128i, m_val, m_rank)
-#else
- typedef union { uint64 u64; struct _u32 { uint32 low, high; } u32; } u6432;
- #undef INSR64
- #define INSR64(m_val, m_into, m_rank) { \
- u6432 v; \
- v.u64 = m_val; \
- (*(um128i*) &m_into).m128i = _mm_insert_epi32((*(um128i*) &m_into).m128i, v.u32.low, (m_rank)*2); \
- (*(um128i*) &m_into).m128i = _mm_insert_epi32((*(um128i*) &m_into).m128i, v.u32.high, (m_rank)*2 + 1); \
- }
-
- #undef LOAD64
- #define LOAD64(m_val, m_into) \
- m_into = _mm_cvtsi32_si128(m_val); \
- INSR32((m_val) >> 32, m_into, 1);
+#ifndef SSE_VERSION
+#define SSE_VERSION 4
#endif
-IGNORE_UNINITIALIZED_WARNING_STOP
+#include "32bpp_ssse3.hpp"
/** The SSE4 32 bpp blitter (without palette animation). */
class Blitter_32bppSSE4 : public Blitter_32bppSSSE3 {
public:
- Colour AdjustBrightness(Colour colour, uint8 brightness);
- static Colour ReallyAdjustBrightness(Colour colour, uint8 brightness);
-
/* virtual */ void Draw(Blitter::BlitterParams *bp, BlitterMode mode, ZoomLevel zoom);
template <BlitterMode mode, Blitter_32bppSSE_Base::ReadMode read_mode, Blitter_32bppSSE_Base::BlockType bt_last>
void Draw(const Blitter::BlitterParams *bp, ZoomLevel zoom);