diff options
Diffstat (limited to 'storage/ndb/src/common/debugger/signaldata/LCP.cpp')
-rw-r--r-- | storage/ndb/src/common/debugger/signaldata/LCP.cpp | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/storage/ndb/src/common/debugger/signaldata/LCP.cpp b/storage/ndb/src/common/debugger/signaldata/LCP.cpp new file mode 100644 index 00000000000..6b4bb13e2cd --- /dev/null +++ b/storage/ndb/src/common/debugger/signaldata/LCP.cpp @@ -0,0 +1,89 @@ +/* Copyright (C) 2003 MySQL AB + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ + + +#include <RefConvert.hpp> +#include <signaldata/LCP.hpp> +#include <DebuggerNames.hpp> + +bool +printSTART_LCP_REQ(FILE * output, const Uint32 * theData, + Uint32 len, Uint16 receiverBlockNo){ + + const StartLcpReq * const sig = (StartLcpReq *) theData; + + char buf1[8*_NDB_NODE_BITMASK_SIZE+1]; + char buf2[8*_NDB_NODE_BITMASK_SIZE+1]; + fprintf(output, + " Sender: %d LcpId: %d\n" + " ParticipatingDIH = %s\n" + " ParticipatingLQH = %s\n", + refToNode(sig->senderRef), sig->lcpId, + sig->participatingDIH.getText(buf1), + sig->participatingLQH.getText(buf2)); + + return true; +} + +bool +printSTART_LCP_CONF(FILE * output, const Uint32 * theData, + Uint32 len, Uint16 receiverBlockNo){ + + const StartLcpConf * const sig = (StartLcpConf *) theData; + + fprintf(output, " Sender: %d LcpId: %d\n", + refToNode(sig->senderRef), sig->lcpId); + + return true; +} + +bool +printLCP_FRAG_ORD(FILE * output, const Uint32 * theData, + Uint32 len, Uint16 receiverBlockNo){ + + const LcpFragOrd * const sig = (LcpFragOrd *) theData; + + fprintf(output, " LcpId: %d LcpNo: %d Table: %d Fragment: %d\n", + sig->lcpId, sig->lcpNo, sig->tableId, sig->fragmentId); + + fprintf(output, " KeepGCI: %d LastFragmentFlag: %d\n", + sig->keepGci, sig->lastFragmentFlag); + return true; +} + +bool +printLCP_FRAG_REP(FILE * output, const Uint32 * theData, + Uint32 len, Uint16 receiverBlockNo){ + + const LcpFragRep * const sig = (LcpFragRep *) theData; + + fprintf(output, " LcpId: %d LcpNo: %d NodeId: %d Table: %d Fragment: %d\n", + sig->lcpId, sig->lcpNo, sig->nodeId, sig->tableId, sig->fragId); + fprintf(output, " Max GCI Started: %d Max GCI Completed: %d\n", + sig->maxGciStarted, sig->maxGciCompleted); + return true; +} + +bool +printLCP_COMPLETE_REP(FILE * output, const Uint32 * theData, + Uint32 len, Uint16 receiverBlockNo){ + + const LcpCompleteRep * const sig = (LcpCompleteRep *) theData; + + fprintf(output, " LcpId: %d NodeId: %d Block: %s\n", + sig->lcpId, sig->nodeId, getBlockName(sig->blockNo)); + return true; +} |