mirror of https://gitee.com/openkylin/linux.git
orangefs: get rid of <censored> macros
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Mike Marshall <hubcap@omnibond.com>
This commit is contained in:
parent
90e54e36c9
commit
fc916da52d
|
@ -619,47 +619,6 @@ extern wait_queue_head_t orangefs_bufmap_init_waitq;
|
|||
/*
|
||||
* misc convenience macros
|
||||
*/
|
||||
#define add_op_to_request_list(op) \
|
||||
do { \
|
||||
spin_lock(&orangefs_request_list_lock); \
|
||||
spin_lock(&op->lock); \
|
||||
set_op_state_waiting(op); \
|
||||
list_add_tail(&op->list, &orangefs_request_list); \
|
||||
spin_unlock(&orangefs_request_list_lock); \
|
||||
spin_unlock(&op->lock); \
|
||||
wake_up_interruptible(&orangefs_request_list_waitq); \
|
||||
} while (0)
|
||||
|
||||
#define add_priority_op_to_request_list(op) \
|
||||
do { \
|
||||
spin_lock(&orangefs_request_list_lock); \
|
||||
spin_lock(&op->lock); \
|
||||
set_op_state_waiting(op); \
|
||||
\
|
||||
list_add(&op->list, &orangefs_request_list); \
|
||||
spin_unlock(&orangefs_request_list_lock); \
|
||||
spin_unlock(&op->lock); \
|
||||
wake_up_interruptible(&orangefs_request_list_waitq); \
|
||||
} while (0)
|
||||
|
||||
#define remove_op_from_request_list(op) \
|
||||
do { \
|
||||
struct list_head *tmp = NULL; \
|
||||
struct list_head *tmp_safe = NULL; \
|
||||
struct orangefs_kernel_op_s *tmp_op = NULL; \
|
||||
\
|
||||
spin_lock(&orangefs_request_list_lock); \
|
||||
list_for_each_safe(tmp, tmp_safe, &orangefs_request_list) { \
|
||||
tmp_op = list_entry(tmp, \
|
||||
struct orangefs_kernel_op_s, \
|
||||
list); \
|
||||
if (tmp_op && (tmp_op == op)) { \
|
||||
list_del(&tmp_op->list); \
|
||||
break; \
|
||||
} \
|
||||
} \
|
||||
spin_unlock(&orangefs_request_list_lock); \
|
||||
} while (0)
|
||||
|
||||
#define ORANGEFS_OP_INTERRUPTIBLE 1 /* service_operation() is interruptible */
|
||||
#define ORANGEFS_OP_PRIORITY 2 /* service_operation() is high priority */
|
||||
|
|
|
@ -41,6 +41,31 @@ void purge_waiting_ops(void)
|
|||
spin_unlock(&orangefs_request_list_lock);
|
||||
}
|
||||
|
||||
static inline void
|
||||
add_op_to_request_list(struct orangefs_kernel_op_s *op)
|
||||
{
|
||||
spin_lock(&orangefs_request_list_lock);
|
||||
spin_lock(&op->lock);
|
||||
set_op_state_waiting(op);
|
||||
list_add_tail(&op->list, &orangefs_request_list);
|
||||
spin_unlock(&orangefs_request_list_lock);
|
||||
spin_unlock(&op->lock);
|
||||
wake_up_interruptible(&orangefs_request_list_waitq);
|
||||
}
|
||||
|
||||
static inline
|
||||
void add_priority_op_to_request_list(struct orangefs_kernel_op_s *op)
|
||||
{
|
||||
spin_lock(&orangefs_request_list_lock);
|
||||
spin_lock(&op->lock);
|
||||
set_op_state_waiting(op);
|
||||
|
||||
list_add(&op->list, &orangefs_request_list);
|
||||
spin_unlock(&orangefs_request_list_lock);
|
||||
spin_unlock(&op->lock);
|
||||
wake_up_interruptible(&orangefs_request_list_waitq);
|
||||
}
|
||||
|
||||
/*
|
||||
* submits a ORANGEFS operation and waits for it to complete
|
||||
*
|
||||
|
@ -252,6 +277,25 @@ int service_operation(struct orangefs_kernel_op_s *op,
|
|||
return ret;
|
||||
}
|
||||
|
||||
static inline void remove_op_from_request_list(struct orangefs_kernel_op_s *op)
|
||||
{
|
||||
struct list_head *tmp = NULL;
|
||||
struct list_head *tmp_safe = NULL;
|
||||
struct orangefs_kernel_op_s *tmp_op = NULL;
|
||||
|
||||
spin_lock(&orangefs_request_list_lock);
|
||||
list_for_each_safe(tmp, tmp_safe, &orangefs_request_list) {
|
||||
tmp_op = list_entry(tmp,
|
||||
struct orangefs_kernel_op_s,
|
||||
list);
|
||||
if (tmp_op && (tmp_op == op)) {
|
||||
list_del(&tmp_op->list);
|
||||
break;
|
||||
}
|
||||
}
|
||||
spin_unlock(&orangefs_request_list_lock);
|
||||
}
|
||||
|
||||
void orangefs_clean_up_interrupted_operation(struct orangefs_kernel_op_s *op)
|
||||
{
|
||||
/*
|
||||
|
|
Loading…
Reference in New Issue