2006-12-16 18:54:02 +00:00
|
|
|
/*
|
|
|
|
include/common/debug.h
|
|
|
|
This files contains some macros to help debugging.
|
|
|
|
|
|
|
|
Copyright (C) 2000-2006 Willy Tarreau - w@1wt.eu
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
|
|
modify it under the terms of the GNU Lesser General Public
|
|
|
|
License as published by the Free Software Foundation, version 2.1
|
|
|
|
exclusively.
|
|
|
|
|
|
|
|
This library 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
|
|
|
|
Lesser General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
|
|
License along with this library; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _COMMON_DEBUG_H
|
|
|
|
#define _COMMON_DEBUG_H
|
|
|
|
|
2020-05-27 10:58:42 +00:00
|
|
|
#include <haproxy/api.h>
|
2015-09-25 23:27:43 +00:00
|
|
|
#include <common/memory.h>
|
2006-12-16 18:54:02 +00:00
|
|
|
|
|
|
|
#ifdef DEBUG_FULL
|
2006-12-16 22:22:58 +00:00
|
|
|
#define DPRINTF(x...) fprintf(x)
|
2006-12-16 18:54:02 +00:00
|
|
|
#else
|
|
|
|
#define DPRINTF(x...)
|
|
|
|
#endif
|
|
|
|
|
2006-12-16 22:22:58 +00:00
|
|
|
#ifdef DEBUG_FSM
|
|
|
|
#define FSM_PRINTF(x...) fprintf(x)
|
|
|
|
#else
|
|
|
|
#define FSM_PRINTF(x...)
|
|
|
|
#endif
|
|
|
|
|
2008-08-16 12:55:08 +00:00
|
|
|
/* This abort is more efficient than abort() because it does not mangle the
|
|
|
|
* stack and stops at the exact location we need.
|
|
|
|
*/
|
2019-05-14 15:22:28 +00:00
|
|
|
#define ABORT_NOW() (*(volatile int*)1=0)
|
2008-08-16 12:55:08 +00:00
|
|
|
|
2019-05-14 15:27:52 +00:00
|
|
|
/* BUG_ON: complains if <cond> is true when DEBUG_STRICT or DEBUG_STRICT_NOCRASH
|
|
|
|
* are set, does nothing otherwise. With DEBUG_STRICT in addition it immediately
|
|
|
|
* crashes using ABORT_NOW() above.
|
|
|
|
*/
|
|
|
|
#if defined(DEBUG_STRICT) || defined(DEBUG_STRICT_NOCRASH)
|
|
|
|
#if defined(DEBUG_STRICT)
|
|
|
|
#define CRASH_NOW() ABORT_NOW()
|
|
|
|
#else
|
|
|
|
#define CRASH_NOW()
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define BUG_ON(cond) _BUG_ON(cond, __FILE__, __LINE__)
|
|
|
|
#define _BUG_ON(cond, file, line) __BUG_ON(cond, file, line)
|
|
|
|
#define __BUG_ON(cond, file, line) \
|
|
|
|
do { \
|
|
|
|
if (unlikely(cond)) { \
|
|
|
|
const char msg[] = "\nFATAL: bug condition \"" #cond "\" matched at " file ":" #line "\n"; \
|
2020-03-14 09:58:35 +00:00
|
|
|
DISGUISE(write(2, msg, strlen(msg))); \
|
2019-05-14 15:27:52 +00:00
|
|
|
CRASH_NOW(); \
|
|
|
|
} \
|
|
|
|
} while (0)
|
|
|
|
#else
|
|
|
|
#undef CRASH_NOW
|
|
|
|
#define BUG_ON(cond)
|
|
|
|
#endif
|
|
|
|
|
2019-05-16 15:44:30 +00:00
|
|
|
struct task;
|
2019-05-17 08:36:08 +00:00
|
|
|
struct buffer;
|
2019-07-31 17:20:39 +00:00
|
|
|
extern volatile unsigned long threads_to_dump;
|
2019-10-24 16:18:02 +00:00
|
|
|
extern unsigned int debug_commands_issued;
|
2019-05-17 08:36:08 +00:00
|
|
|
void ha_task_dump(struct buffer *buf, const struct task *task, const char *pfx);
|
|
|
|
void ha_thread_dump(struct buffer *buf, int thr, int calling_tid);
|
2019-05-17 08:08:49 +00:00
|
|
|
void ha_thread_dump_all_to_trash();
|
2019-05-20 11:48:29 +00:00
|
|
|
void ha_panic();
|
2019-05-16 15:44:30 +00:00
|
|
|
|
2015-09-25 23:27:43 +00:00
|
|
|
/* This one is useful to automatically apply poisonning on an area returned
|
|
|
|
* by malloc(). Only "p_" is required to make it work, and to define a poison
|
|
|
|
* byte using -dM.
|
|
|
|
*/
|
|
|
|
static inline void *p_malloc(size_t size)
|
|
|
|
{
|
|
|
|
void *ret = malloc(size);
|
2015-10-08 12:12:13 +00:00
|
|
|
if (mem_poison_byte >= 0 && ret)
|
2015-09-25 23:27:43 +00:00
|
|
|
memset(ret, mem_poison_byte, size);
|
|
|
|
return ret;
|
|
|
|
}
|
2008-06-13 20:36:31 +00:00
|
|
|
|
2006-12-16 18:54:02 +00:00
|
|
|
#endif /* _COMMON_DEBUG_H */
|