Coverage Report

Created: 2026-02-26 06:50

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/FreeRDP/libfreerdp/primitives/sse/prim_avxsse.h
Line
Count
Source
1
/**
2
 * FreeRDP: A Remote Desktop Protocol Implementation
3
 * FreeRDP primitives SSE implementation
4
 *
5
 * Copyright 2025 Armin Novak <armin.novak@thincast.com>
6
 * Copyright 2025 Thincast Technologies GmbH
7
 *
8
 * Licensed under the Apache License, Version 2.0 (the "License");
9
 * you may not use this file except in compliance with the License.
10
 * You may obtain a copy of the License at
11
 *
12
 *     http://www.apache.org/licenses/LICENSE-2.0
13
 *
14
 * Unless required by applicable law or agreed to in writing, software
15
 * distributed under the License is distributed on an "AS IS" BASIS,
16
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
 * See the License for the specific language governing permissions and
18
 * limitations under the License.
19
 */
20
#pragma once
21
22
#include <winpr/cast.h>
23
24
#include "../../core/simd.h"
25
26
#if defined(SSE_AVX_INTRINSICS_ENABLED)
27
#include <emmintrin.h>
28
#include <pmmintrin.h>
29
30
WINPR_ATTR_NODISCARD
31
static inline __m128i mm_set_epu32(uint32_t val1, uint32_t val2, uint32_t val3, uint32_t val4)
32
0
{
33
0
  return _mm_set_epi32(WINPR_CXX_COMPAT_CAST(int32_t, val1), WINPR_CXX_COMPAT_CAST(int32_t, val2),
34
0
                       WINPR_CXX_COMPAT_CAST(int32_t, val3),
35
0
                       WINPR_CXX_COMPAT_CAST(int32_t, val4));
36
0
}
Unexecuted instantiation: rfx_sse2.c:mm_set_epu32
Unexecuted instantiation: nsc_sse2.c:mm_set_epu32
Unexecuted instantiation: prim_colors_sse2.c:mm_set_epu32
Unexecuted instantiation: prim_set_sse2.c:mm_set_epu32
Unexecuted instantiation: prim_add_sse3.c:mm_set_epu32
Unexecuted instantiation: prim_alphaComp_sse3.c:mm_set_epu32
Unexecuted instantiation: prim_andor_sse3.c:mm_set_epu32
Unexecuted instantiation: prim_shift_sse3.c:mm_set_epu32
Unexecuted instantiation: prim_sign_ssse3.c:mm_set_epu32
Unexecuted instantiation: prim_YCoCg_ssse3.c:mm_set_epu32
Unexecuted instantiation: prim_copy_sse4_1.c:mm_set_epu32
Unexecuted instantiation: prim_YUV_sse4.1.c:mm_set_epu32
37
38
WINPR_ATTR_NODISCARD
39
static inline __m128i mm_set_epu8(uint8_t val1, uint8_t val2, uint8_t val3, uint8_t val4,
40
                                  uint8_t val5, uint8_t val6, uint8_t val7, uint8_t val8,
41
                                  uint8_t val9, uint8_t val10, uint8_t val11, uint8_t val12,
42
                                  uint8_t val13, uint8_t val14, uint8_t val15, uint8_t val16)
