summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorSergei Golubchik <sergii@pisem.net>2013-04-11 19:35:39 +0200
committerSergei Golubchik <sergii@pisem.net>2013-04-11 19:35:39 +0200
commitea4a417a8d456e8e09b6b4306f22c7c20b3e594c (patch)
tree01f9700b021029f4d6b878a3a0feab7ab8b8a458 /include
parent5d9e50fc950502698d3beb95577bc5fe441b38b7 (diff)
parent61ed0ebe7388d8302f2de7144de41da32bf085ba (diff)
downloadmariadb-git-ea4a417a8d456e8e09b6b4306f22c7c20b3e594c.tar.gz
5.2 merge
Diffstat (limited to 'include')
-rw-r--r--include/my_global.h3
-rw-r--r--include/mysql_com.h25
2 files changed, 27 insertions, 1 deletions
diff --git a/include/my_global.h b/include/my_global.h
index da6c918ff4d..41ab8bc518d 100644
--- a/include/my_global.h
+++ b/include/my_global.h
@@ -498,7 +498,8 @@ C_MODE_END
#define compile_time_assert(X) \
do \
{ \
- typedef char compile_time_assert[(X) ? 1 : -1]; \
+ typedef char compile_time_assert[(X) ? 1 : -1] \
+ __attribute__((unused)); \
} while(0)
#endif
diff --git a/include/mysql_com.h b/include/mysql_com.h
index d811b79889b..29869254171 100644
--- a/include/mysql_com.h
+++ b/include/mysql_com.h
@@ -31,6 +31,31 @@
#define MYSQL50_TABLE_NAME_PREFIX_LENGTH (sizeof(MYSQL50_TABLE_NAME_PREFIX)-1)
#define SAFE_NAME_LEN (NAME_LEN + MYSQL50_TABLE_NAME_PREFIX_LENGTH)
+/*
+ MDEV-4088
+
+ MySQL (and MariaDB 5.x before the fix) was using the first character of the
+ server version string (as sent in the first handshake protocol packet) to
+ decide on the replication event formats. And for 10.x the first character
+ is "1", which the slave thought comes from some ancient 1.x version
+ (ignoring the fact that the first ever MySQL version was 3.x).
+
+ To support replication to these old clients, we fake the version in the
+ first handshake protocol packet to start from "5.5.5-" (for example,
+ it might be "5.5.5-10.0.1-MariaDB-debug-log".
+
+ On the client side we remove this fake version prefix to restore the
+ correct server version. The version "5.5.5" did not support
+ pluggable authentication, so any version starting from "5.5.5-" and
+ claiming to support pluggable auth, must be using this fake prefix.
+*/
+#ifdef EMBEDDED_LIBRARY
+#define RPL_VERSION_HACK ""
+#else
+/* this version must be the one that *does not* support pluggable auth */
+#define RPL_VERSION_HACK "5.5.5-"
+#endif
+
#define SERVER_VERSION_LENGTH 60
#define SQLSTATE_LENGTH 5
#define LIST_PROCESS_HOST_LEN 64