2 * Copyright (c) 2003-2005 The Regents of The University of Michigan
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are
7 * met: redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer;
9 * redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution;
12 * neither the name of the copyright holders nor the names of its
13 * contributors may be used to endorse or promote products derived from
14 * this software without specific prior written permission.
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 #include "base/debug.hh"
31 #include <sys/types.h>
37 #include "base/cprintf.hh"
38 #include "base/logging.hh"
45 // This function will cause the process to signal itself with a
46 // SIGTRAP which is ignored if not in gdb, but will cause the debugger
47 // to break if in gdb.
53 kill(getpid(), SIGTRAP
);
55 cprintf("Debug::breakpoint suppressed, compiled with NDEBUG\n");
60 // Flags for debugging purposes. Primarily for trace.hh
62 int allFlagsVersion
= 0;
66 static FlagsMap flags
;
70 bool SimpleFlag::_active
= false;
73 findFlag(const std::string
&name
)
75 FlagsMap::iterator i
= allFlags().find(name
);
76 if (i
== allFlags().end())
81 Flag::Flag(const char *name
, const char *desc
)
82 : _name(name
), _desc(desc
)
84 pair
<FlagsMap::iterator
, bool> result
=
85 allFlags().insert(make_pair(name
, this));
88 panic("Flag %s already defined!", name
);
95 // should find and remove flag.
99 SimpleFlag::enableAll()
102 for (auto& i
: allFlags())
107 SimpleFlag::disableAll()
110 for (auto& i
: allFlags())
115 CompoundFlag::enable()
117 for (auto& k
: _kids
)
122 CompoundFlag::disable()
124 for (auto& k
: _kids
)
128 struct AllFlags
: public Flag
131 : Flag("All", "All Flags")
137 FlagsMap::iterator i
= allFlags().begin();
138 FlagsMap::iterator end
= allFlags().end();
139 for (; i
!= end
; ++i
)
140 if (i
->second
!= this)
147 FlagsMap::iterator i
= allFlags().begin();
148 FlagsMap::iterator end
= allFlags().end();
149 for (; i
!= end
; ++i
)
150 if (i
->second
!= this)
151 i
->second
->disable();
155 AllFlags theAllFlags
;
156 Flag
*const All
= &theAllFlags
;
159 changeFlag(const char *s
, bool value
)
161 Flag
*f
= findFlag(s
);
175 // add a set of functions that can easily be invoked from gdb
177 setDebugFlag(const char *string
)
179 Debug::changeFlag(string
, true);
183 clearDebugFlag(const char *string
)
185 Debug::changeFlag(string
, false);
191 using namespace Debug
;
192 FlagsMap::iterator i
= allFlags().begin();
193 FlagsMap::iterator end
= allFlags().end();
194 for (; i
!= end
; ++i
) {
195 SimpleFlag
*f
= dynamic_cast<SimpleFlag
*>(i
->second
);
196 if (f
&& f
->status())
197 cprintf("%s\n", f
->name());