source: libcfa/src/bits/debug.hfa @ cdf7d43

Last change on this file since cdf7d43 was 16cc9f7, checked in by Peter A. Buhr <pabuhr@…>, 3 years ago

change cfaabi_bits_print... routines to return the number of characters printed

  • Property mode set to 100644
File size: 6.4 KB
Line 
1//
2// Cforall Version 1.0.0 Copyright (C) 2016 University of Waterloo
3//
4// The contents of this file are covered under the licence agreement in the
5// file "LICENCE" distributed with Cforall.
6//
7// debug.hfa --
8//
9// Author           : Thierry Delisle
10// Created On       : Mon Nov 28 12:27:26 2016
11// Last Modified By : Peter A. Buhr
12// Last Modified On : Fri Apr 22 18:21:56 2022
13// Update Count     : 11
14//
15
16#pragma once
17
18#include <assert.h>
19
20#ifdef __CFA_DEBUG__
21        #define __cfaabi_dbg_debug_do(...) __VA_ARGS__
22        #define __cfaabi_dbg_no_debug_do(...)
23        #define __cfaabi_dbg_ctx __PRETTY_FUNCTION__
24        #define __cfaabi_dbg_ctx2 , __PRETTY_FUNCTION__
25        #define __cfaabi_dbg_ctx_param const char caller[]
26        #define __cfaabi_dbg_ctx_param2 , const char caller[]
27        #define __cfaabi_dbg_ctx_fwd caller
28        #define __cfaabi_dbg_ctx_fwd2 , caller
29#else
30        #define __cfaabi_dbg_debug_do(...)
31        #define __cfaabi_dbg_no_debug_do(...) __VA_ARGS__
32        #define __cfaabi_dbg_ctx
33        #define __cfaabi_dbg_ctx2
34        #define __cfaabi_dbg_ctx_param
35        #define __cfaabi_dbg_ctx_param2
36        #define __cfaabi_dbg_ctx_fwd
37        #define __cfaabi_dbg_ctx_fwd2
38#endif
39
40#ifdef __cforall
41extern "C" {
42#endif
43        #include <stdarg.h>
44
45        extern void __cfaabi_bits_write( int fd, const char buffer[], int len );
46        extern void __cfaabi_bits_acquire();
47        extern void __cfaabi_bits_release();
48        extern int __cfaabi_bits_print_safe  ( int fd, const char fmt[], ... ) __attribute__(( format(printf, 2, 3) ));
49        extern int __cfaabi_bits_print_nolock( int fd, const char fmt[], ... ) __attribute__(( format(printf, 2, 3) ));
50        extern int __cfaabi_bits_print_vararg( int fd, const char fmt[], va_list arg );
51        extern int __cfaabi_bits_print_buffer( int fd, char buffer[], int buffer_size, const char fmt[], ... ) __attribute__(( format(printf, 4, 5) ));
52
53#if defined(__CFA_DEBUG_PRINT__) \
54                || defined(__CFA_DEBUG_PRINT_IO__) || defined(__CFA_DEBUG_PRINT_IO_CORE__) \
55                || defined(__CFA_DEBUG_PRINT_MONITOR__) || defined(__CFA_DEBUG_PRINT_PREEMPTION__) \
56                || defined(__CFA_DEBUG_PRINT_RUNTIME_CORE__) || defined(__CFA_DEBUG_PRINT_EXCEPTION__) \
57                || defined(__CFA_DEBUG_PRINT_READY_QUEUE__)
58        #include <stdio.h>
59        #include <unistd.h>
60#endif
61#ifdef __cforall
62}
63#endif
64
65// Deprecated: Use the versions with the new module names.
66#ifdef __CFA_DEBUG_PRINT__
67        #define __cfaabi_dbg_write( buffer, len )         __cfaabi_bits_write( STDERR_FILENO, buffer, len )
68        #define __cfaabi_dbg_acquire()                    __cfaabi_bits_acquire()
69        #define __cfaabi_dbg_release()                    __cfaabi_bits_release()
70        #define __cfaabi_dbg_print_safe(...)              __cfaabi_bits_print_safe   ( STDERR_FILENO, __VA_ARGS__ )
71        #define __cfaabi_dbg_print_nolock(...)            __cfaabi_bits_print_nolock ( STDERR_FILENO, __VA_ARGS__ )
72        #define __cfaabi_dbg_print_buffer(...)            __cfaabi_bits_print_buffer ( STDERR_FILENO, __VA_ARGS__ )
73        #define __cfaabi_dbg_print_buffer_decl(...)       char __dbg_text[256]; int __dbg_len = snprintf( __dbg_text, 256, __VA_ARGS__ ); __cfaabi_bits_write( STDERR_FILENO, __dbg_text, __dbg_len );
74        #define __cfaabi_dbg_print_buffer_local(...)      __dbg_len = snprintf( __dbg_text, 256, __VA_ARGS__ ); __cfaabi_dbg_write( STDERR_FILENO, __dbg_text, __dbg_len );
75#else
76        #define __cfaabi_dbg_write(...)               ((void)0)
77        #define __cfaabi_dbg_acquire()                ((void)0)
78        #define __cfaabi_dbg_release()                ((void)0)
79        #define __cfaabi_dbg_print_safe(...)          ((void)0)
80        #define __cfaabi_dbg_print_nolock(...)        ((void)0)
81        #define __cfaabi_dbg_print_buffer(...)        ((void)0)
82        #define __cfaabi_dbg_print_buffer_decl(...)   ((void)0)
83        #define __cfaabi_dbg_print_buffer_local(...)  ((void)0)
84#endif
85
86// Debug print functions and statements:
87// Most are wrappers around the bits printing function but are not always used.
88// If they are used depends if the group (first argument) is active or not. The group must be one
89// defined belowe. The other arguments depend on the wrapped function.
90#define __cfadbg_write(group, buffer, len) \
91        __CFADBG_PRINT_GROUP_##group(__cfaabi_bits_write(STDERR_FILENO, buffer, len))
92#define __cfadbg_acquire(group) \
93        __CFADBG_PRINT_GROUP_##group(__cfaabi_bits_acquire())
94#define __cfadbg_release(group) \
95        __CFADBG_PRINT_GROUP_##group(__cfaabi_bits_release())
96#define __cfadbg_print_safe(group, ...) \
97        __CFADBG_PRINT_GROUP_##group(__cfaabi_bits_print_safe(STDERR_FILENO, __VA_ARGS__))
98#define __cfadbg_print_nolock(group, ...) \
99        __CFADBG_PRINT_GROUP_##group(__cfaabi_bits_print_nolock(STDERR_FILENO, __VA_ARGS__))
100#define __cfadbg_print_buffer(group, ...) \
101        __CFADBG_PRINT_GROUP_##group(__cfaabi_bits_print_buffer(STDERR_FILENO, __VA_ARGS__))
102#define __cfadbg_print_buffer_decl(group, ...) \
103        __CFADBG_PRINT_GROUP_##group(char __dbg_text[256]; int __dbg_len = snprintf( __dbg_text, 256, __VA_ARGS__ ); __cfaabi_bits_write( STDERR_FILENO, __dbg_text, __dbg_len ))
104#define __cfadbg_print_buffer_local(group, ...) \
105        __CFADBG_PRINT_GROUP_##group(__dbg_len = snprintf( __dbg_text, 256, __VA_ARGS__ ); __cfaabi_bits_write(STDERR_FILENO, __dbg_text, __dbg_len))
106
107// The debug print groups:
108#if defined(__CFA_DEBUG_PRINT__) || defined(__CFA_DEBUG_PRINT_IO__)
109#       define __CFADBG_PRINT_GROUP_io(...) __VA_ARGS__
110#else
111#       define __CFADBG_PRINT_GROUP_io(...) ((void)0)
112#endif
113#if defined(__CFA_DEBUG_PRINT__) || defined(__CFA_DEBUG_PRINT_IO__) || defined(__CFA_DEBUG_PRINT_IO_CORE__)
114#       define __CFADBG_PRINT_GROUP_io_core(...) __VA_ARGS__
115#else
116#       define __CFADBG_PRINT_GROUP_io_core(...) ((void)0)
117#endif
118#if defined(__CFA_DEBUG_PRINT__) || defined(__CFA_DEBUG_PRINT_MONITOR__)
119#       define __CFADBG_PRINT_GROUP_monitor(...) __VA_ARGS__
120#else
121#       define __CFADBG_PRINT_GROUP_monitor(...) ((void)0)
122#endif
123#if defined(__CFA_DEBUG_PRINT__) || defined(__CFA_DEBUG_PRINT_PREEMPTION__)
124#       define __CFADBG_PRINT_GROUP_preemption(...) __VA_ARGS__
125#else
126#       define __CFADBG_PRINT_GROUP_preemption(...) ((void)0)
127#endif
128#if defined(__CFA_DEBUG_PRINT__) || defined(__CFA_DEBUG_PRINT_RUNTIME_CORE__)
129#       define __CFADBG_PRINT_GROUP_runtime_core(...) __VA_ARGS__
130#else
131#       define __CFADBG_PRINT_GROUP_runtime_core(...) ((void)0)
132#endif
133#if defined(__CFA_DEBUG_PRINT__) || defined(__CFA_DEBUG_PRINT_READY_QUEUE__)
134#       define __CFADBG_PRINT_GROUP_ready_queue(...) __VA_ARGS__
135#else
136#       define __CFADBG_PRINT_GROUP_ready_queue(...) ((void)0)
137#endif
138#if defined(__CFA_DEBUG_PRINT__) || defined(__CFA_DEBUG_PRINT_EXCEPTION__)
139#       define __CFADBG_PRINT_GROUP_exception(...) __VA_ARGS__
140#else
141#       define __CFADBG_PRINT_GROUP_exception(...) ((void)0)
142#endif
143
144// Local Variables: //
145// mode: c //
146// tab-width: 4 //
147// End: //
Note: See TracBrowser for help on using the repository browser.