aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite/gdb.arch/ppc64-break-on-_exit.c
blob: dfa05a6f3944226602211036a56a8751992140ba (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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/* This file is part of GDB, the GNU debugger.

   Copyright 2021-2022 Free Software Foundation, Inc.

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; either version 3 of the License, or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */

/* This file was generated from glibc's 2.31 _exit.c, by doing a glibc build
   on ppc64le-linux, copying the command line, adding -g0 -save-temps and
   recuding the _exit.i file.  */

void _exit (int status);

extern __thread int __libc_errno;

void
_exit (int status)
{
  while (1)
    {
      ({
	long int sc_err __attribute__ ((unused));
	long int sc_ret
	  = ({
	      register long int r0 __asm__ ("r0");
	      register long int r3 __asm__ ("r3");
	      register long int r4 __asm__ ("r4");
	      register long int r5 __asm__ ("r5");
	      register long int r6 __asm__ ("r6");
	      register long int r7 __asm__ ("r7");
	      register long int r8 __asm__ ("r8");
	      long int arg1 = (long int) (status);

	      r0 = 234;

	      extern void __illegally_sized_syscall_arg1 (void);
	      if (__builtin_classify_type (status) != 5 && sizeof (status) > 8)
		__illegally_sized_syscall_arg1 ();

	      r3 = arg1;
	      __asm__ __volatile__ ("sc\n\t" "mfcr  %0\n\t" "0:"
				    : "=&r" (r0), "=&r" (r3), "=&r" (r4),
				      "=&r" (r5), "=&r" (r6), "=&r" (r7),
				      "=&r" (r8) : "0" (r0), "1" (r3)
				    : "r9", "r10", "r11", "r12", "cr0", "ctr", "memory");
	      sc_err = r0;

	      r3;
	    });

	if (((void) (sc_ret), __builtin_expect ((sc_err) & (1 << 28), 0)))
	  {
	    (__libc_errno = ((sc_ret)));
	    sc_ret = -1L;
	  }

	sc_ret;
      });

      ({
	long int sc_err __attribute__ ((unused));
	long int sc_ret
	  = ({
	      register long int r0 __asm__ ("r0");
	      register long int r3 __asm__ ("r3");
	      register long int r4 __asm__ ("r4");
	      register long int r5 __asm__ ("r5");
	      register long int r6 __asm__ ("r6");
	      register long int r7 __asm__ ("r7");
	      register long int r8 __asm__ ("r8");
	      long int arg1 = (long int) (status);

	      r0 = 1;

	      extern void __illegally_sized_syscall_arg1 (void);
	      if (__builtin_classify_type (status) != 5 && sizeof (status) > 8)
		__illegally_sized_syscall_arg1 ();

	      r3 = arg1;
	      __asm__ __volatile__ ("sc\n\t" "mfcr  %0\n\t" "0:"
				    : "=&r" (r0), "=&r" (r3), "=&r" (r4),
				      "=&r" (r5), "=&r" (r6), "=&r" (r7),
				      "=&r" (r8) : "0" (r0), "1" (r3)
				    : "r9", "r10", "r11", "r12", "cr0", "ctr", "memory");
	      sc_err = r0;

	      r3;
	    });

	if (((void) (sc_ret), __builtin_expect ((sc_err) & (1 << 28), 0)))
	  {
	    (__libc_errno = ((sc_ret)));
	    sc_ret = -1L;
	  }

	sc_ret;
      });


      asm (".long 0");
    }
}