annotate gcc/testsuite/gcc.dg/torture/pr68037-3.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-do run { target i?86-*-* x86_64-*-* } } */
kono
parents:
diff changeset
2 /* { dg-options "-mgeneral-regs-only" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include <stddef.h>
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 extern void exit (int);
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 typedef unsigned int uword_t __attribute__ ((mode (__word__)));
kono
parents:
diff changeset
9 typedef int aligned __attribute__((aligned(64)));
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 #define IP 0x12345671
kono
parents:
diff changeset
12 #define CS 0x12345672
kono
parents:
diff changeset
13 #define FLAGS 0x12345673
kono
parents:
diff changeset
14 #define SP 0x12345674
kono
parents:
diff changeset
15 #define SS 0x12345675
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 #define STRING(x) XSTRING(x)
kono
parents:
diff changeset
18 #define XSTRING(x) #x
kono
parents:
diff changeset
19 #define ASMNAME(cname) ASMNAME2 (__USER_LABEL_PREFIX__, cname)
kono
parents:
diff changeset
20 #define ASMNAME2(prefix, cname) XSTRING (prefix) cname
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 struct interrupt_frame
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 uword_t ip;
kono
parents:
diff changeset
25 uword_t cs;
kono
parents:
diff changeset
26 uword_t flags;
kono
parents:
diff changeset
27 uword_t sp;
kono
parents:
diff changeset
28 uword_t ss;
kono
parents:
diff changeset
29 };
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 int
kono
parents:
diff changeset
32 check_int (int *i, int align)
kono
parents:
diff changeset
33 {
kono
parents:
diff changeset
34 *i = 20;
kono
parents:
diff changeset
35 if ((((ptrdiff_t) i) & (align - 1)) != 0)
kono
parents:
diff changeset
36 __builtin_abort ();
kono
parents:
diff changeset
37 return *i;
kono
parents:
diff changeset
38 }
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 __attribute__((interrupt, used))
kono
parents:
diff changeset
41 void
kono
parents:
diff changeset
42 fn (struct interrupt_frame *frame)
kono
parents:
diff changeset
43 {
kono
parents:
diff changeset
44 aligned i;
kono
parents:
diff changeset
45 if (check_int (&i, __alignof__(i)) != i)
kono
parents:
diff changeset
46 __builtin_abort ();
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 if (IP != frame->ip)
kono
parents:
diff changeset
49 __builtin_abort ();
kono
parents:
diff changeset
50 if (CS != frame->cs)
kono
parents:
diff changeset
51 __builtin_abort ();
kono
parents:
diff changeset
52 if (FLAGS != frame->flags)
kono
parents:
diff changeset
53 __builtin_abort ();
kono
parents:
diff changeset
54 if (SP != frame->sp)
kono
parents:
diff changeset
55 __builtin_abort ();
kono
parents:
diff changeset
56 if (SS != frame->ss)
kono
parents:
diff changeset
57 __builtin_abort ();
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 exit (0);
kono
parents:
diff changeset
60 }
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 int
kono
parents:
diff changeset
63 main ()
kono
parents:
diff changeset
64 {
kono
parents:
diff changeset
65 asm ("push $" STRING (SS) "; \
kono
parents:
diff changeset
66 push $" STRING (SP) "; \
kono
parents:
diff changeset
67 push $" STRING (FLAGS) "; \
kono
parents:
diff changeset
68 push $" STRING (CS) "; \
kono
parents:
diff changeset
69 push $" STRING (IP) "; \
kono
parents:
diff changeset
70 jmp " ASMNAME ("fn"));
kono
parents:
diff changeset
71 return 0;
kono
parents:
diff changeset
72 }