aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/arm/aes_xor_combine.c
blob: 17ae1c53e4a9bcb0bd439fd504ceafda4496d809 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
/* { dg-do compile } */
/* { dg-require-effective-target arm_crypto_ok } */
/* { dg-add-options arm_crypto } */
/* { dg-additional-options "-O3" } */

#include <arm_neon.h>

#define AESE(r, v, key) (r = vaeseq_u8 ((v), (key)));
#define AESD(r, v, key) (r = vaesdq_u8 ((v), (key)));

const uint8x16_t zero = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};

uint8x16_t foo_key_0 (uint8x16_t dummy, uint8x16_t foo, uint8x16_t bar)
{
    dummy = dummy ^ foo;
    AESE(dummy, dummy, zero);
    dummy = dummy ^ bar;
    AESE(dummy, dummy, zero);

    dummy = dummy ^ foo;
    AESD(dummy, dummy, zero);
    dummy = dummy ^ bar;
    AESD(dummy, dummy, zero);

    return dummy;
}

uint8x16_t foo_data_0 (uint8x16_t dummy, uint8x16_t foo, uint8x16_t bar)
{
    dummy = dummy ^ foo;
    AESE(dummy, zero, dummy);
    dummy = dummy ^ bar;
    AESE(dummy, zero, dummy);

    dummy = dummy ^ foo;
    AESD(dummy, zero, dummy);
    dummy = dummy ^ bar;
    AESD(dummy, zero, dummy);

    return dummy;
}

/* { dg-final { scan-assembler-not "veor" } } */