annotate gcc/testsuite/gcc.dg/ia64-sync-3.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-do run } */
kono
parents:
diff changeset
2 /* { dg-require-effective-target sync_int_long } */
kono
parents:
diff changeset
3 /* { dg-options } */
kono
parents:
diff changeset
4 /* { dg-options "-march=i486" { target { { i?86-*-* x86_64-*-* } && ia32 } } } */
kono
parents:
diff changeset
5 /* { dg-options "-mcpu=v9" { target sparc*-*-* } } */
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 /* Test basic functionality of the intrinsics. */
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 __extension__ typedef __SIZE_TYPE__ size_t;
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 extern void abort (void);
kono
parents:
diff changeset
12 extern void *memcpy (void *, const void *, size_t);
kono
parents:
diff changeset
13 extern int memcmp (const void *, const void *, size_t);
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 static int AI[4];
kono
parents:
diff changeset
16 static int init_si[4] = { -30,-30,-50,-50 };
kono
parents:
diff changeset
17 static int test_si[4] = { -115,-115,25,25 };
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19 static void
kono
parents:
diff changeset
20 do_si (void)
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 if (__sync_val_compare_and_swap(AI+0, -30, -115) != -30)
kono
parents:
diff changeset
23 abort ();
kono
parents:
diff changeset
24 if (__sync_val_compare_and_swap(AI+0, -30, -115) != -115)
kono
parents:
diff changeset
25 abort ();
kono
parents:
diff changeset
26 if (__sync_bool_compare_and_swap(AI+1, -30, -115) != 1)
kono
parents:
diff changeset
27 abort ();
kono
parents:
diff changeset
28 if (__sync_bool_compare_and_swap(AI+1, -30, -115) != 0)
kono
parents:
diff changeset
29 abort ();
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 if (__sync_val_compare_and_swap(AI+2, AI[2], 25) != -50)
kono
parents:
diff changeset
32 abort ();
kono
parents:
diff changeset
33 if (__sync_val_compare_and_swap(AI+2, AI[2], 25) != 25)
kono
parents:
diff changeset
34 abort ();
kono
parents:
diff changeset
35 if (__sync_bool_compare_and_swap(AI+3, AI[3], 25) != 1)
kono
parents:
diff changeset
36 abort ();
kono
parents:
diff changeset
37 if (__sync_bool_compare_and_swap(AI+3, AI[3], 25) != 1)
kono
parents:
diff changeset
38 abort ();
kono
parents:
diff changeset
39 }
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 static long AL[4];
kono
parents:
diff changeset
42 static long init_di[4] = { -30,-30,-50,-50 };
kono
parents:
diff changeset
43 static long test_di[4] = { -115,-115,25,25 };
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 static void
kono
parents:
diff changeset
46 do_di (void)
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 if (__sync_val_compare_and_swap(AL+0, -30, -115) != -30)
kono
parents:
diff changeset
49 abort ();
kono
parents:
diff changeset
50 if (__sync_val_compare_and_swap(AL+0, -30, -115) != -115)
kono
parents:
diff changeset
51 abort ();
kono
parents:
diff changeset
52 if (__sync_bool_compare_and_swap(AL+1, -30, -115) != 1)
kono
parents:
diff changeset
53 abort ();
kono
parents:
diff changeset
54 if (__sync_bool_compare_and_swap(AL+1, -30, -115) != 0)
kono
parents:
diff changeset
55 abort ();
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 if (__sync_val_compare_and_swap(AL+2, AL[2], 25) != -50)
kono
parents:
diff changeset
58 abort ();
kono
parents:
diff changeset
59 if (__sync_val_compare_and_swap(AL+2, AL[2], 25) != 25)
kono
parents:
diff changeset
60 abort ();
kono
parents:
diff changeset
61 if (__sync_bool_compare_and_swap(AL+3, AL[3], 25) != 1)
kono
parents:
diff changeset
62 abort ();
kono
parents:
diff changeset
63 if (__sync_bool_compare_and_swap(AL+3, AL[3], 25) != 1)
kono
parents:
diff changeset
64 abort ();
kono
parents:
diff changeset
65 }
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 int main()
kono
parents:
diff changeset
68 {
kono
parents:
diff changeset
69 memcpy(AI, init_si, sizeof(init_si));
kono
parents:
diff changeset
70 memcpy(AL, init_di, sizeof(init_di));
kono
parents:
diff changeset
71
kono
parents:
diff changeset
72 do_si ();
kono
parents:
diff changeset
73 do_di ();
kono
parents:
diff changeset
74
kono
parents:
diff changeset
75 if (memcmp (AI, test_si, sizeof(test_si)))
kono
parents:
diff changeset
76 abort ();
kono
parents:
diff changeset
77 if (memcmp (AL, test_di, sizeof(test_di)))
kono
parents:
diff changeset
78 abort ();
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 return 0;
kono
parents:
diff changeset
81 }