mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-31 20:42:39 +00:00 
			
		
		
		
	 579aa9caf5
			
		
	
	
		579aa9caf5
		
	
	
	
	
		
			
			The writer field is not needed for non_DEBU builds so remove it. While we're at i also clean up the interface for is locked asserts to go through and xfs_iget.c helper with an interface like the xfs_ilock routines to isolated the XFS codebase from mrlock internals. That way we can kill mrlock_t entirely once rw_semaphores grow an islocked facility. Also remove unused flags to the ilock family of functions. SGI-PV: 976035 SGI-Modid: xfs-linux-melb:xfs-kern:30902a Signed-off-by: Christoph Hellwig <hch@infradead.org> Signed-off-by: Lachlan McIlroy <lachlan@sgi.com>
		
			
				
	
	
		
			91 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2000-2006 Silicon Graphics, Inc.
 | |
|  * All Rights Reserved.
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU General Public License as
 | |
|  * published by the Free Software Foundation.
 | |
|  *
 | |
|  * This program is distributed in the hope that it would be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write the Free Software Foundation,
 | |
|  * Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 | |
|  */
 | |
| #ifndef __XFS_SUPPORT_MRLOCK_H__
 | |
| #define __XFS_SUPPORT_MRLOCK_H__
 | |
| 
 | |
| #include <linux/rwsem.h>
 | |
| 
 | |
| typedef struct {
 | |
| 	struct rw_semaphore	mr_lock;
 | |
| #ifdef DEBUG
 | |
| 	int			mr_writer;
 | |
| #endif
 | |
| } mrlock_t;
 | |
| 
 | |
| #ifdef DEBUG
 | |
| #define mrinit(mrp, name)	\
 | |
| 	do { (mrp)->mr_writer = 0; init_rwsem(&(mrp)->mr_lock); } while (0)
 | |
| #else
 | |
| #define mrinit(mrp, name)	\
 | |
| 	do { init_rwsem(&(mrp)->mr_lock); } while (0)
 | |
| #endif
 | |
| 
 | |
| #define mrlock_init(mrp, t,n,s)	mrinit(mrp, n)
 | |
| #define mrfree(mrp)		do { } while (0)
 | |
| 
 | |
| static inline void mraccess_nested(mrlock_t *mrp, int subclass)
 | |
| {
 | |
| 	down_read_nested(&mrp->mr_lock, subclass);
 | |
| }
 | |
| 
 | |
| static inline void mrupdate_nested(mrlock_t *mrp, int subclass)
 | |
| {
 | |
| 	down_write_nested(&mrp->mr_lock, subclass);
 | |
| #ifdef DEBUG
 | |
| 	mrp->mr_writer = 1;
 | |
| #endif
 | |
| }
 | |
| 
 | |
| static inline int mrtryaccess(mrlock_t *mrp)
 | |
| {
 | |
| 	return down_read_trylock(&mrp->mr_lock);
 | |
| }
 | |
| 
 | |
| static inline int mrtryupdate(mrlock_t *mrp)
 | |
| {
 | |
| 	if (!down_write_trylock(&mrp->mr_lock))
 | |
| 		return 0;
 | |
| #ifdef DEBUG
 | |
| 	mrp->mr_writer = 1;
 | |
| #endif
 | |
| 	return 1;
 | |
| }
 | |
| 
 | |
| static inline void mrunlock_excl(mrlock_t *mrp)
 | |
| {
 | |
| #ifdef DEBUG
 | |
| 	mrp->mr_writer = 0;
 | |
| #endif
 | |
| 	up_write(&mrp->mr_lock);
 | |
| }
 | |
| 
 | |
| static inline void mrunlock_shared(mrlock_t *mrp)
 | |
| {
 | |
| 	up_read(&mrp->mr_lock);
 | |
| }
 | |
| 
 | |
| static inline void mrdemote(mrlock_t *mrp)
 | |
| {
 | |
| #ifdef DEBUG
 | |
| 	mrp->mr_writer = 0;
 | |
| #endif
 | |
| 	downgrade_write(&mrp->mr_lock);
 | |
| }
 | |
| 
 | |
| #endif /* __XFS_SUPPORT_MRLOCK_H__ */
 |