diff options
author | Jan Kratochvil <jan.kratochvil@redhat.com> | 2010-08-31 18:11:48 +0000 |
---|---|---|
committer | Jan Kratochvil <jan.kratochvil@redhat.com> | 2010-08-31 18:11:48 +0000 |
commit | 06253dd31f4ce1b549d8ba0755dbb71cfb748772 (patch) | |
tree | 7d20a4149603d61a43c33f66be2ba9d1d14e1375 /gdb/linux-tdep.c | |
parent | b8edc417a7143d28618086f1d6d946201001a075 (diff) | |
download | binutils-gdb-06253dd31f4ce1b549d8ba0755dbb71cfb748772.tar.gz |
gdb/
Make linux_get_siginfo_type `type *' unique.
* linux-tdep.c (linux_gdbarch_data_handle, struct linux_gdbarch_data)
(init_linux_gdbarch_data, get_linux_gdbarch_data): New.
(linux_get_siginfo_type): New variable linux_gdbarch_data. Initialize
it. Use linux_gdbarch_data->siginfo_type as a persistent storage.
(_initialize_linux_tdep): New.
Diffstat (limited to 'gdb/linux-tdep.c')
-rw-r--r-- | gdb/linux-tdep.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/gdb/linux-tdep.c b/gdb/linux-tdep.c index 004451e5c1a..c51ede9c618 100644 --- a/gdb/linux-tdep.c +++ b/gdb/linux-tdep.c @@ -25,18 +25,42 @@ #include "elf/common.h" #include "inferior.h" +static struct gdbarch_data *linux_gdbarch_data_handle; + +struct linux_gdbarch_data + { + struct type *siginfo_type; + }; + +static void * +init_linux_gdbarch_data (struct gdbarch *gdbarch) +{ + return GDBARCH_OBSTACK_ZALLOC (gdbarch, struct linux_gdbarch_data); +} + +static struct linux_gdbarch_data * +get_linux_gdbarch_data (struct gdbarch *gdbarch) +{ + return gdbarch_data (gdbarch, linux_gdbarch_data_handle); +} + /* This function is suitable for architectures that don't extend/override the standard siginfo structure. */ struct type * linux_get_siginfo_type (struct gdbarch *gdbarch) { + struct linux_gdbarch_data *linux_gdbarch_data; struct type *int_type, *uint_type, *long_type, *void_ptr_type; struct type *uid_type, *pid_type; struct type *sigval_type, *clock_type; struct type *siginfo_type, *sifields_type; struct type *type; + linux_gdbarch_data = get_linux_gdbarch_data (gdbarch); + if (linux_gdbarch_data->siginfo_type != NULL) + return linux_gdbarch_data->siginfo_type; + int_type = arch_integer_type (gdbarch, gdbarch_int_bit (gdbarch), 0, "int"); uint_type = arch_integer_type (gdbarch, gdbarch_int_bit (gdbarch), @@ -136,6 +160,8 @@ linux_get_siginfo_type (struct gdbarch *gdbarch) "_sifields", sifields_type, TYPE_LENGTH (long_type)); + linux_gdbarch_data->siginfo_type = siginfo_type; + return siginfo_type; } @@ -178,3 +204,10 @@ linux_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch) { set_gdbarch_core_pid_to_str (gdbarch, linux_core_pid_to_str); } + +void +_initialize_linux_tdep (void) +{ + linux_gdbarch_data_handle = + gdbarch_data_register_post_init (init_linux_gdbarch_data); +} |