Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
mariadb
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
db3fcd8a
Commit
db3fcd8a
authored
May 15, 2007
by
tomas@whalegate.ndb.mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge whalegate.ndb.mysql.com:/home/tomas/mysql-5.0-ndb
into whalegate.ndb.mysql.com:/home/tomas/mysql-5.1-single-user
parents
f527479f
30834432
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
10 deletions
+21
-10
storage/ndb/src/kernel/blocks/dbdict/Dbdict.cpp
storage/ndb/src/kernel/blocks/dbdict/Dbdict.cpp
+21
-10
No files found.
storage/ndb/src/kernel/blocks/dbdict/Dbdict.cpp
View file @
db3fcd8a
...
...
@@ -86,6 +86,9 @@
#include <signaldata/CreateObj.hpp>
#include <SLList.hpp>
#include <EventLogger.hpp>
extern
EventLogger
g_eventLogger
;
#define ZNOT_FOUND 626
#define ZALREADYEXIST 630
...
...
@@ -1372,27 +1375,35 @@ void Dbdict::readSchemaConf(Signal* signal,
for
(
Uint32
n
=
0
;
n
<
xsf
->
noOfPages
;
n
++
)
{
SchemaFile
*
sf
=
&
xsf
->
schemaPage
[
n
];
bool
ok
=
false
;
const
char
*
reason
;
if
(
memcmp
(
sf
->
Magic
,
NDB_SF_MAGIC
,
sizeof
(
sf
->
Magic
))
!=
0
)
{
jam
();
}
{
jam
();
reason
=
"magic code"
;
}
else
if
(
sf
->
FileSize
==
0
)
{
jam
();
}
{
jam
();
reason
=
"file size == 0"
;
}
else
if
(
sf
->
FileSize
%
NDB_SF_PAGE_SIZE
!=
0
)
{
jam
();
}
{
jam
();
reason
=
"invalid size multiple"
;
}
else
if
(
sf
->
FileSize
!=
sf0
->
FileSize
)
{
jam
();
}
{
jam
();
reason
=
"invalid size"
;
}
else
if
(
sf
->
PageNumber
!=
n
)
{
jam
();
}
{
jam
();
reason
=
"invalid page number"
;
}
else
if
(
computeChecksum
((
Uint32
*
)
sf
,
NDB_SF_PAGE_SIZE_IN_WORDS
)
!=
0
)
{
jam
();
}
else
if
(
crashInd
)
{
jam
();
}
{
jam
();
reason
=
"invalid checksum"
;
}
else
ok
=
true
;
ndbrequireErr
(
ok
,
NDBD_EXIT_SR_SCHEMAFILE
);
if
(
!
ok
)
{
if
(
!
ok
)
{
char
reason_msg
[
128
];
snprintf
(
reason_msg
,
sizeof
(
reason_msg
),
"schema file corrupt, page %u (%s, "
"sz=%u sz0=%u pn=%u)"
,
n
,
reason
,
sf
->
FileSize
,
sf0
->
FileSize
,
sf
->
PageNumber
);
if
(
crashInd
)
progError
(
__LINE__
,
NDBD_EXIT_SR_SCHEMAFILE
,
reason_msg
);
jam
();
ndbrequireErr
(
fsPtr
.
p
->
fsState
==
FsConnectRecord
::
READ_SCHEMA1
,
NDBD_EXIT_SR_SCHEMAFILE
);
infoEvent
(
"primary %s, trying backup"
,
reason_msg
);
readSchemaRef
(
signal
,
fsPtr
);
return
;
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment