aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gcc.target/aarch64/sha1_1.c
blob: 776753dcd5f825f32ba6ad30b61ba694c4f7e999 (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
44
45
46
47
48
49
50
51
52
53
54
55

/* { dg-do compile } */
/* { dg-options "-march=armv8-a+crypto" } */

#include "arm_neon.h"

uint32x4_t
test_vsha1cq_u32 (uint32x4_t hash_abcd, uint32_t hash_e, uint32x4_t wk)
{
  return vsha1cq_u32 (hash_abcd, hash_e, wk);
}

/* { dg-final { scan-assembler-times "sha1c\\tq" 1 } } */

uint32x4_t
test_vsha1mq_u32 (uint32x4_t hash_abcd, uint32_t hash_e, uint32x4_t wk)
{
  return vsha1mq_u32 (hash_abcd, hash_e, wk);
}

/* { dg-final { scan-assembler-times "sha1m\\tq" 1 } } */

uint32x4_t
test_vsha1pq_u32 (uint32x4_t hash_abcd, uint32_t hash_e, uint32x4_t wk)
{
  return vsha1pq_u32 (hash_abcd, hash_e, wk);
}

/* { dg-final { scan-assembler-times "sha1p\\tq" 1 } } */

uint32_t
test_vsha1h_u32 (uint32_t hash_e)
{
  return vsha1h_u32 (hash_e);
}

/* { dg-final { scan-assembler-times "sha1h\\ts" 1 } } */

uint32x4_t
test_vsha1su0q_u32 (uint32x4_t w0_3, uint32x4_t w4_7, uint32x4_t w8_11)
{
  return vsha1su0q_u32 (w0_3, w4_7, w8_11);
}

/* { dg-final { scan-assembler-times "sha1su0\\tv" 1 } } */

uint32x4_t
test_vsha1su1q_u32 (uint32x4_t tw0_3, uint32x4_t w12_15)
{
  return vsha1su1q_u32 (tw0_3, w12_15);
}

/* { dg-final { scan-assembler-times "sha1su1\\tv" 1 } } */

/* { dg-final { cleanup-saved-temps } } */