patch-2.3.10 linux/mm/filemap.c
Next file: linux/mm/memory.c
Previous file: linux/lib/string.c
Back to the patch index
Back to the overall index
- Lines: 106
- Date:
Tue Jul 6 10:11:40 1999
- Orig file:
v2.3.9/linux/mm/filemap.c
- Orig date:
Wed Jun 30 13:38:20 1999
diff -u --recursive --new-file v2.3.9/linux/mm/filemap.c linux/mm/filemap.c
@@ -1194,8 +1194,6 @@
struct file * in_file, * out_file;
struct inode * in_inode, * out_inode;
- lock_kernel();
-
/*
* Get input file, and verify that it is ok..
*/
@@ -1234,7 +1232,6 @@
if (retval)
goto fput_out;
- unlock_kernel();
retval = 0;
if (count) {
read_descriptor_t desc;
@@ -1244,7 +1241,7 @@
ppos = &in_file->f_pos;
if (offset) {
if (get_user(pos, offset))
- goto fput_out_lock;
+ goto fput_out;
ppos = &pos;
}
@@ -1261,14 +1258,11 @@
put_user(pos, offset);
}
-fput_out_lock:
- lock_kernel();
fput_out:
fput(out_file);
fput_in:
fput(in_file);
out:
- unlock_kernel();
return retval;
}
@@ -1297,9 +1291,7 @@
new_page = 0;
offset = (address & PAGE_MASK) - area->vm_start + area->vm_offset;
if (offset >= inode->i_size && (area->vm_flags & VM_SHARED) && area->vm_mm == current->mm)
- goto no_page_nolock;
-
- unlock_kernel();
+ goto no_page;
/*
* Do we have something in the page cache already?
@@ -1344,7 +1336,6 @@
page_cache_free(new_page);
flush_page_to_ram(old_page);
- lock_kernel();
return old_page;
}
@@ -1354,7 +1345,6 @@
copy_page(new_page, old_page);
flush_page_to_ram(new_page);
page_cache_release(page);
- lock_kernel();
return new_page;
no_cached_page:
@@ -1431,8 +1421,6 @@
if (new_page)
page_cache_free(new_page);
no_page:
- lock_kernel();
-no_page_nolock:
return 0;
}
@@ -1487,7 +1475,7 @@
* If a task terminates while we're swapping the page, the vma and
* and file could be released ... increment the count to be safe.
*/
- atomic_inc(&file->f_count);
+ get_file(file);
result = do_write_page(inode, file, (const char *) page, offset);
fput(file);
return result;
@@ -1648,8 +1636,7 @@
NULL, /* advise */
filemap_nopage, /* nopage */
NULL, /* wppage */
- filemap_swapout, /* swapout */
- NULL, /* swapin */
+ filemap_swapout /* swapout */
};
/*
@@ -1667,8 +1654,7 @@
NULL, /* advise */
filemap_nopage, /* nopage */
NULL, /* wppage */
- NULL, /* swapout */
- NULL, /* swapin */
+ NULL /* swapout */
};
/* This is used for a general mmap of a disk file */
FUNET's LINUX-ADM group, linux-adm@nic.funet.fi
TCL-scripts by Sam Shen (who was at: slshen@lbl.gov)