| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #ifndef _LINUX_RAMFS_H
 | 
					
						
							|  |  |  | #define _LINUX_RAMFS_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-04 17:32:18 +03:00
										 |  |  | struct inode *ramfs_get_inode(struct super_block *sb, const struct inode *dir, | 
					
						
							| 
									
										
										
										
											2011-07-26 03:16:55 -04:00
										 |  |  | 	 umode_t mode, dev_t dev); | 
					
						
							| 
									
										
										
										
											2010-07-25 11:46:36 +04:00
										 |  |  | extern struct dentry *ramfs_mount(struct file_system_type *fs_type, | 
					
						
							|  |  |  | 	 int flags, const char *dev_name, void *data); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-29 15:06:12 -07:00
										 |  |  | #ifdef CONFIG_MMU
 | 
					
						
							|  |  |  | static inline int | 
					
						
							|  |  |  | ramfs_nommu_expand_for_mapping(struct inode *inode, size_t newsize) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2008-10-02 14:50:16 -07:00
										 |  |  | extern int ramfs_nommu_expand_for_mapping(struct inode *inode, size_t newsize); | 
					
						
							| 
									
										
											  
											
												[PATCH] NOMMU: Provide shared-writable mmap support on ramfs
The attached patch makes ramfs support shared-writable mmaps by:
 (1) Attempting to perform a contiguous block allocation to the requested size
     when truncate attempts to increase the file from zero size, such as
     happens when:
	fd = shm_open("/file/on/ramfs", ...):
	ftruncate(fd, size_requested);
	addr = mmap(NULL, subsize, PROT_READ|PROT_WRITE|PROT_EXEC, MAP_SHARED,
		    fd, offset);
 (2) Permitting any shared-writable mapping over any contiguous set of extant
     pages. get_unmapped_area() will return the address into the actual ramfs
     pages. The mapping may start anywhere and be of any size, but may not go
     over the end of file. Multiple mappings may overlap in any way.
 (3) Not permitting a file to be shrunk if it would truncate any shared
     mappings (private mappings are copied).
Thus this patch provides support for POSIX shared memory on NOMMU kernels,
with certain limitations such as there being a large enough block of pages
available to support the allocation and it only working on directly mappable
filesystems.
Signed-off-by: David Howells <dhowells@redhat.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
											
										 
											2006-01-06 00:11:41 -08:00
										 |  |  | extern unsigned long ramfs_nommu_get_unmapped_area(struct file *file, | 
					
						
							|  |  |  | 						   unsigned long addr, | 
					
						
							|  |  |  | 						   unsigned long len, | 
					
						
							|  |  |  | 						   unsigned long pgoff, | 
					
						
							|  |  |  | 						   unsigned long flags); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern int ramfs_nommu_mmap(struct file *file, struct vm_area_struct *vma); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-03-28 01:56:42 -08:00
										 |  |  | extern const struct file_operations ramfs_file_operations; | 
					
						
							| 
									
										
										
										
											2009-09-27 22:29:37 +04:00
										 |  |  | extern const struct vm_operations_struct generic_file_vm_ops; | 
					
						
							| 
									
										
										
										
											2006-09-30 20:52:18 +02:00
										 |  |  | extern int __init init_rootfs(void); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-16 21:55:21 +01:00
										 |  |  | int ramfs_fill_super(struct super_block *sb, void *data, int silent); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #endif
 |