Below is the list of changes that have just been committed into a local
5.1 repository of pekka. When pekka does a push these changes will
be propagated to the main repository and, within 24 hours after the
push, to the public repository.
For information on how to access the public repository
see http://dev.mysql.com/doc/mysql/en/installing-source-tree.html
ChangeSet
1.2126 06/02/01 18:09:38 pekka@stripped +3 -0
ndb - wl#2972 fix some mem leaks
storage/ndb/test/ndbapi/test_event_merge.cpp
1.11 06/02/01 18:08:08 pekka@stripped +43 -7
fix some mem leaks (event ops however are never dtor-ed yet)
storage/ndb/src/ndbapi/NdbEventOperationImpl.cpp
1.38 06/02/01 18:08:08 pekka@stripped +10 -1
fix some mem leaks (event ops however are never dtor-ed yet)
storage/ndb/src/ndbapi/NdbBlob.cpp
1.34 06/02/01 18:08:08 pekka@stripped +1 -0
fix some mem leaks (event ops however are never dtor-ed yet)
# This is a BitKeeper patch. What follows are the unified diffs for the
# set of deltas contained in the patch. The rest of the patch, the part
# that BitKeeper cares about, is below these diffs.
# User: pekka
# Host: orca.ndb.mysql.com
# Root: /space/pekka/ndb/version/my51
--- 1.37/storage/ndb/src/ndbapi/NdbEventOperationImpl.cpp 2006-01-23 07:24:45 +01:00
+++ 1.38/storage/ndb/src/ndbapi/NdbEventOperationImpl.cpp 2006-02-01 18:08:08 +01:00
@@ -159,7 +159,8 @@
; // ToDo? We should send stop signal here
m_ndb->theImpl->theNdbObjectIdMap.unmap(m_oid, this);
- DBUG_PRINT("exit",("this: 0x%x/0x%x oid: %u", this, m_facade, m_oid));
+ DBUG_PRINT("exit",("this: %p/%p oid: %u main: %p",
+ this, m_facade, m_oid, theMainOp));
if (m_eventImpl)
{
@@ -2027,6 +2028,14 @@
{
tBlobOp->stop();
tBlobOp = tBlobOp->m_next;
+ }
+
+ // release blob handles now, further access is user error
+ while (op->theBlobList != NULL)
+ {
+ NdbBlob* tBlob = op->theBlobList;
+ op->theBlobList = tBlob->theNext;
+ m_ndb->releaseNdbBlob(tBlob);
}
}
--- 1.33/storage/ndb/src/ndbapi/NdbBlob.cpp 2006-01-25 22:00:27 +01:00
+++ 1.34/storage/ndb/src/ndbapi/NdbBlob.cpp 2006-02-01 18:08:08 +01:00
@@ -158,6 +158,7 @@
if (c == NULL)
return -1;
getBlobEventName(bename, e, c);
+ delete e; // it is from new NdbEventImpl
return 0;
}
--- 1.10/storage/ndb/test/ndbapi/test_event_merge.cpp 2006-01-22 13:27:23 +01:00
+++ 1.11/storage/ndb/test/ndbapi/test_event_merge.cpp 2006-02-01 18:08:08 +01:00
@@ -366,11 +366,12 @@
noop = 0;
ppeq = 0;
}
- void free() {
+ void freemem() {
delete [] tx1.val;
delete [] tx2.val;
delete [] bl1.val;
- init();
+ tx1.val = tx2.val = bl1.val = 0;
+ tx1.len = tx2.len = bl1.len = 0;
}
};
@@ -469,6 +470,12 @@
return out;
}
+// some random os may define these
+#undef NUL
+#undef INS
+#undef DEL
+#undef UPD
+
static const uint g_optypes = 3; // real ops 0-2
/*
@@ -504,6 +511,10 @@
match = false;
gci = 0;
}
+ void freemem() {
+ data[0].freemem();
+ data[1].freemem();
+ }
};
static NdbOut&
@@ -583,7 +594,7 @@
assert(g_freeops == 0);
Op* op = new Op;
assert(op != 0);
- op->next_free = g_opfree;
+ op->next_free = g_opfree; // 0
g_opfree = op;
op->free = true;
g_freeops++;
@@ -594,6 +605,7 @@
g_freeops--;
g_usedops++;
op->init(a_kind);
+ op->free = false;
return op;
}
@@ -601,8 +613,7 @@
freeop(Op* op)
{
assert(! op->free);
- op->data[0].free();
- op->data[1].free();
+ op->freemem();
op->free = true;
op->next_free = g_opfree;
g_opfree = op;
@@ -665,6 +676,18 @@
g_num_gci = g_num_ev = 0;
}
+static void
+deleteops() // for memleak checks
+{
+ while (g_opfree != 0) {
+ Op* tmp_op = g_opfree;
+ g_opfree = g_opfree->next_free;
+ delete tmp_op;
+ g_freeops--;
+ }
+ assert(g_freeops == 0);
+}
+
struct Comp {
Op::Type t1, t2, t3;
};
@@ -1312,6 +1335,10 @@
Op* tot_op = g_pk_op[pk1];
if (tot_op == 0)
continue;
+ if (tot_op->next_gci == 0) {
+ assert(g_loop != 0 && tot_op->type == Op::INS);
+ continue;
+ }
// first commit chain
assert(tot_op->next_gci != 0);
gci_op[pk1] = tot_op->next_gci;
@@ -1361,7 +1388,10 @@
if (tot_op == 0)
continue;
Op* gci_op = tot_op->next_gci;
- assert(gci_op != 0);
+ if (gci_op == 0) {
+ assert(g_loop != 0 && tot_op->type == Op::INS);
+ continue;
+ }
while (gci_op != 0) {
Op* com_op = gci_op->next_com;
assert(com_op != 0 && com_op->next_com == 0);
@@ -1648,6 +1678,7 @@
// copy and add
Op* ev = getop(Op::EV);
copyop(g_rec_ev, ev);
+ g_rec_ev->freemem();
last_ev->next_ev = ev;
g_num_ev++;
}
@@ -1706,6 +1737,8 @@
}
chkrc(dropevent() == 0);
chkrc(droptable() == 0);
+ resetmem();
+ deleteops();
return 0;
}
@@ -1836,8 +1869,11 @@
if (g_ncc->connect(30) == 0) {
g_ndb = new Ndb(g_ncc, "TEST_DB");
if (g_ndb->init() == 0 && g_ndb->waitUntilReady(30) == 0) {
- if (runtest() == 0)
+ if (runtest() == 0) {
+ delete g_ndb;
+ delete g_ncc;
return NDBT_ProgramExit(NDBT_OK);
+ }
}
}
if (g_evt_op != 0) {
| Thread |
|---|
| • bk commit into 5.1 tree (pekka:1.2126) | pekka | 1 Feb |