43
0
{
44
0
  return _mm_set_epi8(WINPR_CXX_COMPAT_CAST(int8_t, val1), WINPR_CXX_COMPAT_CAST(int8_t, val2),
45
0
                      WINPR_CXX_COMPAT_CAST(int8_t, val3), WINPR_CXX_COMPAT_CAST(int8_t, val4),
46
0
                      WINPR_CXX_COMPAT_CAST(int8_t, val5), WINPR_CXX_COMPAT_CAST(int8_t, val6),
47
0
                      WINPR_CXX_COMPAT_CAST(int8_t, val7), WINPR_CXX_COMPAT_CAST(int8_t, val8),
48
0
                      WINPR_CXX_COMPAT_CAST(int8_t, val9), WINPR_CXX_COMPAT_CAST(int8_t, val10),
49
0
                      WINPR_CXX_COMPAT_CAST(int8_t, val11), WINPR_CXX_COMPAT_CAST(int8_t, val12),
50
0
                      WINPR_CXX_COMPAT_CAST(int8_t, val13), WINPR_CXX_COMPAT_CAST(int8_t, val14),
51
0
                      WINPR_CXX_COMPAT_CAST(int8_t, val15), WINPR_CXX_COMPAT_CAST(int8_t, val16));
52
0
}
Unexecuted instantiation: rfx_sse2.c:mm_set_epu8
Unexecuted instantiation: nsc_sse2.c:mm_set_epu8
Unexecuted instantiation: prim_colors_sse2.c:mm_set_epu8
Unexecuted instantiation: prim_set_sse2.c:mm_set_epu8
Unexecuted instantiation: prim_add_sse3.c:mm_set_epu8
Unexecuted instantiation: prim_alphaComp_sse3.c:mm_set_epu8
Unexecuted instantiation: prim_andor_sse3.c:mm_set_epu8
Unexecuted instantiation: prim_shift_sse3.c:mm_set_epu8
Unexecuted instantiation: prim_sign_ssse3.c:mm_set_epu8
Unexecuted instantiation: prim_YCoCg_ssse3.c:mm_set_epu8
Unexecuted instantiation: prim_copy_sse4_1.c:mm_set_epu8
Unexecuted instantiation: prim_YUV_sse4.1.c:mm_set_epu8
53
54
WINPR_ATTR_NODISCARD
55
static inline __m128i mm_set1_epu32(uint32_t val)
56
0
{
57
0
  return _mm_set1_epi32(WINPR_CXX_COMPAT_CAST(int32_t, val));
58
0
}
Unexecuted instantiation: rfx_sse2.c:mm_set1_epu32
Unexecuted instantiation: nsc_sse2.c:mm_set1_epu32
Unexecuted instantiation: prim_colors_sse2.c:mm_set1_epu32
Unexecuted instantiation: prim_set_sse2.c:mm_set1_epu32
Unexecuted instantiation: prim_add_sse3.c:mm_set1_epu32
Unexecuted instantiation: prim_alphaComp_sse3.c:mm_set1_epu32
Unexecuted instantiation: prim_andor_sse3.c:mm_set1_epu32
Unexecuted instantiation: prim_shift_sse3.c:mm_set1_epu32
Unexecuted instantiation: prim_sign_ssse3.c:mm_set1_epu32
Unexecuted instantiation: prim_YCoCg_ssse3.c:mm_set1_epu32
Unexecuted instantiation: prim_copy_sse4_1.c:mm_set1_epu32
Unexecuted instantiation: prim_YUV_sse4.1.c:mm_set1_epu32
59
60
WINPR_ATTR_NODISCARD
61
static inline __m128i mm_set1_epu8(uint8_t val)
62
0
{
63
0
  return _mm_set1_epi8(WINPR_CXX_COMPAT_CAST(int8_t, val));
64
0
}
Unexecuted instantiation: rfx_sse2.c:mm_set1_epu8
Unexecuted instantiation: nsc_sse2.c:mm_set1_epu8
Unexecuted instantiation: prim_colors_sse2.c:mm_set1_epu8
Unexecuted instantiation: prim_set_sse2.c:mm_set1_epu8
Unexecuted instantiation: prim_add_sse3.c:mm_set1_epu8
Unexecuted instantiation: prim_alphaComp_sse3.c:mm_set1_epu8
Unexecuted instantiation: prim_andor_sse3.c:mm_set1_epu8
Unexecuted instantiation: prim_shift_sse3.c:mm_set1_epu8
Unexecuted instantiation: prim_sign_ssse3.c:mm_set1_epu8
Unexecuted instantiation: prim_YCoCg_ssse3.c:mm_set1_epu8
Unexecuted instantiation: prim_copy_sse4_1.c:mm_set1_epu8
Unexecuted instantiation: prim_YUV_sse4.1.c:mm_set1_epu8
65
66
WINPR_ATTR_NODISCARD
67
static inline __m128i LOAD_SI128(const void* ptr)
68
0
{
69
0
  const __m128i* mptr = WINPR_CXX_COMPAT_CAST(const __m128i*, ptr);
70
0
  return _mm_lddqu_si128(mptr);
71
0
}
Unexecuted instantiation: rfx_sse2.c:LOAD_SI128
Unexecuted instantiation: nsc_sse2.c:LOAD_SI128
Unexecuted instantiation: prim_colors_sse2.c:LOAD_SI128
Unexecuted instantiation: prim_set_sse2.c:LOAD_SI128
Unexecuted instantiation: prim_add_sse3.c:LOAD_SI128
Unexecuted instantiation: prim_alphaComp_sse3.c:LOAD_SI128
Unexecuted instantiation: prim_andor_sse3.c:LOAD_SI128
Unexecuted instantiation: prim_shift_sse3.c:LOAD_SI128
Unexecuted instantiation: prim_sign_ssse3.c:LOAD_SI128
Unexecuted instantiation: prim_YCoCg_ssse3.c:LOAD_SI128
Unexecuted instantiation: prim_copy_sse4_1.c:LOAD_SI128
Unexecuted instantiation: prim_YUV_sse4.1.c:LOAD_SI128
72
73
static inline void STORE_SI128(void* ptr, __m128i val)
74
0
{
75
0
  __m128i* mptr = WINPR_CXX_COMPAT_CAST(__m128i*, ptr);
76
0
  _mm_storeu_si128(mptr, val);
77
0
}
Unexecuted instantiation: rfx_sse2.c:STORE_SI128
Unexecuted instantiation: nsc_sse2.c:STORE_SI128
Unexecuted instantiation: prim_colors_sse2.c:STORE_SI128
Unexecuted instantiation: prim_set_sse2.c:STORE_SI128
Unexecuted instantiation: prim_add_sse3.c:STORE_SI128
Unexecuted instantiation: prim_alphaComp_sse3.c:STORE_SI128
Unexecuted instantiation: prim_andor_sse3.c:STORE_SI128
Unexecuted instantiation: prim_shift_sse3.c:STORE_SI128
Unexecuted instantiation: prim_sign_ssse3.c:STORE_SI128
Unexecuted instantiation: prim_YCoCg_ssse3.c:STORE_SI128
Unexecuted instantiation: prim_copy_sse4_1.c:STORE_SI128
Unexecuted instantiation: prim_YUV_sse4.1.c:STORE_SI128
78
79
#endif