diff options
author | Sergei Golubchik <sergii@pisem.net> | 2013-04-11 19:35:39 +0200 |
---|---|---|
committer | Sergei Golubchik <sergii@pisem.net> | 2013-04-11 19:35:39 +0200 |
commit | ea4a417a8d456e8e09b6b4306f22c7c20b3e594c (patch) | |
tree | 01f9700b021029f4d6b878a3a0feab7ab8b8a458 /include | |
parent | 5d9e50fc950502698d3beb95577bc5fe441b38b7 (diff) | |
parent | 61ed0ebe7388d8302f2de7144de41da32bf085ba (diff) | |
download | mariadb-git-ea4a417a8d456e8e09b6b4306f22c7c20b3e594c.tar.gz |
5.2 merge
Diffstat (limited to 'include')
-rw-r--r-- | include/my_global.h | 3 | ||||
-rw-r--r-- | include/mysql_com.h | 25 |
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 |