MySQL 5.6.14 Source Code Document
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
MasterGCP.hpp
1 /*
2  Copyright (C) 2003, 2005-2007 MySQL AB
3  All rights reserved. Use is subject to license terms.
4 
5  This program is free software; you can redistribute it and/or modify
6  it under the terms of the GNU General Public License as published by
7  the Free Software Foundation; version 2 of the License.
8 
9  This program is distributed in the hope that it will be useful,
10  but WITHOUT ANY WARRANTY; without even the implied warranty of
11  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  GNU General Public License for more details.
13 
14  You should have received a copy of the GNU General Public License
15  along with this program; if not, write to the Free Software
16  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
17 */
18 
19 #ifndef MASTER_GCP_HPP
20 #define MASTER_GCP_HPP
21 
22 #include <NodeBitmask.hpp>
23 
31  friend class Dbdih;
32 
33 public:
34  STATIC_CONST( SignalLength = 10 + NdbNodeBitmask::Size );
35 
36  enum State {
37  GCP_READY = 0,
42 
46  GCP_COMMIT_RECEIVED = 2, // GCP_COMMIT received (and is running)
47 
53  };
54 
55  enum SaveState {
56  GCP_SAVE_IDLE = 0,
61 
66 
71  };
72 
73  struct Upgrade {
77  enum State {
78  GCP_READY = 0,
79  GCP_PREPARE_RECEIVED = 1,
80  GCP_COMMIT_RECEIVED = 2,
81  GCP_TC_FINISHED = 3
82  };
83  };
84 
85 private:
89  Uint32 gcpState;
90  Uint32 senderNodeId;
91  Uint32 failedNodeId;
92  Uint32 newGCP_hi;
93  Uint32 latestLCP;
94  Uint32 oldestRestorableGCI;
95  Uint32 keepGCI;
96  Uint32 lcpActive[NdbNodeBitmask::Size];
97  Uint32 newGCP_lo;
98  Uint32 saveState;
99  Uint32 saveGCI;
100 };
101 
109  friend class Dbdih;
110 
111 public:
112  STATIC_CONST( SignalLength = 2 );
113 private:
114  Uint32 masterRef;
115  Uint32 failedNodeId;
116 };
117 
125  friend class Dbdih;
126 
127 public:
128  STATIC_CONST( SignalLength = 2 );
129 private:
130  Uint32 senderNodeId;
131  Uint32 failedNodeId;
132 };
133 #endif