Commit b485ce3d authored by pekka@mysql.com's avatar pekka@mysql.com

ndb - use words not pages in schemafile table entry (5.1 compatible)

parent 9ac03944
...@@ -227,7 +227,6 @@ Dbacc::Dbacc(const class Configuration & conf): ...@@ -227,7 +227,6 @@ Dbacc::Dbacc(const class Configuration & conf):
&mlpqOperPtr, &mlpqOperPtr,
&queOperPtr, &queOperPtr,
&readWriteOpPtr, &readWriteOpPtr,
&tgnptMainOpPtr,
&iopOverflowRecPtr, &iopOverflowRecPtr,
&tfoOverflowRecPtr, &tfoOverflowRecPtr,
&porOverflowRecPtr, &porOverflowRecPtr,
......
...@@ -1132,20 +1132,23 @@ Dbdict::convertSchemaFileTo_5_0_5(XSchemaFile * xsf) ...@@ -1132,20 +1132,23 @@ Dbdict::convertSchemaFileTo_5_0_5(XSchemaFile * xsf)
Uint32 noOfPages = 1; Uint32 noOfPages = 1;
Uint32 n, i, j; Uint32 n, i, j;
for (n = 0; n < xsf->noOfPages; n++) { for (n = 0; n < xsf->noOfPages; n++) {
jam();
for (i = 0; i < NDB_SF_PAGE_ENTRIES; i++) { for (i = 0; i < NDB_SF_PAGE_ENTRIES; i++) {
j = n * NDB_SF_PAGE_ENTRIES + i; j = n * NDB_SF_PAGE_ENTRIES + i;
if (j >= sf_old->NoOfTableEntries) if (j >= sf_old->NoOfTableEntries)
continue; continue;
const SchemaFile::TableEntry_old & te_old = sf_old->TableEntries_old[j]; const SchemaFile::TableEntry_old & te_old = sf_old->TableEntries_old[j];
if (te_old.m_tableState == SchemaFile::INIT || if (te_old.m_tableState == SchemaFile::INIT ||
te_old.m_tableState == SchemaFile::DROP_TABLE_COMMITTED) te_old.m_tableState == SchemaFile::DROP_TABLE_COMMITTED ||
te_old.m_noOfPages == 0)
continue; continue;
SchemaFile * sf = &xsf->schemaPage[n]; SchemaFile * sf = &xsf->schemaPage[n];
SchemaFile::TableEntry & te = sf->TableEntries[i]; SchemaFile::TableEntry & te = sf->TableEntries[i];
te.m_tableState = te_old.m_tableState; te.m_tableState = te_old.m_tableState;
te.m_tableVersion = te_old.m_tableVersion; te.m_tableVersion = te_old.m_tableVersion;
te.m_tableType = te_old.m_tableType; te.m_tableType = te_old.m_tableType;
te.m_noOfPages = te_old.m_noOfPages; te.m_info_words = te_old.m_noOfPages * ZSIZE_OF_PAGES_IN_WORDS -
ZPAGE_HEADER_SIZE;
te.m_gcp = te_old.m_gcp; te.m_gcp = te_old.m_gcp;
if (noOfPages < n) if (noOfPages < n)
noOfPages = n; noOfPages = n;
...@@ -2503,7 +2506,8 @@ Dbdict::restartCreateTab(Signal* signal, Uint32 tableId, ...@@ -2503,7 +2506,8 @@ Dbdict::restartCreateTab(Signal* signal, Uint32 tableId,
if(file && !ERROR_INSERTED(6002)){ if(file && !ERROR_INSERTED(6002)){
jam(); jam();
c_readTableRecord.noOfPages = te->m_noOfPages; c_readTableRecord.noOfPages =
DIV(te->m_info_words + ZPAGE_HEADER_SIZE, ZSIZE_OF_PAGES_IN_WORDS);
c_readTableRecord.pageId = 0; c_readTableRecord.pageId = 0;
c_readTableRecord.m_callback.m_callbackData = createTabPtr.p->key; c_readTableRecord.m_callback.m_callbackData = createTabPtr.p->key;
c_readTableRecord.m_callback.m_callbackFunction = c_readTableRecord.m_callback.m_callbackFunction =
...@@ -3291,8 +3295,7 @@ Dbdict::execALTER_TAB_REQ(Signal * signal) ...@@ -3291,8 +3295,7 @@ Dbdict::execALTER_TAB_REQ(Signal * signal)
tabEntry.m_tableType = tablePtr.p->tableType; tabEntry.m_tableType = tablePtr.p->tableType;
tabEntry.m_tableState = SchemaFile::ALTER_TABLE_COMMITTED; tabEntry.m_tableState = SchemaFile::ALTER_TABLE_COMMITTED;
tabEntry.m_gcp = gci; tabEntry.m_gcp = gci;
tabEntry.m_noOfPages = tabEntry.m_info_words = tabInfoPtr.sz;
DIV(tabInfoPtr.sz + ZPAGE_HEADER_SIZE, ZSIZE_OF_PAGES_IN_WORDS);
memset(tabEntry.m_unused, 0, sizeof(tabEntry.m_unused)); memset(tabEntry.m_unused, 0, sizeof(tabEntry.m_unused));
Callback callback; Callback callback;
...@@ -4114,8 +4117,7 @@ Dbdict::createTab_prepare(Signal* signal, CreateTabReq * req){ ...@@ -4114,8 +4117,7 @@ Dbdict::createTab_prepare(Signal* signal, CreateTabReq * req){
tabEntry.m_tableType = tabPtr.p->tableType; tabEntry.m_tableType = tabPtr.p->tableType;
tabEntry.m_tableState = SchemaFile::ADD_STARTED; tabEntry.m_tableState = SchemaFile::ADD_STARTED;
tabEntry.m_gcp = gci; tabEntry.m_gcp = gci;
tabEntry.m_noOfPages = tabEntry.m_info_words = tabInfoPtr.sz;
DIV(tabInfoPtr.sz + ZPAGE_HEADER_SIZE, ZSIZE_OF_PAGES_IN_WORDS);
memset(tabEntry.m_unused, 0, sizeof(tabEntry.m_unused)); memset(tabEntry.m_unused, 0, sizeof(tabEntry.m_unused));
Callback callback; Callback callback;
...@@ -4571,8 +4573,7 @@ Dbdict::createTab_commit(Signal * signal, CreateTabReq * req){ ...@@ -4571,8 +4573,7 @@ Dbdict::createTab_commit(Signal * signal, CreateTabReq * req){
tabEntry.m_tableType = tabPtr.p->tableType; tabEntry.m_tableType = tabPtr.p->tableType;
tabEntry.m_tableState = SchemaFile::TABLE_ADD_COMMITTED; tabEntry.m_tableState = SchemaFile::TABLE_ADD_COMMITTED;
tabEntry.m_gcp = tabPtr.p->gciTableCreated; tabEntry.m_gcp = tabPtr.p->gciTableCreated;
tabEntry.m_noOfPages = tabEntry.m_info_words = tabPtr.p->packedSize;
DIV(tabPtr.p->packedSize + ZPAGE_HEADER_SIZE, ZSIZE_OF_PAGES_IN_WORDS);
memset(tabEntry.m_unused, 0, sizeof(tabEntry.m_unused)); memset(tabEntry.m_unused, 0, sizeof(tabEntry.m_unused));
Callback callback; Callback callback;
......
...@@ -62,7 +62,7 @@ struct SchemaFile { ...@@ -62,7 +62,7 @@ struct SchemaFile {
Uint32 m_tableState; Uint32 m_tableState;
Uint32 m_tableVersion; Uint32 m_tableVersion;
Uint32 m_tableType; Uint32 m_tableType;
Uint32 m_noOfPages; Uint32 m_info_words;
Uint32 m_gcp; Uint32 m_gcp;
Uint32 m_unused[3]; Uint32 m_unused[3];
......
...@@ -2,6 +2,9 @@ ...@@ -2,6 +2,9 @@
make -f Makefile -f - printSchemaFile <<'_eof_' make -f Makefile -f - printSchemaFile <<'_eof_'
printSchemaFile: printSchemaFile.cpp SchemaFile.hpp printSchemaFile: printSchemaFile.cpp SchemaFile.hpp
$(CXXCOMPILE) -o $@ $@.cpp -L../../../common/util/.libs -lgeneral $(CXXCOMPILE) -o $@ $@.cpp -L../../../common/util/.libs -lgeneral
ifneq ($(MYSQL_HOME),)
ln -sf `pwd`/$@ $(MYSQL_HOME)/bin/$@
endif
_eof_ _eof_
exit $? exit $?
#endif #endif
...@@ -134,7 +137,7 @@ print(const char * filename, const SchemaFile * xsf, Uint32 sz) ...@@ -134,7 +137,7 @@ print(const char * filename, const SchemaFile * xsf, Uint32 sz)
<< " State = " << te.m_tableState << " State = " << te.m_tableState
<< " version = " << te.m_tableVersion << " version = " << te.m_tableVersion
<< " type = " << te.m_tableType << " type = " << te.m_tableType
<< " noOfPages = " << te.m_noOfPages << " noOfWords = " << te.m_info_words
<< " gcp: " << te.m_gcp << endl; << " gcp: " << te.m_gcp << endl;
} }
if (te.m_unused[0] != 0 || te.m_unused[1] != 0 || te.m_unused[2] != 0) { if (te.m_unused[0] != 0 || te.m_unused[1] != 0 || te.m_unused[2] != 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