aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPedro Alves <palves@redhat.com>2010-03-16 17:47:52 +0000
committerPedro Alves <palves@redhat.com>2010-03-16 17:47:52 +0000
commite92d13d5bcf6a7d365fcbaae5af81ad80648fe8f (patch)
tree71ac9c810f41ac867f425f508ee10f7be9061305
parent46956e396d10846a7ab0374a71bb1204bdd4d0d5 (diff)
downloadgdb-e92d13d5bcf6a7d365fcbaae5af81ad80648fe8f.zip
gdb-e92d13d5bcf6a7d365fcbaae5af81ad80648fe8f.tar.gz
gdb-e92d13d5bcf6a7d365fcbaae5af81ad80648fe8f.tar.bz2
gdb/gdbserver/
* server.h (internal_error): Declare. (gdb_assert, ASSERT_FUNCTION, gdb_assert_fail): Define. * utils.c (internal_error): New function.
-rw-r--r--gdb/gdbserver/ChangeLog6
-rw-r--r--gdb/gdbserver/server.h30
-rw-r--r--gdb/gdbserver/utils.c16
3 files changed, 52 insertions, 0 deletions
diff --git a/gdb/gdbserver/ChangeLog b/gdb/gdbserver/ChangeLog
index e76390e..2944489 100644
--- a/gdb/gdbserver/ChangeLog
+++ b/gdb/gdbserver/ChangeLog
@@ -1,3 +1,9 @@
+2010-03-16 Pedro Alves <pedro@codesourcery.com>
+
+ * server.h (internal_error): Declare.
+ (gdb_assert, ASSERT_FUNCTION, gdb_assert_fail): Define.
+ * utils.c (internal_error): New function.
+
2010-03-15 Andreas Schwab <schwab@redhat.com>
* configure.srv: Fix typo setting srv_regobj.
diff --git a/gdb/gdbserver/server.h b/gdb/gdbserver/server.h
index f46ee60..1823295 100644
--- a/gdb/gdbserver/server.h
+++ b/gdb/gdbserver/server.h
@@ -407,9 +407,39 @@ void freeargv (char **argv);
void perror_with_name (const char *string);
void error (const char *string,...) ATTR_NORETURN ATTR_FORMAT (printf, 1, 2);
void fatal (const char *string,...) ATTR_NORETURN ATTR_FORMAT (printf, 1, 2);
+void internal_error (const char *file, int line, const char *, ...)
+ ATTR_NORETURN ATTR_FORMAT (printf, 3, 4);
void warning (const char *string,...) ATTR_FORMAT (printf, 1, 2);
char *paddress (CORE_ADDR addr);
+#define gdb_assert(expr) \
+ ((void) ((expr) ? 0 : \
+ (gdb_assert_fail (#expr, __FILE__, __LINE__, ASSERT_FUNCTION), 0)))
+
+/* Version 2.4 and later of GCC define a magical variable `__PRETTY_FUNCTION__'
+ which contains the name of the function currently being defined.
+ This is broken in G++ before version 2.6.
+ C9x has a similar variable called __func__, but prefer the GCC one since
+ it demangles C++ function names. */
+#if (GCC_VERSION >= 2004)
+#define ASSERT_FUNCTION __PRETTY_FUNCTION__
+#else
+#if defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L
+#define ASSERT_FUNCTION __func__
+#endif
+#endif
+
+/* This prints an "Assertion failed" message, and exits. */
+#if defined (ASSERT_FUNCTION)
+#define gdb_assert_fail(assertion, file, line, function) \
+ internal_error (file, line, "%s: Assertion `%s' failed.", \
+ function, assertion)
+#else
+#define gdb_assert_fail(assertion, file, line, function) \
+ internal_error (file, line, "Assertion `%s' failed.", \
+ assertion)
+#endif
+
/* Maximum number of bytes to read/write at once. The value here
is chosen to fill up a packet (the headers account for the 32). */
#define MAXBUFBYTES(N) (((N)-32)/2)
diff --git a/gdb/gdbserver/utils.c b/gdb/gdbserver/utils.c
index 6035f1e..78c6f66 100644
--- a/gdb/gdbserver/utils.c
+++ b/gdb/gdbserver/utils.c
@@ -171,6 +171,22 @@ warning (const char *string,...)
va_end (args);
}
+/* Report a problem internal to GDBserver, and exit. */
+
+void
+internal_error (const char *file, int line, const char *fmt, ...)
+{
+ va_list args;
+ va_start (args, fmt);
+
+ fprintf (stderr, "\
+%s:%d: A problem internal to GDBserver has been detected.\n", file, line);
+ vfprintf (stderr, fmt, args);
+ fprintf (stderr, "\n");
+ va_end (args);
+ exit (1);
+}
+
/* Temporary storage using circular buffer. */
#define NUMCELLS 4
#define CELLSIZE 50