mirror of
https://github.com/MariaDB/server.git
synced 2025-01-26 00:34:18 +01:00
40ec012c90
WL#3951 - MyISAM: Additional Error Logs for Data Corruption When table corruption is detected, in addition to current error message provide following information: - list of threads (and queries) accessing a table; - thread_id of a thread that detected corruption; - source file name and line number where this corruption was detected; - optional extra information (string). mysql-test/r/myisam_crash_before_flush_keys.result: Adjusted a test case according to WL#3951. mysql-test/t/myisam_crash_before_flush_keys.test: Adjusted a test case according to WL#3951. storage/myisam/CMakeLists.txt: Added mi_extrafunc.h to myisam sources list. storage/myisam/Makefile.am: Added mi_extrafunc.h to myisam headers list. storage/myisam/ha_myisam.cc: Added _mi_report_crashed() function (reports additional information whenever table corruption is detected). storage/myisam/mi_extrafunc.h: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisam/mi_locking.c: For every call to mi_lock_database(F_[RD|WR|EXTRA_]LCK) - add current thread to the list of threads accessing this table. For every call to mi_lock_database(F_UNLCK) - remove current thread from the list of threads accessing this table. storage/myisam/mi_test1.c: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisam/mi_test2.c: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisam/mi_test3.c: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisam/myisam_ftdump.c: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisam/myisamchk.c: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisam/myisamdef.h: Extra elements are added to MI_INFO and MYISAM_SHARE structures. MI_INFO is extended with LIST element, that holds a pointer to THD object accessing a table. MYISAM_SHARE is extended with LIST (list of threads accessing a table). Whenever table is marked as crashed, call mi_report_crashed() macro to provide useful information. storage/myisam/myisamlog.c: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisam/myisampack.c: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisam/rt_test.c: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisam/sp_test.c: All standalone programs must define their version of _mi_report_crashed() by including mi_extrafunc.h. storage/myisammrg/ha_myisammrg.cc: For each unedrlying table initialize `in_use' variable.
175 lines
6.8 KiB
Makefile
175 lines
6.8 KiB
Makefile
# Copyright (C) 2000-2006 MySQL AB
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; version 2 of the License.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
MYSQLDATAdir = $(localstatedir)
|
|
MYSQLSHAREdir = $(pkgdatadir)
|
|
MYSQLBASEdir= $(prefix)
|
|
MYSQLLIBdir= $(pkglibdir)
|
|
INCLUDES = -I$(top_srcdir)/include -I$(top_builddir)/include \
|
|
-I$(top_srcdir)/regex \
|
|
-I$(top_srcdir)/sql \
|
|
-I$(srcdir)
|
|
WRAPLIBS=
|
|
|
|
LDADD =
|
|
|
|
DEFS = @DEFS@
|
|
|
|
EXTRA_DIST = mi_test_all.sh mi_test_all.res ft_stem.c CMakeLists.txt plug.in
|
|
pkgdata_DATA = mi_test_all mi_test_all.res
|
|
|
|
pkglib_LIBRARIES = libmyisam.a
|
|
bin_PROGRAMS = myisamchk myisamlog myisampack myisam_ftdump
|
|
myisamchk_DEPENDENCIES= $(LIBRARIES)
|
|
myisamchk_LDADD= @CLIENT_EXTRA_LDFLAGS@ libmyisam.a \
|
|
$(top_builddir)/mysys/libmysys.a \
|
|
$(top_builddir)/dbug/libdbug.a \
|
|
$(top_builddir)/strings/libmystrings.a @ZLIB_LIBS@
|
|
myisamlog_DEPENDENCIES= $(LIBRARIES)
|
|
myisamlog_LDADD= @CLIENT_EXTRA_LDFLAGS@ libmyisam.a \
|
|
$(top_builddir)/mysys/libmysys.a \
|
|
$(top_builddir)/dbug/libdbug.a \
|
|
$(top_builddir)/strings/libmystrings.a @ZLIB_LIBS@
|
|
myisampack_DEPENDENCIES=$(LIBRARIES)
|
|
myisampack_LDADD= @CLIENT_EXTRA_LDFLAGS@ libmyisam.a \
|
|
$(top_builddir)/mysys/libmysys.a \
|
|
$(top_builddir)/dbug/libdbug.a \
|
|
$(top_builddir)/strings/libmystrings.a @ZLIB_LIBS@
|
|
noinst_PROGRAMS = mi_test1 mi_test2 mi_test3 rt_test sp_test #ft_test1 ft_eval
|
|
noinst_HEADERS = myisamdef.h rt_index.h rt_key.h rt_mbr.h sp_defs.h \
|
|
fulltext.h ftdefs.h ft_test1.h ft_eval.h \
|
|
ha_myisam.h mi_extrafunc.h
|
|
mi_test1_DEPENDENCIES= $(LIBRARIES)
|
|
mi_test1_LDADD= @CLIENT_EXTRA_LDFLAGS@ libmyisam.a \
|
|
$(top_builddir)/mysys/libmysys.a \
|
|
$(top_builddir)/dbug/libdbug.a \
|
|
$(top_builddir)/strings/libmystrings.a @ZLIB_LIBS@
|
|
mi_test2_DEPENDENCIES= $(LIBRARIES)
|
|
mi_test2_LDADD= @CLIENT_EXTRA_LDFLAGS@ libmyisam.a \
|
|
$(top_builddir)/mysys/libmysys.a \
|
|
$(top_builddir)/dbug/libdbug.a \
|
|
$(top_builddir)/strings/libmystrings.a @ZLIB_LIBS@
|
|
mi_test3_DEPENDENCIES= $(LIBRARIES)
|
|
mi_test3_LDADD= @CLIENT_EXTRA_LDFLAGS@ libmyisam.a \
|
|
$(top_builddir)/mysys/libmysys.a \
|
|
$(top_builddir)/dbug/libdbug.a \
|
|
$(top_builddir)/strings/libmystrings.a @ZLIB_LIBS@
|
|
#ft_test1_DEPENDENCIES= $(LIBRARIES)
|
|
#ft_eval_DEPENDENCIES= $(LIBRARIES)
|
|
myisam_ftdump_DEPENDENCIES= $(LIBRARIES)
|
|
myisam_ftdump_LDADD = @CLIENT_EXTRA_LDFLAGS@ libmyisam.a \
|
|
$(top_builddir)/mysys/libmysys.a \
|
|
$(top_builddir)/dbug/libdbug.a \
|
|
$(top_builddir)/strings/libmystrings.a @ZLIB_LIBS@
|
|
rt_test_DEPENDENCIES= $(LIBRARIES)
|
|
rt_test_LDADD = @CLIENT_EXTRA_LDFLAGS@ libmyisam.a \
|
|
$(top_builddir)/mysys/libmysys.a \
|
|
$(top_builddir)/dbug/libdbug.a \
|
|
$(top_builddir)/strings/libmystrings.a @ZLIB_LIBS@
|
|
sp_test_DEPENDENCIES= $(LIBRARIES)
|
|
sp_test_LDADD = @CLIENT_EXTRA_LDFLAGS@ libmyisam.a \
|
|
$(top_builddir)/mysys/libmysys.a \
|
|
$(top_builddir)/dbug/libdbug.a \
|
|
$(top_builddir)/strings/libmystrings.a @ZLIB_LIBS@
|
|
libmyisam_a_SOURCES = mi_open.c mi_extra.c mi_info.c mi_rkey.c \
|
|
mi_rnext.c mi_rnext_same.c \
|
|
mi_search.c mi_page.c mi_key.c mi_locking.c \
|
|
mi_rrnd.c mi_scan.c mi_cache.c \
|
|
mi_statrec.c mi_packrec.c mi_dynrec.c \
|
|
mi_update.c mi_write.c mi_unique.c \
|
|
mi_delete.c \
|
|
mi_rprev.c mi_rfirst.c mi_rlast.c mi_rsame.c \
|
|
mi_rsamepos.c mi_panic.c mi_close.c mi_create.c\
|
|
mi_range.c mi_dbug.c mi_checksum.c mi_log.c \
|
|
mi_changed.c mi_static.c mi_delete_all.c \
|
|
mi_delete_table.c mi_rename.c mi_check.c \
|
|
mi_keycache.c mi_preload.c \
|
|
ft_parser.c ft_stopwords.c ft_static.c \
|
|
ft_update.c ft_boolean_search.c ft_nlq_search.c sort.c \
|
|
ha_myisam.cc \
|
|
rt_index.c rt_key.c rt_mbr.c rt_split.c sp_key.c
|
|
CLEANFILES = test?.MY? FT?.MY? isam.log mi_test_all rt_test.MY? sp_test.MY?
|
|
|
|
# Move to automake rules ?
|
|
prolint:; plparse -b -u -hF1 "-width(0,0)" "-format=%f:%l:\s%t:%n\s%m" \
|
|
"-elib(????)" "+elib(?3??)" my.lnt $(nisam_SOURCES)
|
|
|
|
SUFFIXES = .sh
|
|
|
|
.sh:
|
|
@RM@ -f $@ $@-t
|
|
@SED@ \
|
|
-e 's!@''bindir''@!$(bindir)!g' \
|
|
-e 's!@''scriptdir''@!$(bindir)!g' \
|
|
-e 's!@''prefix''@!$(prefix)!g' \
|
|
-e 's!@''datadir''@!$(datadir)!g' \
|
|
-e 's!@''localstatedir''@!$(localstatedir)!g' \
|
|
-e 's!@''libexecdir''@!$(libexecdir)!g' \
|
|
-e 's!@''CC''@!@CC@!'\
|
|
-e 's!@''CXX''@!@CXX@!'\
|
|
-e 's!@''GXX''@!@GXX@!'\
|
|
-e 's!@''PERL''@!@PERL@!' \
|
|
-e 's!@''CFLAGS''@!@SAVE_CFLAGS@!'\
|
|
-e 's!@''CXXFLAGS''@!@SAVE_CXXFLAGS@!'\
|
|
-e 's!@''LDFLAGS''@!@SAVE_LDFLAGS@!'\
|
|
-e 's!@''VERSION''@!@VERSION@!' \
|
|
-e 's!@''MYSQL_SERVER_SUFFIX''@!@MYSQL_SERVER_SUFFIX@!' \
|
|
-e 's!@''COMPILATION_COMMENT''@!@COMPILATION_COMMENT@!' \
|
|
-e 's!@''MACHINE_TYPE''@!@MACHINE_TYPE@!' \
|
|
-e 's!@''HOSTNAME''@!@HOSTNAME@!' \
|
|
-e 's!@''SYSTEM_TYPE''@!@SYSTEM_TYPE@!' \
|
|
-e 's!@''CHECK_PID''@!@CHECK_PID@!' \
|
|
-e 's!@''FIND_PROC''@!@FIND_PROC@!' \
|
|
-e 's!@''MYSQLD_DEFAULT_SWITCHES''@!@MYSQLD_DEFAULT_SWITCHES@!' \
|
|
-e 's!@''MYSQL_UNIX_ADDR''@!@MYSQL_UNIX_ADDR@!' \
|
|
-e 's!@''TARGET_LINUX''@!@TARGET_LINUX@!' \
|
|
-e "s!@""CONF_COMMAND""@!@CONF_COMMAND@!" \
|
|
-e 's!@''MYSQLD_USER''@!@MYSQLD_USER@!' \
|
|
-e 's!@''sysconfdir''@!@sysconfdir@!' \
|
|
-e 's!@''SHORT_MYSQL_INTRO''@!@SHORT_MYSQL_INTRO@!' \
|
|
-e 's!@''SHARED_LIB_VERSION''@!@SHARED_LIB_VERSION@!' \
|
|
-e 's!@''MYSQL_BASE_VERSION''@!@MYSQL_BASE_VERSION@!' \
|
|
-e 's!@''MYSQL_NO_DASH_VERSION''@!@MYSQL_NO_DASH_VERSION@!' \
|
|
-e 's!@''MYSQL_TCP_PORT''@!@MYSQL_TCP_PORT@!' \
|
|
-e 's!@''PERL_DBI_VERSION''@!@PERL_DBI_VERSION@!' \
|
|
-e 's!@''PERL_DBD_VERSION''@!@PERL_DBD_VERSION@!' \
|
|
-e 's!@''PERL_DATA_DUMPER''@!@PERL_DATA_DUMPER@!' \
|
|
$< > $@-t
|
|
@CHMOD@ +x $@-t
|
|
@MV@ $@-t $@
|
|
|
|
if HAVE_DTRACE_DASH_G
|
|
libmyisam_a_LIBADD = probes_mysql.o
|
|
libmyisam_a_DEPENDENCIES = probes_mysql.o dtrace_files dtrace_providers
|
|
CLEANFILES += probes_mysql.o dtrace_files dtrace_providers
|
|
DTRACEFILES = ha_myisam.o
|
|
DTRACEPROVIDER = probes_mysql.d
|
|
CLEANFILES += $(DTRACEPROVIDER) dtrace_sources
|
|
|
|
dtrace_files:
|
|
echo $(DTRACEFILES) > $@
|
|
dtrace_providers: probes_mysql.d
|
|
echo $(DTRACEPROVIDER) > $@
|
|
probes_mysql.d:
|
|
-$(RM) -f probes_mysql.d
|
|
$(CP) $(top_srcdir)/include/probes_mysql.d.base probes_mysql.d
|
|
echo timestamp > dtrace_sources
|
|
|
|
probes_mysql.o: $(DTRACEPROVIDER) $(DTRACEFILES)
|
|
$(DTRACE) $(DTRACEFLAGS) -G -s $(DTRACEPROVIDER) $(DTRACEFILES) -o $@
|
|
endif
|
|
|
|
# Don't update the files from bitkeeper
|
|
%::SCCS/s.%
|