diff options
author | Andres Freund <andres@anarazel.de> | 2016-04-13 16:42:01 -0700 |
---|---|---|
committer | Andres Freund <andres@anarazel.de> | 2016-04-13 17:00:53 -0700 |
commit | 80abbeba23d466b6541cf95082a9e1f36704424e (patch) | |
tree | 088426c853cdd776344f04ede1d4a3bae9e3b29d /src/include/utils/elog.h | |
parent | 6cead413bb92be0579a2dbf6320121edcc32e369 (diff) | |
download | postgresql-80abbeba23d466b6541cf95082a9e1f36704424e.tar.gz |
Make init_spin_delay() C89 compliant and change stuck spinlock reporting.
The current definition of init_spin_delay (introduced recently in
48354581a) wasn't C89 compliant. It's not legal to refer to refer to
non-constant expressions, and the ptr argument was one. This, as
reported by Tom, lead to a failure on buildfarm animal pademelon.
The pointer, especially on system systems with ASLR, isn't super helpful
anyway, though. So instead of making init_spin_delay into an inline
function, make s_lock_stuck() report the function name in addition to
file:line and change init_spin_delay() accordingly. While not a direct
replacement, the function name is likely more useful anyway (line
numbers are often hard to interpret in third party reports).
This also fixes what file/line number is reported for waits via
s_lock().
As PG_FUNCNAME_MACRO is now used outside of elog.h, move it to c.h.
Reported-By: Tom Lane
Discussion: 4369.1460435533@sss.pgh.pa.us
Diffstat (limited to 'src/include/utils/elog.h')
-rw-r--r-- | src/include/utils/elog.h | 12 |
1 files changed, 0 insertions, 12 deletions
diff --git a/src/include/utils/elog.h b/src/include/utils/elog.h index 7471dadd4b..c43e5b8943 100644 --- a/src/include/utils/elog.h +++ b/src/include/utils/elog.h @@ -71,18 +71,6 @@ #include "utils/errcodes.h" -/* Which __func__ symbol do we have, if any? */ -#ifdef HAVE_FUNCNAME__FUNC -#define PG_FUNCNAME_MACRO __func__ -#else -#ifdef HAVE_FUNCNAME__FUNCTION -#define PG_FUNCNAME_MACRO __FUNCTION__ -#else -#define PG_FUNCNAME_MACRO NULL -#endif -#endif - - /*---------- * New-style error reporting API: to be used in this way: * ereport(ERROR, |