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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
4f5ea1c1
Commit
4f5ea1c1
authored
Feb 21, 2007
by
unknown
Browse files
Options
Browse Files
Download
Plain Diff
Merge desktop.sanja.is.com.ua:/home/bell/mysql/bk/mysql-maria
into desktop.sanja.is.com.ua:/home/bell/mysql/bk/work-maria
parents
e57303a9
378225c4
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
32 additions
and
61 deletions
+32
-61
storage/maria/ma_loghandler.c
storage/maria/ma_loghandler.c
+32
-61
No files found.
storage/maria/ma_loghandler.c
View file @
4f5ea1c1
...
@@ -359,6 +359,27 @@ typedef struct st_translog_validator_data
...
@@ -359,6 +359,27 @@ typedef struct st_translog_validator_data
const
char
*
maria_data_root
;
const
char
*
maria_data_root
;
/*
Check cursor/buffer consistence
SYNOPSIS
translog_check_cursor
cursor cursor which will be checked
*/
#ifndef DBUG_OFF
static
void
translog_check_cursor
(
struct
st_buffer_cursor
*
cursor
)
{
DBUG_ASSERT
(
cursor
->
chaser
||
((
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
==
cursor
->
buffer
->
size
));
DBUG_ASSERT
(
cursor
->
buffer
->
buffer_no
==
cursor
->
buffer_no
);
DBUG_ASSERT
((
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
%
TRANSLOG_PAGE_SIZE
==
cursor
->
current_page_fill
%
TRANSLOG_PAGE_SIZE
);
DBUG_ASSERT
(
cursor
->
current_page_fill
<=
TRANSLOG_PAGE_SIZE
);
}
#endif
/*
/*
Get file name of the log by log number
Get file name of the log by log number
...
@@ -696,11 +717,7 @@ static void translog_new_page_header(TRANSLOG_ADDRESS *horizon,
...
@@ -696,11 +717,7 @@ static void translog_new_page_header(TRANSLOG_ADDRESS *horizon,
(
uint
)
cursor
->
buffer
->
buffer_no
,
(
ulong
)
cursor
->
buffer
,
(
uint
)
cursor
->
buffer
->
buffer_no
,
(
ulong
)
cursor
->
buffer
,
cursor
->
chaser
,
(
ulong
)
cursor
->
buffer
->
size
,
cursor
->
chaser
,
(
ulong
)
cursor
->
buffer
->
size
,
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)));
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)));
DBUG_ASSERT
(
cursor
->
chaser
||
DBUG_EXECUTE
(
"info"
,
translog_check_cursor
(
cursor
););
((
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
==
cursor
->
buffer
->
size
));
DBUG_ASSERT
(
cursor
->
buffer
->
buffer_no
==
cursor
->
buffer_no
);
DBUG_ASSERT
(
cursor
->
current_page_fill
<=
TRANSLOG_PAGE_SIZE
);
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
...
@@ -814,12 +831,8 @@ static void translog_finish_page(TRANSLOG_ADDRESS *horizon,
...
@@ -814,12 +831,8 @@ static void translog_finish_page(TRANSLOG_ADDRESS *horizon,
(
ulong
)
cursor
->
buffer
->
size
,
(
ulong
)
cursor
->
buffer
->
size
,
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
),
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
),
(
uint
)
cursor
->
current_page_fill
,
(
uint
)
left
));
(
uint
)
cursor
->
current_page_fill
,
(
uint
)
left
));
DBUG_ASSERT
(
cursor
->
ptr
!=
NULL
);
DBUG_ASSERT
((
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
%
TRANSLOG_PAGE_SIZE
==
cursor
->
current_page_fill
%
TRANSLOG_PAGE_SIZE
);
DBUG_ASSERT
(
LSN_FILE_NO
(
*
horizon
)
==
LSN_FILE_NO
(
cursor
->
buffer
->
offset
));
DBUG_ASSERT
(
LSN_FILE_NO
(
*
horizon
)
==
LSN_FILE_NO
(
cursor
->
buffer
->
offset
));
DBUG_ASSERT
(
LSN_OFFSET
(
cursor
->
buffer
->
offset
)
+
DBUG_EXECUTE
(
"info"
,
translog_check_cursor
(
cursor
););
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
==
LSN_OFFSET
(
*
horizon
));
if
(
cursor
->
protected
)
if
(
cursor
->
protected
)
{
{
DBUG_PRINT
(
"info"
,
(
"Already protected and finished"
));
DBUG_PRINT
(
"info"
,
(
"Already protected and finished"
));
...
@@ -843,10 +856,7 @@ static void translog_finish_page(TRANSLOG_ADDRESS *horizon,
...
@@ -843,10 +856,7 @@ static void translog_finish_page(TRANSLOG_ADDRESS *horizon,
(
ulong
)
cursor
->
buffer
,
cursor
->
chaser
,
(
ulong
)
cursor
->
buffer
,
cursor
->
chaser
,
(
ulong
)
cursor
->
buffer
->
size
,
(
ulong
)
cursor
->
buffer
->
size
,
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)));
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)));
DBUG_ASSERT
(
cursor
->
chaser
DBUG_EXECUTE
(
"info"
,
translog_check_cursor
(
cursor
););
||
((
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
==
cursor
->
buffer
->
size
));
DBUG_ASSERT
(
cursor
->
buffer
->
buffer_no
==
cursor
->
buffer_no
);
}
}
if
(
page
[
TRANSLOG_PAGE_FLAGS
]
&
TRANSLOG_SECTOR_PROTECTION
)
if
(
page
[
TRANSLOG_PAGE_FLAGS
]
&
TRANSLOG_SECTOR_PROTECTION
)
{
{
...
@@ -1011,10 +1021,7 @@ static void translog_start_buffer(struct st_translog_buffer *buffer,
...
@@ -1011,10 +1021,7 @@ static void translog_start_buffer(struct st_translog_buffer *buffer,
(
uint
)
cursor
->
buffer
->
buffer_no
,
(
ulong
)
cursor
->
buffer
,
(
uint
)
cursor
->
buffer
->
buffer_no
,
(
ulong
)
cursor
->
buffer
,
cursor
->
chaser
,
(
ulong
)
cursor
->
buffer
->
size
,
cursor
->
chaser
,
(
ulong
)
cursor
->
buffer
->
size
,
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)));
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)));
DBUG_ASSERT
(
cursor
->
chaser
||
DBUG_EXECUTE
(
"info"
,
translog_check_cursor
(
cursor
););
((
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
==
cursor
->
buffer
->
size
));
DBUG_ASSERT
(
cursor
->
buffer
->
buffer_no
==
cursor
->
buffer_no
);
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
...
@@ -2042,13 +2049,7 @@ my_bool translog_init(const char *directory,
...
@@ -2042,13 +2049,7 @@ my_bool translog_init(const char *directory,
(
ulong
)
log_descriptor
.
bc
.
buffer
->
size
,
(
ulong
)
log_descriptor
.
bc
.
buffer
->
size
,
(
ulong
)
(
log_descriptor
.
bc
.
ptr
-
log_descriptor
.
bc
.
(
ulong
)
(
log_descriptor
.
bc
.
ptr
-
log_descriptor
.
bc
.
buffer
->
buffer
)));
buffer
->
buffer
)));
DBUG_ASSERT
(
log_descriptor
.
bc
.
chaser
||
DBUG_EXECUTE
(
"info"
,
translog_check_cursor
(
&
log_descriptor
.
bc
););
((
ulong
)
(
log_descriptor
.
bc
.
ptr
-
log_descriptor
.
bc
.
buffer
->
buffer
)
==
log_descriptor
.
bc
.
buffer
->
size
));
DBUG_ASSERT
(
log_descriptor
.
bc
.
buffer
->
buffer_no
==
log_descriptor
.
bc
.
buffer_no
);
DBUG_ASSERT
(
log_descriptor
.
bc
.
current_page_fill
<=
TRANSLOG_PAGE_SIZE
);
}
}
}
}
DBUG_PRINT
(
"info"
,
(
"Logs found: %d was recovered: %d"
,
DBUG_PRINT
(
"info"
,
(
"Logs found: %d was recovered: %d"
,
...
@@ -2332,11 +2333,7 @@ static my_bool translog_write_data_on_page(TRANSLOG_ADDRESS *horizon,
...
@@ -2332,11 +2333,7 @@ static my_bool translog_write_data_on_page(TRANSLOG_ADDRESS *horizon,
(
uint
)
cursor
->
buffer
->
buffer_no
,
(
ulong
)
cursor
->
buffer
,
(
uint
)
cursor
->
buffer
->
buffer_no
,
(
ulong
)
cursor
->
buffer
,
cursor
->
chaser
,
(
ulong
)
cursor
->
buffer
->
size
,
cursor
->
chaser
,
(
ulong
)
cursor
->
buffer
->
size
,
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)));
(
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)));
DBUG_ASSERT
(
cursor
->
chaser
||
DBUG_EXECUTE
(
"info"
,
translog_check_cursor
(
cursor
););
((
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
==
cursor
->
buffer
->
size
));
DBUG_ASSERT
(
cursor
->
buffer
->
buffer_no
==
cursor
->
buffer_no
);
DBUG_ASSERT
(
cursor
->
current_page_fill
<=
TRANSLOG_PAGE_SIZE
);
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
...
@@ -2430,17 +2427,7 @@ static my_bool translog_write_parts_on_page(TRANSLOG_ADDRESS *horizon,
...
@@ -2430,17 +2427,7 @@ static my_bool translog_write_parts_on_page(TRANSLOG_ADDRESS *horizon,
(
ulong
)
LSN_OFFSET
(
*
horizon
),
(
ulong
)
LSN_OFFSET
(
*
horizon
),
(
ulong
)
(
LSN_OFFSET
(
cursor
->
buffer
->
offset
)
+
(
ulong
)
(
LSN_OFFSET
(
cursor
->
buffer
->
offset
)
+
cursor
->
buffer
->
size
)));
cursor
->
buffer
->
size
)));
/*
DBUG_EXECUTE
(
"info"
,
translog_check_cursor
(
cursor
););
TODO: make one check function for the buffer/loghandler
*/
DBUG_ASSERT
(
cursor
->
chaser
||
((
ulong
)
(
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
==
cursor
->
buffer
->
size
));
DBUG_ASSERT
(
cursor
->
buffer
->
buffer_no
==
cursor
->
buffer_no
);
DBUG_ASSERT
((
cursor
->
ptr
-
cursor
->
buffer
->
buffer
)
%
TRANSLOG_PAGE_SIZE
==
cursor
->
current_page_fill
%
TRANSLOG_PAGE_SIZE
);
DBUG_ASSERT
(
cursor
->
current_page_fill
<=
TRANSLOG_PAGE_SIZE
);
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
...
@@ -2698,9 +2685,7 @@ static my_bool translog_advance_pointer(uint pages, uint16 last_page_data)
...
@@ -2698,9 +2685,7 @@ static my_bool translog_advance_pointer(uint pages, uint16 last_page_data)
translog_wait_for_buffer_free
(
new_buffer
);
translog_wait_for_buffer_free
(
new_buffer
);
min_offset
=
min
(
buffer_end_offset
,
file_end_offset
);
min_offset
=
min
(
buffer_end_offset
,
file_end_offset
);
/*
/* TODO: check is it ptr or size enough */
TODO: check is it ptr or size enough
*/
log_descriptor
.
bc
.
buffer
->
size
+=
min_offset
;
log_descriptor
.
bc
.
buffer
->
size
+=
min_offset
;
log_descriptor
.
bc
.
ptr
+=
min_offset
;
log_descriptor
.
bc
.
ptr
+=
min_offset
;
DBUG_PRINT
(
"info"
,
(
"NewP buffer #%u: 0x%lx chaser: %d Size: %lu (%lu)"
,
DBUG_PRINT
(
"info"
,
(
"NewP buffer #%u: 0x%lx chaser: %d Size: %lu (%lu)"
,
...
@@ -2761,16 +2746,7 @@ static my_bool translog_advance_pointer(uint pages, uint16 last_page_data)
...
@@ -2761,16 +2746,7 @@ static my_bool translog_advance_pointer(uint pages, uint16 last_page_data)
(
"pointer moved to: (%lu, 0x%lx)"
,
(
"pointer moved to: (%lu, 0x%lx)"
,
(
ulong
)
LSN_FILE_NO
(
log_descriptor
.
horizon
),
(
ulong
)
LSN_FILE_NO
(
log_descriptor
.
horizon
),
(
ulong
)
LSN_OFFSET
(
log_descriptor
.
horizon
)));
(
ulong
)
LSN_OFFSET
(
log_descriptor
.
horizon
)));
DBUG_ASSERT
(
log_descriptor
.
bc
.
chaser
||
DBUG_EXECUTE
(
"info"
,
translog_check_cursor
(
&
log_descriptor
.
bc
););
((
ulong
)
(
log_descriptor
.
bc
.
ptr
-
log_descriptor
.
bc
.
buffer
->
buffer
)
==
log_descriptor
.
bc
.
buffer
->
size
));
DBUG_ASSERT
(
log_descriptor
.
bc
.
buffer
->
buffer_no
==
log_descriptor
.
bc
.
buffer_no
);
DBUG_ASSERT
((
log_descriptor
.
bc
.
ptr
-
log_descriptor
.
bc
.
buffer
->
buffer
)
%
TRANSLOG_PAGE_SIZE
==
log_descriptor
.
bc
.
current_page_fill
%
TRANSLOG_PAGE_SIZE
);
DBUG_ASSERT
(
log_descriptor
.
bc
.
current_page_fill
<=
TRANSLOG_PAGE_SIZE
);
log_descriptor
.
bc
.
protected
=
0
;
log_descriptor
.
bc
.
protected
=
0
;
DBUG_RETURN
(
0
);
DBUG_RETURN
(
0
);
}
}
...
@@ -5132,14 +5108,9 @@ static void translog_force_current_buffer_to_finish()
...
@@ -5132,14 +5108,9 @@ static void translog_force_current_buffer_to_finish()
new_buff_begunning
+=
log_descriptor
.
bc
.
buffer
->
size
;
/* increase offset */
new_buff_begunning
+=
log_descriptor
.
bc
.
buffer
->
size
;
/* increase offset */
DBUG_ASSERT
(
log_descriptor
.
bc
.
ptr
!=
NULL
);
DBUG_ASSERT
(
log_descriptor
.
bc
.
ptr
!=
NULL
);
DBUG_ASSERT
((
log_descriptor
.
bc
.
ptr
-
log_descriptor
.
bc
.
buffer
->
buffer
)
%
TRANSLOG_PAGE_SIZE
==
log_descriptor
.
bc
.
current_page_fill
%
TRANSLOG_PAGE_SIZE
);
DBUG_ASSERT
(
LSN_FILE_NO
(
log_descriptor
.
horizon
)
==
DBUG_ASSERT
(
LSN_FILE_NO
(
log_descriptor
.
horizon
)
==
LSN_FILE_NO
(
log_descriptor
.
bc
.
buffer
->
offset
));
LSN_FILE_NO
(
log_descriptor
.
bc
.
buffer
->
offset
));
DBUG_ASSERT
(
LSN_OFFSET
(
log_descriptor
.
bc
.
buffer
->
offset
)
+
DBUG_EXECUTE
(
"info"
,
translog_check_cursor
(
&
log_descriptor
.
bc
););
(
log_descriptor
.
bc
.
ptr
-
log_descriptor
.
bc
.
buffer
->
buffer
)
==
LSN_OFFSET
(
log_descriptor
.
horizon
));
DBUG_ASSERT
(
left
<
TRANSLOG_PAGE_SIZE
);
DBUG_ASSERT
(
left
<
TRANSLOG_PAGE_SIZE
);
if
(
left
!=
0
)
if
(
left
!=
0
)
{
{
...
...
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