#undef dout
#define dout(l) if (l<=g_conf.debug_lockdep) *_dout << g_clock.now() << " " << std::hex << pthread_self() << std::dec << " lockdep: "
+#undef dendl
+#define dendl std::endl
// global
int g_lockdep = 0;
int last_id = 0;
hash_map<pthread_t, map<int,BackTrace*> > held;
-BackTrace *follows[MAX_LOCKS][MAX_LOCKS]; // follows[a][b] means b taken after a
+BackTrace *follows[MAX_LOCKS][MAX_LOCKS]; // follows[a][b] means b taken after a
#define BACKTRACE_SKIP 3
for (hash_map<pthread_t, map<int,BackTrace*> >::iterator p = held.begin();
p != held.end();
p++) {
- dout(0) << "--- thread " << p->first << " ---" << std::endl;
+ dout(0) << "--- thread " << p->first << " ---" << dendl;
for (map<int,BackTrace*>::iterator q = p->second.begin();
q != p->second.end();
q++) {
- dout(0) << " * " << lock_names[q->first] << std::endl;
+ dout(0) << " * " << lock_names[q->first] << "\n";
if (q->second)
q->second->print(*_dout);
+ *_dout << dendl;
}
}
for (int i=0; i<MAX_LOCKS; i++)
for (int j=0; j<MAX_LOCKS; j++)
follows[i][j] = NULL;
-
+
hash_map<const char *, int>::iterator p = lock_ids.find(name);
if (p == lock_ids.end()) {
assert(last_id < MAX_LOCKS);
id = last_id++;
lock_ids[name] = id;
lock_names[id] = name;
- dout(10) << "registered '" << name << "' as " << id << std::endl;
+ dout(10) << "registered '" << name << "' as " << id << dendl;
} else {
id = p->second;
- dout(20) << "had '" << name << "' as " << id << std::endl;
+ dout(20) << "had '" << name << "' as " << id << dendl;
}
pthread_mutex_unlock(&lockdep_mutex);
static bool does_follow(int a, int b)
{
if (follows[a][b]) {
- *_dout << std::endl;
- dout(0) << "------------------------------------" << std::endl;
- dout(0) << "existing dependency " << lock_names[a] << " (" << a << ") -> " << lock_names[b] << " (" << b << ") at: " << std::endl;
+ dout(0) << "\n";
+ *_dout << "------------------------------------" << "\n";
+ *_dout << "existing dependency " << lock_names[a] << " (" << a << ") -> "
+ << lock_names[b] << " (" << b << ") at:\n";
follows[a][b]->print(*_dout);
- *_dout << std::endl;
+ *_dout << dendl;
return true;
}
for (int i=0; i<MAX_LOCKS; i++) {
if (follows[a][i] &&
does_follow(i, b)) {
- dout(0) << "existing intermediate dependency " << lock_names[a] << " (" << a << ") -> " << lock_names[i] << " (" << i << ") at:" << std::endl;
+ dout(0) << "existing intermediate dependency " << lock_names[a]
+ << " (" << a << ") -> " << lock_names[i] << " (" << i << ") at:\n";
follows[a][i]->print(*_dout);
- *_dout << std::endl;
+ *_dout << dendl;
return true;
}
}
if (id < 0) id = lockdep_register(name);
pthread_mutex_lock(&lockdep_mutex);
- dout(20) << "_will_lock " << name << " (" << id << ")" << std::endl;
+ dout(20) << "_will_lock " << name << " (" << id << ")" << dendl;
// check dependency graph
map<int, BackTrace *> &m = held[p];
p != m.end();
p++) {
if (p->first == id) {
- *_dout << std::endl;
- dout(0) << "recursive lock of " << name << " (" << id << ")" << std::endl;
+ dout(0) << "\n";
+ *_dout << "recursive lock of " << name << " (" << id << ")\n";
BackTrace *bt = new BackTrace(BACKTRACE_SKIP);
bt->print(*_dout);
if (p->second) {
- *_dout << std::endl;
- dout(0) << "previously locked at" << std::endl;
+ *_dout << "\npreviously locked at\n";
p->second->print(*_dout);
}
- *_dout << std::endl;
+ *_dout << dendl;
assert(0);
}
else if (!follows[p->first][id]) {
- // new dependency
-
+ // new dependency
+
// did we just create a cycle?
BackTrace *bt = new BackTrace(BACKTRACE_SKIP);
if (does_follow(id, p->first)) {
- dout(0) << "new dependency " << lock_names[p->first] << " (" << p->first << ") -> " << name << " (" << id << ")"
- << " creates a cycle at"
- << std::endl;
+ dout(0) << "new dependency " << lock_names[p->first]
+ << " (" << p->first << ") -> " << name << " (" << id << ")"
+ << " creates a cycle at\n";
bt->print(*_dout);
- *_dout << std::endl;
+ *_dout << dendl;
- dout(0) << "btw, i am holding these locks:" << std::endl;
+ dout(0) << "btw, i am holding these locks:" << dendl;
for (map<int, BackTrace *>::iterator q = m.begin();
q != m.end();
q++) {
- dout(0) << " " << lock_names[q->first] << " (" << q->first << ")" << std::endl;
+ dout(0) << " " << lock_names[q->first] << " (" << q->first << ")" << dendl;
if (q->second) {
+ dout(0) << " ";
q->second->print(*_dout);
- *_dout << std::endl;
+ *_dout << dendl;
}
}
- *_dout << std::endl;
- *_dout << std::endl;
+ dout(0) << "\n" << dendl;
// don't add this dependency, or we'll get aMutex. cycle in the graph, and
// does_follow() won't terminate.
assert(0); // actually, we should just die here.
} else {
follows[p->first][id] = bt;
- dout(10) << lock_names[p->first] << " -> " << name << " at" << std::endl;
+ dout(10) << lock_names[p->first] << " -> " << name << " at" << dendl;
//bt->print(*_dout);
}
}
if (id < 0) id = lockdep_register(name);
pthread_mutex_lock(&lockdep_mutex);
- dout(20) << "_locked " << name << std::endl;
+ dout(20) << "_locked " << name << dendl;
if (g_lockdep >= 2 || force_backtrace)
held[p][id] = new BackTrace(BACKTRACE_SKIP);
else
int lockdep_will_unlock(const char *name, int id)
{
pthread_t p = pthread_self();
-
+
if (id < 0) {
//id = lockdep_register(name);
assert(id == -1);
}
pthread_mutex_lock(&lockdep_mutex);
- dout(20) << "_will_unlock " << name << std::endl;
+ dout(20) << "_will_unlock " << name << dendl;
// don't assert.. lockdep may be enabled at any point in time
//assert(held.count(p));