2 * Copyright (C) Sistina Software, Inc. 1997-2003 All rights reserved.
3 * Copyright (C) 2004-2005 Red Hat, Inc. All rights reserved.
5 * This copyrighted material is made available to anyone wishing to use,
6 * modify, copy, or redistribute it subject to the terms and conditions
7 * of the GNU General Public License version 2.
10 #ifndef LOCK_DLM_DOT_H
11 #define LOCK_DLM_DOT_H
13 #include <linux/module.h>
14 #include <linux/slab.h>
15 #include <linux/spinlock.h>
16 #include <linux/module.h>
17 #include <linux/types.h>
18 #include <linux/string.h>
19 #include <linux/list.h>
20 #include <linux/socket.h>
21 #include <linux/delay.h>
22 #include <linux/kthread.h>
23 #include <linux/kobject.h>
24 #include <linux/fcntl.h>
25 #include <linux/wait.h>
28 #include <linux/dlm.h>
29 #include "../../lm_interface.h"
32 * Internally, we prefix things with gdlm_ and GDLM_ (for gfs-dlm) since a
33 * prefix of lock_dlm_ gets awkward. Externally, GFS refers to this module
37 #define GDLM_STRNAME_BYTES 24
38 #define GDLM_LVB_SIZE 32
39 #define GDLM_DROP_COUNT 50000
40 #define GDLM_DROP_PERIOD 60
41 #define GDLM_NAME_LEN 128
43 /* GFS uses 12 bytes to identify a resource (32 bit type + 64 bit number).
44 We sprintf these numbers into a 24 byte string of hex values to make them
45 human-readable (to make debugging simpler.) */
48 unsigned char name
[GDLM_STRNAME_BYTES
];
49 unsigned short namelen
;
65 char clustername
[GDLM_NAME_LEN
];
66 char fsname
[GDLM_NAME_LEN
];
68 dlm_lockspace_t
*dlm_lockspace
;
73 int recover_jid_status
;
74 spinlock_t async_lock
;
75 struct list_head complete
;
76 struct list_head blocking
;
77 struct list_head delayed
;
78 struct list_head submit
;
79 struct list_head all_locks
;
81 wait_queue_head_t wait_control
;
82 struct task_struct
*thread1
;
83 struct task_struct
*thread2
;
84 wait_queue_head_t thread_wait
;
85 unsigned long drop_time
;
87 int drop_locks_period
;
96 LFL_FORCE_PROMOTE
= 5,
103 LFL_UNLOCK_DELETE
= 12,
108 struct lm_lockname lockname
;
110 struct dlm_lksb lksb
;
115 u32 lkf
; /* dlm flags DLM_LKF_ */
116 unsigned long flags
; /* lock_dlm flags LFL_ */
118 int bast_mode
; /* protected by async_lock */
119 struct completion ast_wait
;
121 struct list_head clist
; /* complete */
122 struct list_head blist
; /* blocking */
123 struct list_head delay_list
; /* delayed */
124 struct list_head all_list
; /* all locks for the fs */
125 struct gdlm_lock
*hold_null
; /* NL lock for hold_lvb */
128 #define gdlm_assert(assertion, fmt, args...) \
130 if (unlikely(!(assertion))) { \
131 printk(KERN_EMERG "lock_dlm: fatal assertion failed \"%s\"\n" \
132 "lock_dlm: " fmt "\n", \
133 #assertion, ##args); \
138 #define log_print(lev, fmt, arg...) printk(lev "lock_dlm: " fmt "\n" , ## arg)
139 #define log_info(fmt, arg...) log_print(KERN_INFO , fmt , ## arg)
140 #define log_error(fmt, arg...) log_print(KERN_ERR , fmt , ## arg)
141 #ifdef LOCK_DLM_LOG_DEBUG
142 #define log_debug(fmt, arg...) log_print(KERN_DEBUG , fmt , ## arg)
144 #define log_debug(fmt, arg...)
149 int gdlm_sysfs_init(void);
150 void gdlm_sysfs_exit(void);
151 int gdlm_kobject_setup(struct gdlm_ls
*, struct kobject
*);
152 void gdlm_kobject_release(struct gdlm_ls
*);
156 int gdlm_init_threads(struct gdlm_ls
*);
157 void gdlm_release_threads(struct gdlm_ls
*);
161 s16
gdlm_make_lmstate(s16
);
162 void gdlm_queue_delayed(struct gdlm_lock
*);
163 void gdlm_submit_delayed(struct gdlm_ls
*);
164 int gdlm_release_all_locks(struct gdlm_ls
*);
165 void gdlm_delete_lp(struct gdlm_lock
*);
166 unsigned int gdlm_do_lock(struct gdlm_lock
*);
168 int gdlm_get_lock(lm_lockspace_t
*, struct lm_lockname
*, lm_lock_t
**);
169 void gdlm_put_lock(lm_lock_t
*);
170 unsigned int gdlm_lock(lm_lock_t
*, unsigned int, unsigned int, unsigned int);
171 unsigned int gdlm_unlock(lm_lock_t
*, unsigned int);
172 void gdlm_cancel(lm_lock_t
*);
173 int gdlm_hold_lvb(lm_lock_t
*, char **);
174 void gdlm_unhold_lvb(lm_lock_t
*, char *);
175 void gdlm_sync_lvb(lm_lock_t
*, char *);
179 int gdlm_plock_init(void);
180 void gdlm_plock_exit(void);
181 int gdlm_plock(lm_lockspace_t
*, struct lm_lockname
*, struct file
*, int,
183 int gdlm_plock_get(lm_lockspace_t
*, struct lm_lockname
*, struct file
*,
185 int gdlm_punlock(lm_lockspace_t
*, struct lm_lockname
*, struct file
*,