MasterGCP.hpp
上传用户:romrleung
上传日期:2022-05-23
资源大小:18897k
文件大小:2k
源码类别:

MySQL数据库

开发平台:

Visual C++

  1. /* Copyright (C) 2003 MySQL AB
  2.    This program is free software; you can redistribute it and/or modify
  3.    it under the terms of the GNU General Public License as published by
  4.    the Free Software Foundation; either version 2 of the License, or
  5.    (at your option) any later version.
  6.    This program is distributed in the hope that it will be useful,
  7.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  8.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  9.    GNU General Public License for more details.
  10.    You should have received a copy of the GNU General Public License
  11.    along with this program; if not, write to the Free Software
  12.    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
  13. #ifndef MASTER_GCP_HPP
  14. #define MASTER_GCP_HPP
  15. #include <NodeBitmask.hpp>
  16. /**
  17.  * 
  18.  */
  19. class MasterGCPConf {
  20.   /**
  21.    * Sender(s) / Reciver(s)
  22.    */
  23.   friend class Dbdih;
  24.     
  25. public:
  26.   STATIC_CONST( SignalLength = 8 + NdbNodeBitmask::Size );
  27.   enum State {
  28.     GCP_READY            = 0,
  29.     GCP_PREPARE_RECEIVED = 1,
  30.     GCP_COMMIT_RECEIVED  = 2,
  31.     GCP_TC_FINISHED      = 3
  32.   };
  33. private:  
  34.   /**
  35.    * Data replied
  36.    */
  37.   Uint32 gcpState;
  38.   Uint32 senderNodeId;
  39.   Uint32 failedNodeId;
  40.   Uint32 newGCP;
  41.   Uint32 latestLCP;
  42.   Uint32 oldestRestorableGCI;
  43.   Uint32 keepGCI;
  44.   Uint32 lcpActive[NdbNodeBitmask::Size];
  45. };
  46. /**
  47.  * 
  48.  */
  49. class MasterGCPReq {
  50.   /**
  51.    * Sender(s) / Reciver(s)
  52.    */
  53.   friend class Dbdih;
  54.     
  55. public:
  56.   STATIC_CONST( SignalLength = 2 );
  57. private:
  58.   Uint32 masterRef;
  59.   Uint32 failedNodeId;
  60. };
  61. /**
  62.  * 
  63.  */
  64. class MasterGCPRef {
  65.   /**
  66.    * Sender(s) / Reciver(s)
  67.    */
  68.   friend class Dbdih;
  69.     
  70. public:
  71.   STATIC_CONST( SignalLength = 2 );
  72. private:
  73.   Uint32 senderNodeId;
  74.   Uint32 failedNodeId;
  75. };
  76. #endif