31 lines
876 B
C
31 lines
876 B
C
#ifndef COSMOPOLITAN_LIBC_INTRIN_PACKSSWB_H_
|
||
#define COSMOPOLITAN_LIBC_INTRIN_PACKSSWB_H_
|
||
#include "libc/intrin/macros.h"
|
||
#include "libc/macros.h"
|
||
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
||
|
||
/**
|
||
* Casts shorts to signed chars w/ saturation.
|
||
*
|
||
* 𝑎 ← {CLAMP[𝑏ᵢ]|𝑖∈[0,4)} ║ {CLAMP[𝑐ᵢ]|𝑖∈[4,8)}
|
||
*
|
||
* @see packuswb()
|
||
* @mayalias
|
||
*/
|
||
static void packsswb(signed char a[16], const short b[8], const short c[8]) {
|
||
int i;
|
||
for (i = 0; i < 8; ++i) {
|
||
a[i] = MIN(127, MAX(-128, b[i]));
|
||
}
|
||
for (i = 0; i < 8; ++i) {
|
||
a[i + 8] = MIN(127, MAX(-128, c[i]));
|
||
}
|
||
}
|
||
|
||
#define packsswb(A, B, C) \
|
||
INTRIN_SSEVEX_X_X_X_(packsswb, SSE2, "packsswb", INTRIN_NONCOMMUTATIVE, A, \
|
||
B, C)
|
||
|
||
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
||
#endif /* COSMOPOLITAN_LIBC_INTRIN_PACKSSWB_H_ */
|