 6c46a77d95
			
		
	
	
		6c46a77d95
		
	
	
	
	
		
			
			- The lmfs_get_block*(3) API calls may now return an error. The idea is to encourage a next generation of file system services to do a better job at dealing with block read errors than the MFS-derived implementations do. These existing file systems have been changed to panic immediately upon getting a block read error, in order to let unchecked errors cause corruption. Note that libbdev already retries failing I/O operations a few times first. - The libminixfs block device I/O module (bio.c) now deals properly with end-of-file conditions on block devices. Since a device or partition size may not be a multiple of the root file system's block size, support for partial block retrival has been added, with a new internal lmfs_get_partial_block(3) call. A new test program, test85, tests the new handling of EOF conditions when reading, writing, and memory-mapping a block device. Change-Id: I05e35b6b8851488328a2679da635ebba0c6d08ce
		
			
				
	
	
		
			112 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef EXT2_PROTO_H
 | |
| #define EXT2_PROTO_H
 | |
| 
 | |
| #define put_block(n) lmfs_put_block(n)
 | |
| 
 | |
| /* Function prototypes. */
 | |
| 
 | |
| /* Structs used in prototypes must be declared as such first. */
 | |
| struct buf;
 | |
| struct filp;
 | |
| struct inode;
 | |
| struct super_block;
 | |
| 
 | |
| /* balloc.c */
 | |
| void discard_preallocated_blocks(struct inode *rip);
 | |
| block_t alloc_block(struct inode *rip, block_t goal);
 | |
| void free_block(struct super_block *sp, bit_t bit);
 | |
| 
 | |
| /* ialloc.c */
 | |
| struct inode *alloc_inode(struct inode *parent, mode_t bits, uid_t uid,
 | |
| 	gid_t gid);
 | |
| void free_inode(struct inode *rip);
 | |
| 
 | |
| /* inode.c */
 | |
| void dup_inode(struct inode *ip);
 | |
| struct inode *find_inode(dev_t dev, ino_t numb);
 | |
| int fs_putnode(ino_t ino_nr, unsigned int count);
 | |
| void init_inode_cache(void);
 | |
| struct inode *get_inode(dev_t dev, ino_t numb);
 | |
| void put_inode(struct inode *rip);
 | |
| void update_times(struct inode *rip);
 | |
| void rw_inode(struct inode *rip, int rw_flag);
 | |
| 
 | |
| /* link.c */
 | |
| int fs_trunc(ino_t ino_nr, off_t start, off_t end);
 | |
| int fs_link(ino_t dir_nr, char *name, ino_t ino_nr);
 | |
| int fs_rdlink(ino_t ino_nr, struct fsdriver_data *data, size_t bytes);
 | |
| int fs_rename(ino_t old_dir_nr, char *old_name, ino_t new_dir_nr,
 | |
| 	char *new_name);
 | |
| int fs_unlink(ino_t dir_nr, char *name, int call);
 | |
| int truncate_inode(struct inode *rip, off_t len);
 | |
| 
 | |
| /* misc.c */
 | |
| void fs_sync(void);
 | |
| 
 | |
| /* mount.c */
 | |
| int fs_mount(dev_t dev, unsigned int flags, struct fsdriver_node *root_node,
 | |
| 	unsigned int *res_flags);
 | |
| void fs_unmount(void);
 | |
| int fs_mountpt(ino_t ino_nr);
 | |
| 
 | |
| /* open.c */
 | |
| int fs_create(ino_t dir_nr, char *name, mode_t mode, uid_t uid, gid_t gid,
 | |
| 	struct fsdriver_node *node);
 | |
| int fs_mkdir(ino_t dir_nr, char *name, mode_t mode, uid_t uid, gid_t gid);
 | |
| int fs_mknod(ino_t dir_nr, char *name, mode_t mode, uid_t uid, gid_t gid,
 | |
| 	dev_t dev);
 | |
| int fs_slink(ino_t dir_nr, char *name, uid_t uid, gid_t gid,
 | |
| 	struct fsdriver_data *data, size_t bytes);
 | |
| void fs_seek(ino_t ino_nr);
 | |
| 
 | |
| /* path.c */
 | |
| int fs_lookup(ino_t dir_nr, char *name, struct fsdriver_node *node,
 | |
| 	int *is_mountpt);
 | |
| struct inode *advance(struct inode *dirp, const char *string);
 | |
| int search_dir(struct inode *ldir_ptr, const char *string, ino_t *numb,
 | |
| 	int flag, int ftype);
 | |
| 
 | |
| /* protect.c */
 | |
| int fs_chmod(ino_t ino_nr, mode_t *mode);
 | |
| int fs_chown(ino_t ino_nr, uid_t uid, gid_t gid, mode_t *mode);
 | |
| 
 | |
| /* read.c */
 | |
| ssize_t fs_readwrite(ino_t ino_nr, struct fsdriver_data *data, size_t bytes,
 | |
| 	off_t pos, int call);
 | |
| block_t rd_indir(struct buf *bp, int index);
 | |
| block_t read_map(struct inode *rip, off_t pos, int opportunistic);
 | |
| struct buf *get_block_map(register struct inode *rip, u64_t position);
 | |
| ssize_t fs_getdents(ino_t ino_nr, struct fsdriver_data *data, size_t bytes,
 | |
| 	off_t *posp);
 | |
| 
 | |
| /* stadir.c */
 | |
| int fs_stat(ino_t ino_nr, struct stat *statbuf);
 | |
| int fs_statvfs(struct statvfs *st);
 | |
| 
 | |
| /* super.c */
 | |
| unsigned int get_block_size(dev_t dev);
 | |
| struct super_block *get_super(dev_t dev);
 | |
| int read_super(struct super_block *sp);
 | |
| void write_super(struct super_block *sp);
 | |
| struct group_desc* get_group_desc(unsigned int bnum);
 | |
| 
 | |
| /* time.c */
 | |
| int fs_utime(ino_t ino, struct timespec *atime, struct timespec *mtime);
 | |
| 
 | |
| /* utility.c */
 | |
| struct buf *get_block(dev_t dev, block_t block, int how);
 | |
| unsigned conv2(int norm, int w);
 | |
| long conv4(int norm, long x);
 | |
| int ansi_strcmp(register const char* ansi_s, register const char *s2,
 | |
| 	register size_t ansi_s_length);
 | |
| bit_t setbit(bitchunk_t *bitmap, bit_t max_bits, unsigned int word);
 | |
| bit_t setbyte(bitchunk_t *bitmap, bit_t max_bits);
 | |
| int unsetbit(bitchunk_t *bitmap, bit_t bit);
 | |
| 
 | |
| /* write.c */
 | |
| struct buf *new_block(struct inode *rip, off_t position);
 | |
| void zero_block(struct buf *bp);
 | |
| int write_map(struct inode *, off_t, block_t, int);
 | |
| 
 | |
| #endif /* EXT2_PROTO_H */
 |