Commit e690212e authored by joreland@mysql.com's avatar joreland@mysql.com

removed copy paste index code

improved handling of bits in last word
parent 5374ac8f
...@@ -173,29 +173,17 @@ private: ...@@ -173,29 +173,17 @@ private:
NdbIndexOperation(Ndb* aNdb); NdbIndexOperation(Ndb* aNdb);
~NdbIndexOperation(); ~NdbIndexOperation();
void closeScan();
int receiveTCINDXREF(NdbApiSignal* aSignal); int receiveTCINDXREF(NdbApiSignal* aSignal);
// Overloaded method from NdbOperation
void setLastFlag(NdbApiSignal* signal, Uint32 lastFlag);
// Overloaded methods from NdbCursorOperation
int executeCursor(int ProcessorId);
// Overloaded methods from NdbCursorOperation // Overloaded methods from NdbCursorOperation
int indxInit(const class NdbIndexImpl* anIndex, int indxInit(const class NdbIndexImpl* anIndex,
const class NdbTableImpl* aTable, const class NdbTableImpl* aTable,
NdbConnection* myConnection); NdbConnection* myConnection);
int equal_impl(const class NdbColumnImpl*, const char* aValue, Uint32 len);
int prepareSend(Uint32 TC_ConnectPtr, Uint64 TransactionId); int prepareSend(Uint32 TC_ConnectPtr, Uint64 TransactionId);
// Private attributes // Private attributes
const NdbIndexImpl* m_theIndex; const NdbIndexImpl* m_theIndex;
Uint32 m_theIndexDefined[NDB_MAX_ATTRIBUTES_IN_INDEX][3];
Uint32 m_theIndexLen; // Length of the index in words
Uint32 m_theNoOfIndexDefined; // The number of index attributes
}; };
#endif #endif
...@@ -821,8 +821,7 @@ protected: ...@@ -821,8 +821,7 @@ protected:
int insertKEYINFO(const char* aValue, int insertKEYINFO(const char* aValue,
Uint32 aStartPosition, Uint32 aStartPosition,
Uint32 aKeyLenInByte, Uint32 aKeyLenInByte);
Uint32 anAttrBitsInLastWord);
virtual void setErrorCode(int aErrorCode); virtual void setErrorCode(int aErrorCode);
virtual void setErrorCodeAbort(int aErrorCode); virtual void setErrorCodeAbort(int aErrorCode);
......
...@@ -370,7 +370,6 @@ operator<<(NdbOut& out, const Dbtux::Index& index) ...@@ -370,7 +370,6 @@ operator<<(NdbOut& out, const Dbtux::Index& index)
{ {
out << "[Index " << hex << &index; out << "[Index " << hex << &index;
out << " [tableId " << dec << index.m_tableId << "]"; out << " [tableId " << dec << index.m_tableId << "]";
out << " [fragOff " << dec << index.m_fragOff << "]";
out << " [numFrags " << dec << index.m_numFrags << "]"; out << " [numFrags " << dec << index.m_numFrags << "]";
for (unsigned i = 0; i < index.m_numFrags; i++) { for (unsigned i = 0; i < index.m_numFrags; i++) {
out << " [frag " << dec << i << " "; out << " [frag " << dec << i << " ";
...@@ -393,7 +392,6 @@ operator<<(NdbOut& out, const Dbtux::Frag& frag) ...@@ -393,7 +392,6 @@ operator<<(NdbOut& out, const Dbtux::Frag& frag)
out << "[Frag " << hex << &frag; out << "[Frag " << hex << &frag;
out << " [tableId " << dec << frag.m_tableId << "]"; out << " [tableId " << dec << frag.m_tableId << "]";
out << " [indexId " << dec << frag.m_indexId << "]"; out << " [indexId " << dec << frag.m_indexId << "]";
out << " [fragOff " << dec << frag.m_fragOff << "]";
out << " [fragId " << dec << frag.m_fragId << "]"; out << " [fragId " << dec << frag.m_fragId << "]";
out << " [descPage " << hex << frag.m_descPage << "]"; out << " [descPage " << hex << frag.m_descPage << "]";
out << " [descOff " << dec << frag.m_descOff << "]"; out << " [descOff " << dec << frag.m_descOff << "]";
......
This diff is collapsed.
...@@ -129,12 +129,9 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo, ...@@ -129,12 +129,9 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo,
const int slack = sizeInBytes & 3; const int slack = sizeInBytes & 3;
if ((((UintPtr)aValue & 3) != 0) || (slack != 0)){ if ((((UintPtr)aValue & 3) != 0) || (slack != 0)){
tempData[attributeSize >> 2] = 0;
memcpy(&tempData[0], aValue, attributeSize); memcpy(&tempData[0], aValue, attributeSize);
aValue = (char*)&tempData[0]; aValue = (char*)&tempData[0];
if(slack != 0) {
char * tmp = (char*)&tempData[0];
memset(&tmp[attributeSize], 0, (4 - slack));
}//if
}//if }//if
} }
const char* aValueToWrite = aValue; const char* aValueToWrite = aValue;
...@@ -152,9 +149,7 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo, ...@@ -152,9 +149,7 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo,
aValue = (char*)xfrmData; aValue = (char*)xfrmData;
} }
Uint32 bitsInLastWord = 8 * (sizeInBytes & 3) ;
Uint32 totalSizeInWords = (sizeInBytes + 3)/4; // Inc. bits in last word Uint32 totalSizeInWords = (sizeInBytes + 3)/4; // Inc. bits in last word
Uint32 sizeInWords = sizeInBytes / 4; // Exc. bits in last word
if (true){ //tArraySize != 0) { if (true){ //tArraySize != 0) {
Uint32 tTupKeyLen = theTupKeyLen; Uint32 tTupKeyLen = theTupKeyLen;
...@@ -195,8 +190,7 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo, ...@@ -195,8 +190,7 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo,
if ((tDistrKey != 1)) { if ((tDistrKey != 1)) {
; ;
} else { } else {
/** TODO DISTKEY */ //set_distribution_key(aValue, totalSizeInWords);
theDistrKeyIndicator = 1;
} }
/****************************************************************************** /******************************************************************************
* If the operation is an insert request and the attribute is stored then * If the operation is an insert request and the attribute is stored then
...@@ -216,21 +210,13 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo, ...@@ -216,21 +210,13 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo,
const Uint32 sz = totalSizeInWords; const Uint32 sz = totalSizeInWords;
AttributeHeader::init(&ahValue, tAttrId, sz); AttributeHeader::init(&ahValue, tAttrId, sz);
insertATTRINFO( ahValue ); insertATTRINFO( ahValue );
insertATTRINFOloop((Uint32*)aValueToWrite, sizeInWords); insertATTRINFOloop((Uint32*)aValueToWrite, sz);
if (bitsInLastWord != 0) {
tData = *(Uint32*)(aValueToWrite + (sizeInWords << 2));
tData = convertEndian(tData);
tData = tData & ((1 << bitsInLastWord) - 1);
tData = convertEndian(tData);
insertATTRINFO( tData );
}//if
}//if }//if
/*************************************************************************** /***************************************************************************
* Store the Key information in the TCKEYREQ and KEYINFO signals. * Store the Key information in the TCKEYREQ and KEYINFO signals.
**************************************************************************/ **************************************************************************/
if (insertKEYINFO(aValue, tKeyInfoPosition, if (insertKEYINFO(aValue, tKeyInfoPosition, totalSizeInWords) != -1) {
totalSizeInWords, bitsInLastWord) != -1) {
/************************************************************************* /*************************************************************************
* Add one to number of tuple key attributes defined. * Add one to number of tuple key attributes defined.
* If all have been defined then set the operation state to indicate * If all have been defined then set the operation state to indicate
...@@ -239,7 +225,7 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo, ...@@ -239,7 +225,7 @@ NdbOperation::equal_impl(const NdbColumnImpl* tAttrInfo,
************************************************************************/ ************************************************************************/
Uint32 tNoKeysDef = theNoOfTupKeyDefined; Uint32 tNoKeysDef = theNoOfTupKeyDefined;
Uint32 tErrorLine = theErrorLine; Uint32 tErrorLine = theErrorLine;
int tNoTableKeys = m_currentTable->m_noOfKeys; int tNoTableKeys = m_accessTable->m_noOfKeys;
unsigned char tInterpretInd = theInterpretIndicator; unsigned char tInterpretInd = theInterpretIndicator;
tNoKeysDef++; tNoKeysDef++;
theNoOfTupKeyDefined = tNoKeysDef; theNoOfTupKeyDefined = tNoKeysDef;
...@@ -365,8 +351,7 @@ NdbOperation::setTupleId() ...@@ -365,8 +351,7 @@ NdbOperation::setTupleId()
int int
NdbOperation::insertKEYINFO(const char* aValue, NdbOperation::insertKEYINFO(const char* aValue,
register Uint32 aStartPosition, register Uint32 aStartPosition,
register Uint32 anAttrSizeInWords, register Uint32 anAttrSizeInWords)
register Uint32 anAttrBitsInLastWord)
{ {
NdbApiSignal* tSignal; NdbApiSignal* tSignal;
NdbApiSignal* tCurrentKEYINFO; NdbApiSignal* tCurrentKEYINFO;
...@@ -386,7 +371,7 @@ NdbOperation::insertKEYINFO(const char* aValue, ...@@ -386,7 +371,7 @@ NdbOperation::insertKEYINFO(const char* aValue,
*****************************************************************************/ *****************************************************************************/
tEndPos = aStartPosition + anAttrSizeInWords - 1; tEndPos = aStartPosition + anAttrSizeInWords - 1;
if ((tEndPos < 9) && (anAttrBitsInLastWord == 0)) { if ((tEndPos < 9)) {
register Uint32 tkeyData = *(Uint32*)aValue; register Uint32 tkeyData = *(Uint32*)aValue;
//TcKeyReq* tcKeyReq = CAST_PTR(TcKeyReq, tTCREQ->getDataPtrSend()); //TcKeyReq* tcKeyReq = CAST_PTR(TcKeyReq, tTCREQ->getDataPtrSend());
register Uint32* tDataPtr = (Uint32*)aValue; register Uint32* tDataPtr = (Uint32*)aValue;
...@@ -496,25 +481,6 @@ NdbOperation::insertKEYINFO(const char* aValue, ...@@ -496,25 +481,6 @@ NdbOperation::insertKEYINFO(const char* aValue,
} while (1); } while (1);
LastWordLabel: LastWordLabel:
/*****************************************************************************
* There could be a last word that only contains partial data. This word*
* will contain zeroes in the rest of the bits since the index expects *
* a certain number of words and do not care for parts of words. *
*****************************************************************************/
if (anAttrBitsInLastWord != 0) {
tData = *(Uint32*)(aValue + (anAttrSizeInWords - 1) * 4);
tData = convertEndian(tData);
tData = tData & ((1 << anAttrBitsInLastWord) - 1);
tData = convertEndian(tData);
if (tPosition > 8) {
tCurrentKEYINFO->setData(tData, signalCounter);
signalCounter++;
} else {
theTCREQ->setData(tData, (12 + tPosition));
}//if
}//if
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment