mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 08:08:13 +00:00 
			
		
		
		
	 d3fec424b2
			
		
	
	
		d3fec424b2
		
	
	
	
	
		
			
			This is an variation on the patch sent by Christoph Hellwig which kills file_count abuse by the Coda kernel module by moving the coda_flush functionality into coda_release. However part of reason we were using the coda_flush callback was to allow Coda to pass errors that occur during writeback from the userspace cache manager back to close(). As Al Viro explained on linux-fsdevel, it is impossible to guarantee that such errors can in fact be returned back to the caller. There are many cases where the last reference to a file is not released by the close system call and it is also impossible to pick some close as a 'last-close' and delay it until all other references have been destroyed. The CODA_STORE/CODA_RELEASE upcall combination is clearly a broken design, and it is better to remove it completely. Signed-off-by: Jan Harkes <jaharkes@cs.cmu.edu> Cc: Christoph Hellwig <hch@lst.de> Cc: Al Viro <viro@ftp.linux.org.uk> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
		
			
				
	
	
		
			93 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __CODA_PSDEV_H
 | |
| #define __CODA_PSDEV_H
 | |
| 
 | |
| #include <linux/magic.h>
 | |
| 
 | |
| #define CODA_PSDEV_MAJOR 67
 | |
| #define MAX_CODADEVS  5	   /* how many do we allow */
 | |
| 
 | |
| struct kstatfs;
 | |
| 
 | |
| /* communication pending/processing queues */
 | |
| struct venus_comm {
 | |
| 	u_long		    vc_seq;
 | |
| 	wait_queue_head_t   vc_waitq; /* Venus wait queue */
 | |
| 	struct list_head    vc_pending;
 | |
| 	struct list_head    vc_processing;
 | |
| 	int                 vc_inuse;
 | |
| 	struct super_block *vc_sb;
 | |
| };
 | |
| 
 | |
| 
 | |
| static inline struct venus_comm *coda_vcp(struct super_block *sb)
 | |
| {
 | |
| 	return (struct venus_comm *)((sb)->s_fs_info);
 | |
| }
 | |
| 
 | |
| 
 | |
| /* upcalls */
 | |
| int venus_rootfid(struct super_block *sb, struct CodaFid *fidp);
 | |
| int venus_getattr(struct super_block *sb, struct CodaFid *fid,
 | |
| 		  struct coda_vattr *attr);
 | |
| int venus_setattr(struct super_block *, struct CodaFid *, struct coda_vattr *);
 | |
| int venus_lookup(struct super_block *sb, struct CodaFid *fid, 
 | |
| 		 const char *name, int length, int *type, 
 | |
| 		 struct CodaFid *resfid);
 | |
| int venus_close(struct super_block *sb, struct CodaFid *fid, int flags,
 | |
| 		vuid_t uid);
 | |
| int venus_open(struct super_block *sb, struct CodaFid *fid, int flags,
 | |
| 	       struct file **f);
 | |
| int venus_mkdir(struct super_block *sb, struct CodaFid *dirfid, 
 | |
| 		const char *name, int length, 
 | |
| 		struct CodaFid *newfid, struct coda_vattr *attrs);
 | |
| int venus_create(struct super_block *sb, struct CodaFid *dirfid, 
 | |
| 		 const char *name, int length, int excl, int mode,
 | |
| 		 struct CodaFid *newfid, struct coda_vattr *attrs) ;
 | |
| int venus_rmdir(struct super_block *sb, struct CodaFid *dirfid, 
 | |
| 		const char *name, int length);
 | |
| int venus_remove(struct super_block *sb, struct CodaFid *dirfid, 
 | |
| 		 const char *name, int length);
 | |
| int venus_readlink(struct super_block *sb, struct CodaFid *fid, 
 | |
| 		   char *buffer, int *length);
 | |
| int venus_rename(struct super_block *, struct CodaFid *new_fid, 
 | |
| 		 struct CodaFid *old_fid, size_t old_length, 
 | |
| 		 size_t new_length, const char *old_name, 
 | |
| 		 const char *new_name);
 | |
| int venus_link(struct super_block *sb, struct CodaFid *fid, 
 | |
| 		  struct CodaFid *dirfid, const char *name, int len );
 | |
| int venus_symlink(struct super_block *sb, struct CodaFid *fid,
 | |
| 		  const char *name, int len, const char *symname, int symlen);
 | |
| int venus_access(struct super_block *sb, struct CodaFid *fid, int mask);
 | |
| int venus_pioctl(struct super_block *sb, struct CodaFid *fid,
 | |
| 		 unsigned int cmd, struct PioctlData *data);
 | |
| int coda_downcall(int opcode, union outputArgs *out, struct super_block *sb);
 | |
| int venus_fsync(struct super_block *sb, struct CodaFid *fid);
 | |
| int venus_statfs(struct dentry *dentry, struct kstatfs *sfs);
 | |
| 
 | |
| 
 | |
| /* messages between coda filesystem in kernel and Venus */
 | |
| struct upc_req {
 | |
| 	struct list_head    uc_chain;
 | |
| 	caddr_t	            uc_data;
 | |
| 	u_short	            uc_flags;
 | |
| 	u_short             uc_inSize;  /* Size is at most 5000 bytes */
 | |
| 	u_short	            uc_outSize;
 | |
| 	u_short	            uc_opcode;  /* copied from data to save lookup */
 | |
| 	int		    uc_unique;
 | |
| 	wait_queue_head_t   uc_sleep;   /* process' wait queue */
 | |
| };
 | |
| 
 | |
| #define REQ_ASYNC  0x1
 | |
| #define REQ_READ   0x2
 | |
| #define REQ_WRITE  0x4
 | |
| #define REQ_ABORT  0x8
 | |
| 
 | |
| 
 | |
| /*
 | |
|  * Statistics
 | |
|  */
 | |
| 
 | |
| extern struct venus_comm coda_comms[];
 | |
| 
 | |
| #endif
 |