|  | /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
|  | /* | 
|  | *   Copyright (C) International Business Machines Corp., 2000-2001 | 
|  | *   Portions Copyright (C) Christoph Hellwig, 2001-2002 | 
|  | */ | 
|  | #ifndef _H_JFS_LOCK | 
|  | #define _H_JFS_LOCK | 
|  |  | 
|  | #include <linux/spinlock.h> | 
|  | #include <linux/mutex.h> | 
|  | #include <linux/sched.h> | 
|  |  | 
|  | /* | 
|  | *	jfs_lock.h | 
|  | */ | 
|  |  | 
|  | /* | 
|  | * Conditional sleep where condition is protected by spinlock | 
|  | * | 
|  | * lock_cmd and unlock_cmd take and release the spinlock | 
|  | */ | 
|  | #define __SLEEP_COND(wq, cond, lock_cmd, unlock_cmd)	\ | 
|  | do {							\ | 
|  | DECLARE_WAITQUEUE(__wait, current);		\ | 
|  | \ | 
|  | add_wait_queue(&wq, &__wait);			\ | 
|  | for (;;) {					\ | 
|  | set_current_state(TASK_UNINTERRUPTIBLE);\ | 
|  | if (cond)				\ | 
|  | break;				\ | 
|  | unlock_cmd;				\ | 
|  | io_schedule();				\ | 
|  | lock_cmd;				\ | 
|  | }						\ | 
|  | __set_current_state(TASK_RUNNING);			\ | 
|  | remove_wait_queue(&wq, &__wait);		\ | 
|  | } while (0) | 
|  |  | 
|  | #endif				/* _H_JFS_LOCK */ |