~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/thr_lock.h

  • Committer: Monty Taylor
  • Date: 2011-02-13 17:26:39 UTC
  • mfrom: (2157.2.2 give-in-to-pkg-config)
  • mto: This revision was merged to the branch mainline in revision 2166.
  • Revision ID: mordred@inaugust.com-20110213172639-nhy7i72sfhoq13ms
Merged in pkg-config fixes.

Show diffs side-by-side

added added

removed removed

Lines of Context:
11
11
 
12
12
   You should have received a copy of the GNU General Public License
13
13
   along with this program; if not, write to the Free Software
14
 
   Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
 
14
   Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA */
15
15
 
16
16
/* For use with thr_locks */
17
17
 
18
18
#ifndef DRIZZLED_THR_LOCK_H
19
19
#define DRIZZLED_THR_LOCK_H
20
20
 
21
 
#include <pthread.h>
 
21
#include <boost/thread/mutex.hpp>
 
22
#include <boost/thread/shared_mutex.hpp>
 
23
#include <boost/thread/condition_variable.hpp>
 
24
 
 
25
#include "drizzled/visibility.h"
22
26
 
23
27
namespace drizzled
24
28
{
25
29
 
26
 
struct st_thr_lock;
27
 
extern uint32_t locks_immediate,locks_waited ;
28
 
 
29
 
namespace internal
30
 
{
31
 
extern pthread_mutex_t THR_LOCK_lock;
32
 
}
33
 
 
34
30
extern uint64_t max_write_lock_count;
35
31
extern uint64_t table_lock_wait_timeout;
36
 
extern bool thr_lock_inited;
37
32
 
38
33
 
39
34
enum thr_lock_type { TL_IGNORE=-1,
78
73
  of an instance of this structure is used to uniquely identify the thread.
79
74
*/
80
75
 
81
 
typedef struct st_thr_lock_info
 
76
struct THR_LOCK_INFO
82
77
{
83
 
  pthread_t thread;
84
78
  uint64_t thread_id;
85
79
  uint32_t n_cursors;
86
 
} THR_LOCK_INFO;
 
80
 
 
81
  THR_LOCK_INFO() : 
 
82
    thread_id(0),
 
83
    n_cursors(0)
 
84
  { }
 
85
 
 
86
  void init();
 
87
 
 
88
};
87
89
 
88
90
/*
89
91
  Lock owner identifier. Globally identifies the lock owner within the
91
93
  structure is used as id.
92
94
*/
93
95
 
94
 
typedef struct st_thr_lock_owner
 
96
struct THR_LOCK_OWNER
95
97
{
96
98
  THR_LOCK_INFO *info;
97
 
} THR_LOCK_OWNER;
98
 
 
99
 
 
100
 
typedef struct st_thr_lock_data {
 
99
 
 
100
  THR_LOCK_OWNER() :
 
101
    info(0)
 
102
  { }
 
103
 
 
104
};
 
105
 
 
106
struct THR_LOCK;
 
107
struct THR_LOCK_DATA;
 
108
 
 
109
struct DRIZZLED_API THR_LOCK_DATA {
101
110
  THR_LOCK_OWNER *owner;
102
 
  struct st_thr_lock_data *next,**prev;
103
 
  struct st_thr_lock *lock;
104
 
  pthread_cond_t *cond;
 
111
  struct THR_LOCK_DATA *next,**prev;
 
112
  struct THR_LOCK *lock;
 
113
  boost::condition_variable_any *cond;
105
114
  enum thr_lock_type type;
106
115
  void *status_param;                   /* Param to status functions */
107
 
} THR_LOCK_DATA;
 
116
 
 
117
  THR_LOCK_DATA() :
 
118
    owner(0),
 
119
    next(0),
 
120
    prev(0),
 
121
    lock(0),
 
122
    cond(0),
 
123
    type(TL_UNLOCK),
 
124
    status_param(0)
 
125
  { }
 
126
 
 
127
  void init(THR_LOCK *lock,
 
128
            void *status_param= NULL);
 
129
};
108
130
 
109
131
struct st_lock_list {
110
132
  THR_LOCK_DATA *data,**last;
 
133
 
 
134
  st_lock_list() :
 
135
    data(0),
 
136
    last(0)
 
137
  { }
111
138
};
112
139
 
113
 
typedef struct st_thr_lock {
114
 
  pthread_mutex_t mutex;
 
140
struct THR_LOCK {
 
141
private:
 
142
  boost::mutex mutex;
 
143
public:
115
144
  struct st_lock_list read_wait;
116
145
  struct st_lock_list read;
117
146
  struct st_lock_list write_wait;
119
148
  /* write_lock_count is incremented for write locks and reset on read locks */
120
149
  uint32_t write_lock_count;
121
150
  uint32_t read_no_write_count;
122
 
  void (*get_status)(void*, int);       /* When one gets a lock */
123
 
  void (*copy_status)(void*,void*);
124
 
  void (*update_status)(void*);         /* Before release of write */
125
 
  void (*restore_status)(void*);         /* Before release of read */
126
 
  bool (*check_status)(void *);
127
 
} THR_LOCK;
128
 
 
129
 
 
130
 
bool init_thr_lock(void);               /* Must be called once/thread */
 
151
 
 
152
  THR_LOCK() :
 
153
    write_lock_count(0),
 
154
    read_no_write_count(0)
 
155
  { }
 
156
 
 
157
  ~THR_LOCK()
 
158
  { }
 
159
 
 
160
  void abort_locks();
 
161
  bool abort_locks_for_thread(uint64_t thread);
 
162
 
 
163
  void lock()
 
164
  {
 
165
    mutex.lock();
 
166
  }
 
167
 
 
168
  void unlock()
 
169
  {
 
170
    mutex.unlock();
 
171
  }
 
172
 
 
173
  void init()
 
174
  {
 
175
  }
 
176
 
 
177
  void deinit()
 
178
  {
 
179
  }
 
180
 
 
181
  boost::mutex *native_handle()
 
182
  {
 
183
    return &mutex;
 
184
  }
 
185
};
 
186
 
 
187
class Session; 
 
188
 
131
189
#define thr_lock_owner_init(owner, info_arg) (owner)->info= (info_arg)
132
 
void thr_lock_info_init(THR_LOCK_INFO *info);
133
 
void thr_lock_init(THR_LOCK *lock);
134
 
void thr_lock_delete(THR_LOCK *lock);
135
 
void thr_lock_data_init(THR_LOCK *lock,THR_LOCK_DATA *data,
136
 
                        void *status_param);
137
 
enum enum_thr_lock_result thr_multi_lock(THR_LOCK_DATA **data,
 
190
DRIZZLED_API void thr_lock_init(THR_LOCK *lock);
 
191
enum enum_thr_lock_result thr_multi_lock(Session &session, THR_LOCK_DATA **data,
138
192
                                         uint32_t count, THR_LOCK_OWNER *owner);
139
193
void thr_multi_unlock(THR_LOCK_DATA **data,uint32_t count);
140
 
void thr_abort_locks(THR_LOCK *lock);
141
 
bool thr_abort_locks_for_thread(THR_LOCK *lock, uint64_t thread);
142
194
 
143
195
} /* namespace drizzled */
144
196