Commit cb4ce043 authored by Rich Prohaska's avatar Rich Prohaska Committed by Yoni Fogel

1st cut at verifying the lsn sequence. addresses #1837

git-svn-id: file:///svn/toku/tokudb@13093 c7de825b-a66e-492c-adef-691d508d4ae1
parent ea5825ed
...@@ -524,6 +524,13 @@ generate_rollbacks (void) { ...@@ -524,6 +524,13 @@ generate_rollbacks (void) {
fprintf(cf, " }\n return EINVAL;\n}\n"); fprintf(cf, " }\n return EINVAL;\n}\n");
} }
static void
generate_log_entry_functions(void) {
fprintf(hf, "LSN toku_log_entry_get_lsn(struct log_entry *);\n");
fprintf(cf, "LSN toku_log_entry_get_lsn(struct log_entry *le) {\n");
fprintf(cf, " return le->u.begin_checkpoint.lsn;\n");
fprintf(cf, "}\n");
}
const char *codepath = "log_code.c"; const char *codepath = "log_code.c";
const char *headerpath = "log_header.h"; const char *headerpath = "log_header.h";
...@@ -550,6 +557,7 @@ int main (int argc __attribute__((__unused__)), char *argv[] __attribute__((__u ...@@ -550,6 +557,7 @@ int main (int argc __attribute__((__unused__)), char *argv[] __attribute__((__u
generate_log_reader(); generate_log_reader();
generate_logprint(); generate_logprint();
generate_rollbacks(); generate_rollbacks();
generate_log_entry_functions();
fprintf(hf, "#endif\n"); fprintf(hf, "#endif\n");
{ {
int r=fclose(hf); int r=fclose(hf);
......
...@@ -498,6 +498,7 @@ int tokudb_recover(const char *data_dir, const char *log_dir) { ...@@ -498,6 +498,7 @@ int tokudb_recover(const char *data_dir, const char *log_dir) {
//printf("%s:%d data_wd=\"%s\"\n", __FILE__, __LINE__, data_wd); //printf("%s:%d data_wd=\"%s\"\n", __FILE__, __LINE__, data_wd);
} }
LSN lastlsn = ZERO_LSN;
FILE *f = NULL; FILE *f = NULL;
for (i=0; i<n_logfiles; i++) { for (i=0; i<n_logfiles; i++) {
if (f) fclose(f); if (f) fclose(f);
...@@ -506,7 +507,7 @@ int tokudb_recover(const char *data_dir, const char *log_dir) { ...@@ -506,7 +507,7 @@ int tokudb_recover(const char *data_dir, const char *log_dir) {
char *logfile = logfiles[n_logfiles-i-1]; char *logfile = logfiles[n_logfiles-i-1];
f = fopen(logfile, "r"); f = fopen(logfile, "r");
assert(f); assert(f);
//printf("Opened %s\n", logfiles[n_logfiles-i-1]); printf("Opened %s\n", logfiles[n_logfiles-i-1]);
r = fseek(f, 0, SEEK_END); assert(r==0); r = fseek(f, 0, SEEK_END); assert(r==0);
struct log_entry le; struct log_entry le;
struct backward_scan_state bs = initial_bss; struct backward_scan_state bs = initial_bss;
...@@ -515,6 +516,13 @@ int tokudb_recover(const char *data_dir, const char *log_dir) { ...@@ -515,6 +516,13 @@ int tokudb_recover(const char *data_dir, const char *log_dir) {
while (1) { while (1) {
r = toku_log_fread_backward(f, &le); r = toku_log_fread_backward(f, &le);
if (r==-1) break; // Ran out of file if (r==-1) break; // Ran out of file
LSN thislsn = toku_log_entry_get_lsn(&le);
if (lastlsn.lsn != 0) {
if (thislsn.lsn != lastlsn.lsn - 1)
printf("bw lastlsn=%"PRId64" lsn=%"PRId64"\n", lastlsn.lsn, thislsn.lsn);
//assert(thislsn.lsn == lastlsn.lsn - 1);
}
lastlsn = thislsn;
logtype_dispatch_assign(&le, toku_recover_backward_, r, &bs); logtype_dispatch_assign(&le, toku_recover_backward_, r, &bs);
if (r!=0) goto go_forward; if (r!=0) goto go_forward;
} }
...@@ -542,6 +550,13 @@ int tokudb_recover(const char *data_dir, const char *log_dir) { ...@@ -542,6 +550,13 @@ int tokudb_recover(const char *data_dir, const char *log_dir) {
assert(r==0); assert(r==0);
while ((r = toku_log_fread(f, &le))==0) { while ((r = toku_log_fread(f, &le))==0) {
//printf("doing %c\n", le.cmd); //printf("doing %c\n", le.cmd);
LSN thislsn = toku_log_entry_get_lsn(&le);
if (lastlsn.lsn != thislsn.lsn) {
printf("fw expectlsn=%"PRId64" lsn=%"PRId64"\n", lastlsn.lsn, thislsn.lsn);
}
// assert(lastlsn.lsn == thislsn.lsn);
lastlsn.lsn += 1;
logtype_dispatch_args(&le, toku_recover_); logtype_dispatch_args(&le, toku_recover_);
entrycount++; entrycount++;
} }
......
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