1 /* This testcase is part of GDB, the GNU debugger.
3 Copyright 1996, 1999, 2003, 2004 Free Software Foundation, Inc.
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
26 code_entry_point
, code_descriptor
, data_read
, data_write
29 static volatile enum tests test
;
31 /* Some basic types and zero buffers. */
34 typedef long code_t (void);
35 data_t
*volatile data
;
36 code_t
*volatile code
;
37 /* "desc" is intentionally initialized to a data object. This is
38 needed to test function descriptors on arches like ia64. */
40 code_t
*volatile desc
= (code_t
*) (void *) zero
;
56 /* Try to read address zero. */
59 /* Try to write (the assignment) to address zero. */
61 case code_entry_point
:
62 /* For typical architectures, call a function at address
66 /* For atypical architectures that use function descriptors,
67 call a function descriptor, the code field of which is zero
68 (which has the effect of jumping to address zero). */
76 static volatile int i
;
79 memset (&act
, 0, sizeof act
);
80 act
.sa_handler
= keeper
;
81 sigaction (SIGSEGV
, &act
, NULL
);
83 for (i
= 0; i
< 10; i
++)