938 lines
21 KiB
C
938 lines
21 KiB
C
/*
|
|
Copyright (c) 2004, 2014, Oracle and/or its affiliates. All rights reserved.
|
|
|
|
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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef NDB_VERSION_H
|
|
#define NDB_VERSION_H
|
|
|
|
#include <ndb_types.h>
|
|
#include <mysql_version.h>
|
|
|
|
/*
|
|
Creates a composite version number from major, minor and build
|
|
ex: NDB_MAKE_VERSION(5,1,47) => 0x00050147
|
|
*/
|
|
#define NDB_MAKE_VERSION(A,B,C) (((A) << 16) | ((B) << 8) | ((C) << 0))
|
|
|
|
/*
|
|
Creates a stringified version from major, minor and build
|
|
ex: NDB_MAKE_STRING_VERSION(7,0,22) => "7.0.22"
|
|
*/
|
|
#define NDB_MAKE_QUOTED_VERSION(A,B,C) #A "." #B "." #C
|
|
#define NDB_MAKE_STRING_VERSION(A,B,C) NDB_MAKE_QUOTED_VERSION(A,B,C)
|
|
|
|
/* NDB version numbers and status */
|
|
#define NDB_VERSION_MAJOR @NDB_VERSION_MAJOR@
|
|
#define NDB_VERSION_MINOR @NDB_VERSION_MINOR@
|
|
#define NDB_VERSION_BUILD @NDB_VERSION_BUILD@
|
|
#define NDB_VERSION_STATUS "@NDB_VERSION_STATUS@"
|
|
|
|
/* Composite version number for NDB */
|
|
#define NDB_VERSION_D \
|
|
NDB_MAKE_VERSION(NDB_VERSION_MAJOR, NDB_VERSION_MINOR, NDB_VERSION_BUILD)
|
|
|
|
/* Version string for NDB, ex: "ndb-7.0.22" */
|
|
#define NDB_NDB_VERSION_STRING \
|
|
"ndb-" NDB_MAKE_STRING_VERSION(NDB_VERSION_MAJOR, \
|
|
NDB_VERSION_MINOR, \
|
|
NDB_VERSION_BUILD) NDB_VERSION_STATUS
|
|
|
|
/*
|
|
The version number of the MySQL Server that NDB is built
|
|
with. Extracted from MYSQL_VERSION_ID
|
|
*/
|
|
#define NDB_MYSQL_VERSION_MAJOR ((MYSQL_VERSION_ID / 10000) % 100)
|
|
#define NDB_MYSQL_VERSION_MINOR ((MYSQL_VERSION_ID /100) % 100)
|
|
#define NDB_MYSQL_VERSION_BUILD (MYSQL_VERSION_ID % 100)
|
|
|
|
/* Composite version number for MYSQL Server */
|
|
#define NDB_MYSQL_VERSION_D \
|
|
NDB_MAKE_VERSION(NDB_MYSQL_VERSION_MAJOR, \
|
|
NDB_MYSQL_VERSION_MINOR, \
|
|
NDB_MYSQL_VERSION_BUILD)
|
|
|
|
#define NDB_VERSION_STRING_BUF_SZ 100
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
void ndbPrintVersion();
|
|
|
|
Uint32 ndbMakeVersion(Uint32 major, Uint32 minor, Uint32 build);
|
|
|
|
Uint32 ndbGetMajor(Uint32 version);
|
|
|
|
Uint32 ndbGetMinor(Uint32 version);
|
|
|
|
Uint32 ndbGetBuild(Uint32 version);
|
|
|
|
const char* ndbGetVersionString(Uint32 version, Uint32 mysql_version, const char * status,
|
|
char *buf, unsigned sz);
|
|
const char* ndbGetOwnVersionString();
|
|
|
|
Uint32 ndbGetOwnVersion();
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#define NDB_VERSION_STRING ndbGetOwnVersionString()
|
|
|
|
#define NDB_VERSION ndbGetOwnVersion()
|
|
|
|
/**
|
|
* This is updated each time a version of backup/lcp format is changed
|
|
* when it's updated, it's set to version that made the change
|
|
*/
|
|
#define NDB_BACKUP_VERSION NDB_MAKE_VERSION(6,3,11)
|
|
|
|
/**
|
|
* From which version do we support rowid
|
|
*/
|
|
#define NDBD_ROWID_VERSION (NDB_MAKE_VERSION(5,1,6))
|
|
#define NDBD_INCL_NODECONF_VERSION_4 NDB_MAKE_VERSION(4,1,17)
|
|
#define NDBD_INCL_NODECONF_VERSION_5 NDB_MAKE_VERSION(5,0,18)
|
|
#define NDBD_FRAGID_VERSION (NDB_MAKE_VERSION(5,1,6))
|
|
#define NDBD_DICT_LOCK_VERSION_5 NDB_MAKE_VERSION(5,0,23)
|
|
#define NDBD_DICT_LOCK_VERSION_5_1 NDB_MAKE_VERSION(5,1,12)
|
|
|
|
#define NDBD_UPDATE_FRAG_DIST_KEY_50 NDB_MAKE_VERSION(5,0,26)
|
|
#define NDBD_UPDATE_FRAG_DIST_KEY_51 NDB_MAKE_VERSION(5,1,12)
|
|
|
|
#define NDBD_QMGR_SINGLEUSER_VERSION_5 NDB_MAKE_VERSION(5,0,25)
|
|
|
|
#define NDBD_SPLIT_VERSION NDB_MAKE_VERSION(6,1,0)
|
|
#define NDBD_NODE_VERSION_REP NDB_MAKE_VERSION(6,1,1)
|
|
|
|
#define NDBD_255_NODES_VERSION NDB_MAKE_VERSION(5,1,4)
|
|
|
|
#define NDBD_MICRO_GCP_62 NDB_MAKE_VERSION(6,2,5)
|
|
#define NDBD_MICRO_GCP_63 NDB_MAKE_VERSION(6,3,2)
|
|
#define NDBD_RAW_LCP MAKE_VERSION(6,3,11)
|
|
#define NDBD_LONG_TCKEYREQ NDB_MAKE_VERSION(6,4,0)
|
|
#define NDBD_LONG_LQHKEYREQ MAKE_VERSION(6,4,0)
|
|
#define NDBD_MAX_RECVBYTESIZE_32K MAKE_VERSION(6,3,18)
|
|
#define NDBD_LONG_SCANTABREQ NDB_MAKE_VERSION(6,4,0)
|
|
#define NDBD_LONG_SCANFRAGREQ MAKE_VERSION(6,4,0)
|
|
#define NDBD_MT_LQH_VERSION MAKE_VERSION(6,4,0)
|
|
|
|
#define NDBD_SCHEMA_TRANS_VERSION NDB_MAKE_VERSION(6,4,0)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_check_micro_gcp(Uint32 version)
|
|
{
|
|
if (version == NDB_VERSION_D)
|
|
return 1;
|
|
{
|
|
const Uint32 major = (version >> 16) & 0xFF;
|
|
const Uint32 minor = (version >> 8) & 0xFF;
|
|
if (major >= 6)
|
|
{
|
|
if (minor == 2)
|
|
return version >= NDBD_MICRO_GCP_62;
|
|
return version >= NDBD_MICRO_GCP_63;
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
#define NDBD_PREPARE_COPY_FRAG_VERSION NDB_MAKE_VERSION(6,2,1)
|
|
#define NDBD_PREPARE_COPY_FRAG_V2_51 NDB_MAKE_VERSION(5,1,23)
|
|
#define NDBD_PREPARE_COPY_FRAG_V2_62 NDB_MAKE_VERSION(6,2,8)
|
|
#define NDBD_PREPARE_COPY_FRAG_V2_63 NDB_MAKE_VERSION(6,3,6)
|
|
|
|
/**
|
|
* 0 = NO PREP COPY FRAG SUPPORT
|
|
* 1 = NO MAX PAGE SUPPORT
|
|
* 2 = LATEST VERSION
|
|
*/
|
|
static
|
|
inline
|
|
int
|
|
ndb_check_prep_copy_frag_version(Uint32 version)
|
|
{
|
|
const Uint32 major = (version >> 16) & 0xFF;
|
|
const Uint32 minor = (version >> 8) & 0xFF;
|
|
|
|
if (version == NDB_VERSION_D)
|
|
return 2;
|
|
|
|
if (major >= 6)
|
|
{
|
|
if (minor == 2)
|
|
{
|
|
if (version >= NDBD_PREPARE_COPY_FRAG_V2_62)
|
|
return 2;
|
|
if (version >= NDBD_PREPARE_COPY_FRAG_VERSION)
|
|
return 1;
|
|
return 0;
|
|
}
|
|
else if (minor == 3)
|
|
{
|
|
if (version >= NDBD_PREPARE_COPY_FRAG_V2_63)
|
|
return 2;
|
|
return 1;
|
|
}
|
|
return 2;
|
|
}
|
|
else if (major == 5 && minor == 1)
|
|
{
|
|
if (version >= NDBD_PREPARE_COPY_FRAG_V2_51)
|
|
return 2;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
#define NDBD_PNR NDB_MAKE_VERSION(6,3,8)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_pnr(Uint32 version)
|
|
{
|
|
return
|
|
version == NDB_VERSION_D || version >= NDBD_PNR;
|
|
}
|
|
|
|
#define NDBD_SUMA_DICT_LOCK_62 NDB_MAKE_VERSION(6,2,14)
|
|
#define NDBD_SUMA_DICT_LOCK_63 NDB_MAKE_VERSION(6,3,11)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_suma_dictlock_startme(Uint32 x)
|
|
{
|
|
if (x >= NDB_VERSION_D)
|
|
return 1;
|
|
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major >= 6)
|
|
{
|
|
if (minor == 2)
|
|
return x >= NDBD_SUMA_DICT_LOCK_62;
|
|
}
|
|
|
|
return x >= NDBD_SUMA_DICT_LOCK_63;
|
|
}
|
|
}
|
|
|
|
#define NDBD_LONG_LIST_TABLES_CONF_62 NDB_MAKE_VERSION(6,2,16)
|
|
#define NDBD_LONG_LIST_TABLES_CONF_63 NDB_MAKE_VERSION(6,3,15)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_LIST_TABLES_CONF_long_signal(Uint32 x)
|
|
{
|
|
if (x >= NDB_VERSION_D)
|
|
return 1;
|
|
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major >= 6)
|
|
{
|
|
if (minor == 2)
|
|
return x >= NDBD_LONG_LIST_TABLES_CONF_62;
|
|
}
|
|
|
|
return x >= NDBD_LONG_LIST_TABLES_CONF_63;
|
|
}
|
|
}
|
|
|
|
#if NOT_YET
|
|
#define NDBD_FIRE_TRIG_ORD_TRANSID_63 NDB_MAKE_VERSION(6,3,9)
|
|
#define NDBD_FIRE_TRIG_ORD_TRANSID_62 NDB_MAKE_VERSION(6,2,12)
|
|
#endif
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_fire_trig_ord_transid(Uint32 version)
|
|
{
|
|
if (version >= NDB_VERSION_D)
|
|
return 1;
|
|
|
|
#if NOT_YET
|
|
const Uint32 major = (version >> 16) & 0xFF;
|
|
const Uint32 minor = (version >> 8) & 0xFF;
|
|
if (major >= 6)
|
|
{
|
|
if (minor == 2)
|
|
{
|
|
return version >= NDBD_FIRE_TRIG_ORD_TRANSID_62;
|
|
}
|
|
|
|
return version >= NDBD_FIRE_TRIG_ORD_TRANSID_63;
|
|
}
|
|
#endif
|
|
|
|
return 0;
|
|
}
|
|
|
|
#define NDBD_SCAN_DISTKEY NDB_MAKE_VERSION(6,4,0)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_scan_distributionkey(Uint32 version)
|
|
{
|
|
return version >= NDBD_SCAN_DISTKEY;
|
|
}
|
|
|
|
#define NDBD_FILTER_INSTANCE_63 NDB_MAKE_VERSION(6,3,16)
|
|
#define NDBD_COPY_GCI_RESTART_NR NDB_MAKE_VERSION(6,3,18)
|
|
|
|
#define NDBD_SUMA_DICTLOCK_HANDOVER NDB_MAKE_VERSION(6,4,0)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_suma_dictlock_handover(Uint32 x)
|
|
{
|
|
return (x >= NDBD_SUMA_DICTLOCK_HANDOVER);
|
|
}
|
|
|
|
#define NDBD_API_TAKE_OVERTCCONF_60 NDB_MAKE_VERSION(5,2,4)
|
|
#define NDBD_API_TAKE_OVERTCCONF_62 NDB_MAKE_VERSION(6,2,17)
|
|
#define NDBD_API_TAKE_OVERTCCONF_63 NDB_MAKE_VERSION(6,3,19)
|
|
|
|
#define NDBD_DELAYED_COPY_ACTIVEREQ_63 NDB_MAKE_VERSION(6,3,29)
|
|
#define NDBD_DELAYED_COPY_ACTIVEREQ_70 NDB_MAKE_VERSION(7,0,10)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_takeovertc(Uint32 x)
|
|
{
|
|
if (x >= NDB_VERSION_D)
|
|
return 1;
|
|
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major >= 6)
|
|
{
|
|
if (minor == 2)
|
|
return x >= NDBD_API_TAKE_OVERTCCONF_62;
|
|
}
|
|
|
|
return x >= NDBD_API_TAKE_OVERTCCONF_63;
|
|
}
|
|
}
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_delayed_copy_active_req(Uint32 x)
|
|
{
|
|
if (x >= NDB_VERSION_D)
|
|
return 1;
|
|
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
|
|
if (major == 6)
|
|
{
|
|
return x >= NDBD_DELAYED_COPY_ACTIVEREQ_63;
|
|
}
|
|
else
|
|
{
|
|
return x >= NDBD_DELAYED_COPY_ACTIVEREQ_70;
|
|
}
|
|
}
|
|
}
|
|
|
|
#define NDBD_SUMA_NOTSTARTED_REF_63 NDB_MAKE_VERSION(6,3,29)
|
|
#define NDBD_SUMA_NOTSTARTED_REF_70 NDB_MAKE_VERSION(7,0,10)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_suma_not_started_ref(Uint32 x)
|
|
{
|
|
if (x >= NDB_VERSION_D)
|
|
return 1;
|
|
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
|
|
if (major == 6)
|
|
{
|
|
return x >= NDBD_SUMA_NOTSTARTED_REF_63;
|
|
}
|
|
else
|
|
{
|
|
return x >= NDBD_SUMA_NOTSTARTED_REF_70;
|
|
}
|
|
}
|
|
}
|
|
|
|
#define NDBD_UNLOCK_OP_SUPPORTED NDB_MAKE_VERSION(7,0,12)
|
|
|
|
#define NDBD_ROUTE_EXEC_FRAG NDB_MAKE_VERSION(7,0,13)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_route_exec_frag(Uint32 x)
|
|
{
|
|
if (x >= NDB_VERSION_D)
|
|
return 1;
|
|
|
|
return x >= NDBD_ROUTE_EXEC_FRAG;
|
|
}
|
|
|
|
#define NDBD_NATIVE_DEFAULT_SUPPORT_70 NDB_MAKE_VERSION(7,0,15)
|
|
#define NDBD_NATIVE_DEFAULT_SUPPORT_71 NDB_MAKE_VERSION(7,1,4)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_native_default_support(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor == 0)
|
|
return x >= NDBD_NATIVE_DEFAULT_SUPPORT_70;
|
|
|
|
return x >= NDBD_NATIVE_DEFAULT_SUPPORT_71;
|
|
}
|
|
|
|
#define NDBD_HB_ORDER_VERSION_63 NDB_MAKE_VERSION(6,3,35)
|
|
#define NDBD_HB_ORDER_VERSION_70 NDB_MAKE_VERSION(7,0,16)
|
|
#define NDBD_HB_ORDER_VERSION_71 NDB_MAKE_VERSION(7,1,5)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_check_hb_order_version(Uint32 x)
|
|
{
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 6 && minor == 3)
|
|
{
|
|
return x >= NDBD_HB_ORDER_VERSION_63;
|
|
}
|
|
if (major == 7 && minor == 0)
|
|
{
|
|
return x >= NDBD_HB_ORDER_VERSION_70;
|
|
}
|
|
return x >= NDBD_HB_ORDER_VERSION_71;
|
|
}
|
|
}
|
|
|
|
#define NDBD_SYNCH_SP_70 NDB_MAKE_VERSION(7,0,17)
|
|
#define NDBD_SYNCH_SP_71 NDB_MAKE_VERSION(7,1,6)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_wait_sp(Uint32 x)
|
|
{
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor == 0)
|
|
{
|
|
return x >= NDBD_SYNCH_SP_70;
|
|
}
|
|
return x >= NDBD_SYNCH_SP_71;
|
|
}
|
|
}
|
|
|
|
#define NDBD_DIH_GET_TABINFO_70 NDB_MAKE_VERSION(7,0,17)
|
|
#define NDBD_DIH_GET_TABINFO_71 NDB_MAKE_VERSION(7,1,6)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_dih_get_tabinfo(Uint32 x)
|
|
{
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor == 0)
|
|
{
|
|
return x >= NDBD_DIH_GET_TABINFO_70;
|
|
}
|
|
return x >= NDBD_DIH_GET_TABINFO_71;
|
|
}
|
|
}
|
|
|
|
#define NDBD_SUMA_STOP_ME_63 NDB_MAKE_VERSION(6,3,37)
|
|
#define NDBD_SUMA_STOP_ME_70 NDB_MAKE_VERSION(7,0,18)
|
|
#define NDBD_SUMA_STOP_ME_71 NDB_MAKE_VERSION(7,1,7)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_suma_stop_me(Uint32 x)
|
|
{
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 6)
|
|
{
|
|
return x >= NDBD_SUMA_STOP_ME_63;
|
|
}
|
|
if (major == 7 && minor == 0)
|
|
{
|
|
return x >= NDBD_SUMA_STOP_ME_70;
|
|
}
|
|
return x >= NDBD_SUMA_STOP_ME_71;
|
|
}
|
|
}
|
|
|
|
#define NDBD_DIH_SUB_GCP_COMPLETE_ACK_63 NDB_MAKE_VERSION(6,3,39)
|
|
#define NDBD_DIH_SUB_GCP_COMPLETE_ACK_70 NDB_MAKE_VERSION(7,0,20)
|
|
#define NDBD_DIH_SUB_GCP_COMPLETE_ACK_71 NDB_MAKE_VERSION(7,1,9)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_dih_sub_gcp_complete_ack(Uint32 x)
|
|
{
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 6)
|
|
{
|
|
return x >= NDBD_DIH_SUB_GCP_COMPLETE_ACK_63;
|
|
}
|
|
if (major == 7 && minor == 0)
|
|
{
|
|
return x >= NDBD_DIH_SUB_GCP_COMPLETE_ACK_70;
|
|
}
|
|
return x >= NDBD_DIH_SUB_GCP_COMPLETE_ACK_71;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* After this version, TC/BACKUP/SUMA does not use ScanFragReq::setAttrLen
|
|
* when sending long SCAN_FRAGREQ
|
|
*/
|
|
#define NDBD_LONG_SCAN_FRAGREQ_70 NDB_MAKE_VERSION(7,0,20)
|
|
#define NDBD_LONG_SCAN_FRAGREQ_71 NDB_MAKE_VERSION(7,1,9)
|
|
|
|
#define NDBD_FAIL_REP_SOURCE_NODE_63 NDB_MAKE_VERSION(6,3,40)
|
|
#define NDBD_FAIL_REP_SOURCE_NODE_70 NDB_MAKE_VERSION(7,0,21)
|
|
#define NDBD_FAIL_REP_SOURCE_NODE_71 NDB_MAKE_VERSION(7,1,10)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_fail_rep_source_node(Uint32 x)
|
|
{
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 6)
|
|
{
|
|
return x >= NDBD_FAIL_REP_SOURCE_NODE_63;
|
|
}
|
|
if (major == 7 && minor == 0)
|
|
{
|
|
return x >= NDBD_FAIL_REP_SOURCE_NODE_70;
|
|
}
|
|
return x >= NDBD_FAIL_REP_SOURCE_NODE_71;
|
|
}
|
|
}
|
|
|
|
|
|
#define NDBD_SYNC_REQ_SUPPORT_70 NDB_MAKE_VERSION(7,0,20)
|
|
#define NDBD_SYNC_REQ_SUPPORT_71 NDB_MAKE_VERSION(7,1,9)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_sync_req_support(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor == 0)
|
|
return x >= NDBD_SYNC_REQ_SUPPORT_70;
|
|
|
|
return x >= NDBD_SYNC_REQ_SUPPORT_71;
|
|
}
|
|
|
|
/**
|
|
* Does not support CopyFragReq::CFR_NON_TRANSACTIONAL
|
|
*/
|
|
#define NDBD_NON_TRANS_COPY_FRAG_REQ_70 NDB_MAKE_VERSION(7,0,22)
|
|
#define NDBD_NON_TRANS_COPY_FRAG_REQ_71 NDB_MAKE_VERSION(7,1,11)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_non_trans_copy_frag_req(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor == 0)
|
|
return x >= NDBD_NON_TRANS_COPY_FRAG_REQ_70;
|
|
|
|
return x >= NDBD_NON_TRANS_COPY_FRAG_REQ_71;
|
|
}
|
|
|
|
#define NDBD_PING_REQ_70 NDB_MAKE_VERSION(7,0,24)
|
|
#define NDBD_PING_REQ_71 NDB_MAKE_VERSION(7,1,13)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_connectivity_check(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor == 0)
|
|
return x >= NDBD_PING_REQ_70;
|
|
|
|
return x >= NDBD_PING_REQ_71;
|
|
}
|
|
|
|
#define NDBD_DEFERRED_UNIQUE_CONSTRAINTS_70 NDB_MAKE_VERSION(7,0,25)
|
|
#define NDBD_DEFERRED_UNIQUE_CONSTRAINTS_71 NDB_MAKE_VERSION(7,1,14)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_deferred_unique_constraints(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor == 0)
|
|
return x >= NDBD_DEFERRED_UNIQUE_CONSTRAINTS_70;
|
|
|
|
return x >= NDBD_DEFERRED_UNIQUE_CONSTRAINTS_71;
|
|
}
|
|
|
|
#define NDBD_TUP_EXTRABITS_70 NDB_MAKE_VERSION(7,0,25)
|
|
#define NDBD_TUP_EXTRABITS_71 NDB_MAKE_VERSION(7,1,14)
|
|
#define NDBD_TUP_EXTRABITS_72 NDB_MAKE_VERSION(7,2,1)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_tup_extrabits(Uint32 x)
|
|
{
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor < 2)
|
|
{
|
|
if (minor == 0)
|
|
return x >= NDBD_TUP_EXTRABITS_70;
|
|
else if (minor == 1)
|
|
return x >= NDBD_TUP_EXTRABITS_71;
|
|
}
|
|
return x >= NDBD_TUP_EXTRABITS_72;
|
|
}
|
|
}
|
|
|
|
#define NDBD_REFRESH_TUPLE_70 NDB_MAKE_VERSION(7,0,26)
|
|
#define NDBD_REFRESH_TUPLE_71 NDB_MAKE_VERSION(7,1,15)
|
|
#define NDBD_REFRESH_TUPLE_72 NDB_MAKE_VERSION(7,2,1)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_refresh_tuple(Uint32 x)
|
|
{
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor < 2)
|
|
{
|
|
if (minor == 0)
|
|
return x >= NDBD_REFRESH_TUPLE_70;
|
|
else if (minor == 1)
|
|
return x >= NDBD_REFRESH_TUPLE_71;
|
|
}
|
|
return x >= NDBD_REFRESH_TUPLE_72;
|
|
}
|
|
}
|
|
|
|
#define NDBD_GET_CONFIG_SUPPORT_70 NDB_MAKE_VERSION(7,0,27)
|
|
#define NDBD_GET_CONFIG_SUPPORT_71 NDB_MAKE_VERSION(7,1,16)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_get_config_supported(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor == 0)
|
|
return x >= NDBD_GET_CONFIG_SUPPORT_70;
|
|
|
|
return x >= NDBD_GET_CONFIG_SUPPORT_71;
|
|
}
|
|
|
|
#define NDBD_CONFIGURABLE_LOG_PARTS_70 NDB_MAKE_VERSION(7,0,29)
|
|
#define NDBD_CONFIGURABLE_LOG_PARTS_71 NDB_MAKE_VERSION(7,1,18)
|
|
#define NDBD_CONFIGURABLE_LOG_PARTS_72 NDB_MAKE_VERSION(7,2,3)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_configurable_log_parts(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor < 2)
|
|
{
|
|
if (minor == 0)
|
|
return x >= NDBD_CONFIGURABLE_LOG_PARTS_70;
|
|
else if (minor == 1)
|
|
return x >= NDBD_CONFIGURABLE_LOG_PARTS_71;
|
|
}
|
|
return x >= NDBD_CONFIGURABLE_LOG_PARTS_72;
|
|
}
|
|
|
|
#define NDBD_128_INSTANCES_ADDRESS_70 NDB_MAKE_VERSION(7,0,31)
|
|
#define NDBD_128_INSTANCES_ADDRESS_71 NDB_MAKE_VERSION(7,1,20)
|
|
#define NDBD_128_INSTANCES_ADDRESS_72 NDB_MAKE_VERSION(7,2,5)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_128_instances_address(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor < 2)
|
|
{
|
|
if (minor == 0)
|
|
return x >= NDBD_128_INSTANCES_ADDRESS_70;
|
|
else if (minor == 1)
|
|
return x >= NDBD_128_INSTANCES_ADDRESS_71;
|
|
}
|
|
return x >= NDBD_128_INSTANCES_ADDRESS_72;
|
|
}
|
|
|
|
#define NDBD_SCAN_TABREQ_IMPLICIT_PARALLELISM_70 NDB_MAKE_VERSION(7,0,34)
|
|
#define NDBD_SCAN_TABREQ_IMPLICIT_PARALLELISM_71 NDB_MAKE_VERSION(7,1,23)
|
|
#define NDBD_SCAN_TABREQ_IMPLICIT_PARALLELISM_72 NDB_MAKE_VERSION(7,2,7)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_scan_tabreq_implicit_parallelism(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor < 2)
|
|
{
|
|
if (minor == 0)
|
|
return x >= NDBD_SCAN_TABREQ_IMPLICIT_PARALLELISM_70;
|
|
else if (minor == 1)
|
|
return x >= NDBD_SCAN_TABREQ_IMPLICIT_PARALLELISM_71;
|
|
}
|
|
return x >= NDBD_SCAN_TABREQ_IMPLICIT_PARALLELISM_72;
|
|
}
|
|
|
|
#define NDBD_FIXED_LOOKUP_QUERY_ABORT_72 NDB_MAKE_VERSION(7,2,5)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_fixed_lookup_query_abort(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major == 7 && minor < 2)
|
|
{
|
|
// Only experimental support of SPJ pre 7.2.0.
|
|
// Assume we support 'fixed-abort' as we want it tested.
|
|
return 1;
|
|
}
|
|
return x >= NDBD_FIXED_LOOKUP_QUERY_ABORT_72;
|
|
}
|
|
|
|
/**
|
|
* NOTE1:
|
|
* Even though pushed join support wasn't GA intil 7.2.4
|
|
* we claim support for it in all 7.2.x versions.
|
|
* NOTE2:
|
|
* By a mistake this online upgrade check was not
|
|
* added until version 7.2.6
|
|
*/
|
|
#define NDBD_JOIN_PUSHDOWN NDB_MAKE_VERSION(7,2,0)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndb_join_pushdown(Uint32 x)
|
|
{
|
|
return x >= NDBD_JOIN_PUSHDOWN;
|
|
}
|
|
|
|
/**
|
|
* DICT did not have a function for receiving GET_TABINFOREF signals
|
|
* (see Bug#14647210).
|
|
*/
|
|
#define NDBD_DICT_GET_TABINFOREF_IMPLEMENTED NDB_MAKE_VERSION(7, 2, 9)
|
|
|
|
inline
|
|
int
|
|
ndbd_dict_get_tabinforef_implemented(Uint32 x)
|
|
{
|
|
return x >= NDBD_DICT_GET_TABINFOREF_IMPLEMENTED;
|
|
}
|
|
|
|
/**
|
|
* Dbtc::execFIRE_TRIG_ORD can receive long signals.
|
|
*/
|
|
#define NDBD_LONG_FIRE_TRIG_ORD NDB_MAKE_VERSION(7,3,2)
|
|
|
|
#define NDBD_MULTI_TC_INSTANCE_TAKEOVER_72 NDB_MAKE_VERSION(7,2,17)
|
|
#define NDBD_MULTI_TC_INSTANCE_TAKEOVER_73 NDB_MAKE_VERSION(7,3,6)
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_long_fire_trig_ord(Uint32 x)
|
|
{
|
|
return x >= NDBD_LONG_FIRE_TRIG_ORD;
|
|
}
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_multi_tc_instance_takeover(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major < 7)
|
|
{
|
|
return 0;
|
|
}
|
|
else if (major == 7)
|
|
{
|
|
if (minor < 2)
|
|
{
|
|
return 0;
|
|
}
|
|
else if (minor == 2)
|
|
{
|
|
return x >= NDBD_MULTI_TC_INSTANCE_TAKEOVER_72;
|
|
}
|
|
else if (minor == 3)
|
|
{
|
|
return x >= NDBD_MULTI_TC_INSTANCE_TAKEOVER_73;
|
|
}
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
/**
|
|
* Support for more parallel fragment LCPs
|
|
*/
|
|
#define NDBD_EXTRA_PARALLEL_FRAG_LCP NDB_MAKE_VERSION(7,4,1)
|
|
|
|
/**
|
|
* Support for PAUSE LCPs
|
|
*/
|
|
#define NDBD_SUPPORT_PAUSE_LCP NDB_MAKE_VERSION(7,4,3)
|
|
|
|
/**
|
|
* Support for Node Recovery Status module, including sending
|
|
* END_TOREP.
|
|
*/
|
|
#define NDBD_NODE_RECOVERY_STATUS_VERSION NDB_MAKE_VERSION(7,4,3)
|
|
|
|
/**
|
|
* Support for removing EMPTY_LCP_REQ protocol in master takeover
|
|
*/
|
|
#define NDBD_EMPTY_LCP_NOT_NEEDED NDB_MAKE_VERSION(7,4,3)
|
|
|
|
/**
|
|
* Support for multiple take over threads per node group in parallel
|
|
* in master node.
|
|
*/
|
|
#define NDBD_SUPPORT_PARALLEL_SYNCH NDB_MAKE_VERSION(7,4,3)
|
|
|
|
#define NDBD_ISOLATE_ORD_72 NDB_MAKE_VERSION(7,2,19)
|
|
#define NDBD_ISOLATE_ORD_73 NDB_MAKE_VERSION(7,3,8)
|
|
#define NDBD_ISOLATE_ORD_74 NDB_MAKE_VERSION(7,4,3)
|
|
|
|
|
|
static
|
|
inline
|
|
int
|
|
ndbd_isolate_ord(Uint32 x)
|
|
{
|
|
const Uint32 major = (x >> 16) & 0xFF;
|
|
const Uint32 minor = (x >> 8) & 0xFF;
|
|
|
|
if (major < 7)
|
|
{
|
|
return 0;
|
|
}
|
|
else if (major == 7)
|
|
{
|
|
if (minor < 2)
|
|
{
|
|
return 0;
|
|
}
|
|
else if (minor == 2)
|
|
{
|
|
return x >= NDBD_ISOLATE_ORD_72;
|
|
}
|
|
else if (minor == 3)
|
|
{
|
|
return x >= NDBD_ISOLATE_ORD_73;
|
|
}
|
|
else if (minor == 4)
|
|
{
|
|
return x >= NDBD_ISOLATE_ORD_74;
|
|
}
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
#endif
|