1. 01 10月, 2006 1 次提交
  2. 11 7月, 2006 1 次提交
    • D
      [PATCH] NOMMU: Fix execution off of ramfs with mmap() · 21ff8216
      David Howells 提交于
      Fix execution through the FDPIC binfmt of programs stored on ramfs by
      preventing the ramfs mmap() returning successfully on a private mapping of
      a ramfs file.  This causes NOMMU mmap to make a copy of the mapped portion
      of the file and map that instead.
      
      This could be improved by granting direct mapping access to read-only
      private mappings for which the data is stored on a contiguous run of pages.
       However, this is only likely to be the case if the file was extended with
      truncate before being written.
      
      ramfs is left to map the file directly for shared mappings so that SYSV IPC
      and POSIX shared memory both still work.
      Signed-off-by: NDavid Howells <dhowells@redhat.com>
      Cc: Hugh Dickins <hugh@veritas.com>
      Signed-off-by: NAndrew Morton <akpm@osdl.org>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      21ff8216
  3. 29 6月, 2006 1 次提交
  4. 29 3月, 2006 1 次提交
  5. 22 3月, 2006 1 次提交
  6. 07 1月, 2006 1 次提交
    • D
      [PATCH] NOMMU: Provide shared-writable mmap support on ramfs · 642fb4d1
      David Howells 提交于
      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: NDavid Howells <dhowells@redhat.com>
      Signed-off-by: NAndrew Morton <akpm@osdl.org>
      Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
      642fb4d1