-rw-r--r-- 1551 saferewrite-20211125/src/encode_256x2/avx/encode.c
#include <immintrin.h>
#include <stdint.h>
#include "crypto_encode.h"
void crypto_encode(unsigned char *s,const void *v)
{
__m256i a0 = _mm256_loadu_si256(0+(__m256i *) v);
__m256i a1 = _mm256_loadu_si256(1+(__m256i *) v);
__m256i a2 = _mm256_loadu_si256(2+(__m256i *) v);
__m256i a3 = _mm256_loadu_si256(3+(__m256i *) v);
__m256i a4 = _mm256_loadu_si256(4+(__m256i *) v);
__m256i a5 = _mm256_loadu_si256(5+(__m256i *) v);
__m256i a6 = _mm256_loadu_si256(6+(__m256i *) v);
__m256i a7 = _mm256_loadu_si256(7+(__m256i *) v);
__m256i bottom = _mm256_set1_epi8(1);
__m256i zero = _mm256_setzero_si256();
__m256i b0 = _mm256_cmpgt_epi8(a0&bottom,zero);
__m256i b1 = _mm256_cmpgt_epi8(a1&bottom,zero);
__m256i b2 = _mm256_cmpgt_epi8(a2&bottom,zero);
__m256i b3 = _mm256_cmpgt_epi8(a3&bottom,zero);
__m256i b4 = _mm256_cmpgt_epi8(a4&bottom,zero);
__m256i b5 = _mm256_cmpgt_epi8(a5&bottom,zero);
__m256i b6 = _mm256_cmpgt_epi8(a6&bottom,zero);
__m256i b7 = _mm256_cmpgt_epi8(a7&bottom,zero);
int32_t c0 = _mm256_movemask_epi8(b0);
int32_t c1 = _mm256_movemask_epi8(b1);
int32_t c2 = _mm256_movemask_epi8(b2);
int32_t c3 = _mm256_movemask_epi8(b3);
int32_t c4 = _mm256_movemask_epi8(b4);
int32_t c5 = _mm256_movemask_epi8(b5);
int32_t c6 = _mm256_movemask_epi8(b6);
int32_t c7 = _mm256_movemask_epi8(b7);
0[(int32_t *) s] = c0;
1[(int32_t *) s] = c1;
2[(int32_t *) s] = c2;
3[(int32_t *) s] = c3;
4[(int32_t *) s] = c4;
5[(int32_t *) s] = c5;
6[(int32_t *) s] = c6;
7[(int32_t *) s] = c7;
}