blob: f6bd91d04c858745f3ebae46f00f72b1d07199c0 [file] [log] [blame]
J. Duke319a3b92007-12-01 00:00:00 +00001/*
2 * Copyright 2003-2004 Sun Microsystems, Inc. All Rights Reserved.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
6 * are met:
7 *
8 * - Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 *
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 *
15 * - Neither the name of Sun Microsystems nor the names of its
16 * contributors may be used to endorse or promote products derived
17 * from this software without specific prior written permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
20 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
21 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
26 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
27 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
28 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
29 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
32#ifndef HPROF_ERROR_H
33#define HPROF_ERROR_H
34
35/* Macros over assert and error functions so we can capture the source loc. */
36
37#define HPROF_BOOL(x) ((jboolean)((x)==0?JNI_FALSE:JNI_TRUE))
38
39#define HPROF_ERROR(fatal,msg) \
40 error_handler(HPROF_BOOL(fatal), JVMTI_ERROR_NONE, msg, __FILE__, __LINE__)
41
42#define HPROF_JVMTI_ERROR(error,msg) \
43 error_handler(HPROF_BOOL(error!=JVMTI_ERROR_NONE), \
44 error, msg, __FILE__, __LINE__)
45
46#if defined(DEBUG) || !defined(NDEBUG)
47 #define HPROF_ASSERT(cond) \
48 (((int)(cond))?(void)0:error_assert(#cond, __FILE__, __LINE__))
49#else
50 #define HPROF_ASSERT(cond)
51#endif
52
53#define LOG_DUMP_MISC 0x1 /* Misc. logging info */
54#define LOG_DUMP_LISTS 0x2 /* Dump tables at vm init and death */
55#define LOG_CHECK_BINARY 0x4 /* If format=b, verify binary format */
56
57#ifdef HPROF_LOGGING
58 #define LOG_STDERR(args) \
59 { \
60 if ( gdata != NULL && (gdata->logflags & LOG_DUMP_MISC) ) { \
61 (void)fprintf args ; \
62 } \
63 }
64#else
65 #define LOG_STDERR(args)
66#endif
67
68#define LOG_FORMAT(format) "HPROF LOG: " format " [%s:%d]\n"
69
70#define LOG1(str1) LOG_STDERR((stderr, LOG_FORMAT("%s"), \
71 str1, __FILE__, __LINE__ ))
72#define LOG2(str1,str2) LOG_STDERR((stderr, LOG_FORMAT("%s %s"), \
73 str1, str2, __FILE__, __LINE__ ))
74#define LOG3(str1,str2,num) LOG_STDERR((stderr, LOG_FORMAT("%s %s 0x%x"), \
75 str1, str2, num, __FILE__, __LINE__ ))
76
77#define LOG(str) LOG1(str)
78
79void error_handler(jboolean fatal, jvmtiError error,
80 const char *message, const char *file, int line);
81void error_assert(const char *condition, const char *file, int line);
82void error_exit_process(int exit_code);
83void error_do_pause(void);
84void error_setup(void);
85void debug_message(const char * format, ...);
86void verbose_message(const char * format, ...);
87
88#endif