The patch titled fix double unlock_page() in 2.6.26-rc5-mm3 kernel BUG at mm/filemap.c:575! has been removed from the -mm tree. Its filename was fix-double-unlock_page-in-2626-rc5-mm3-kernel-bug-at-mm-filemapc-575.patch This patch was dropped because it was folded into mmap-handle-mlocked-pages-during-map-remap-unmap.patch The current -mm tree may be found at http://userweb.kernel.org/~akpm/mmotm/ ------------------------------------------------------ Subject: fix double unlock_page() in 2.6.26-rc5-mm3 kernel BUG at mm/filemap.c:575! From: KAMEZAWA Hiroyuki <kamezawa.hiroyu@xxxxxxxxxxxxxx> This is reproducer of panic. "quick fix" is attached. But I think putback_lru_page() should be re-designed. == #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <sys/mman.h> #include <unistd.h> #include <errno.h> int main(int argc, char *argv[]) { int fd; char *filename = argv[1]; char buffer[4096]; char *addr; int len; fd = open(filename, O_CREAT | O_EXCL | O_RDWR, S_IRWXU); if (fd < 0) { perror("open"); exit(1); } len = write(fd, buffer, sizeof(buffer)); if (len < 0) { perror("write"); exit(1); } addr = mmap(NULL, 4096, PROT_WRITE, MAP_SHARED|MAP_LOCKED, fd, 0); if (addr == MAP_FAILED) { perror("mmap"); exit(1); } munmap(addr, 4096); close(fd); unlink(filename); } == you'll see panic. Fix is here == quick fix for double unlock_page(); Signed-off-by: KAMEZAWA Hiroyuki <kamewzawa.hiroyu@xxxxxxxxxxxxxx> Cc: Nick Piggin <npiggin@xxxxxxx> Cc: Lee Schermerhorn <lee.schermerhorn@xxxxxx> Cc: Rik van Riel <riel@xxxxxxxxxx> Cc: KOSAKI Motohiro <kosaki.motohiro@xxxxxxxxxxxxxx> Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx> --- mm/truncate.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff -puN mm/truncate.c~fix-double-unlock_page-in-2626-rc5-mm3-kernel-bug-at-mm-filemapc-575 mm/truncate.c --- a/mm/truncate.c~fix-double-unlock_page-in-2626-rc5-mm3-kernel-bug-at-mm-filemapc-575 +++ a/mm/truncate.c @@ -104,8 +104,8 @@ truncate_complete_page(struct address_sp cancel_dirty_page(page, PAGE_CACHE_SIZE); - remove_from_page_cache(page); clear_page_mlock(page); + remove_from_page_cache(page); ClearPageUptodate(page); ClearPageMappedToDisk(page); page_cache_release(page); /* pagecache ref */ _ Patches currently in -mm which might be from kamezawa.hiroyu@xxxxxxxxxxxxxx are origin.patch cgroup-fix-possible-memory-leak.patch cgroup-remove-duplicate-code-in-allocate_cg_link.patch cgroup-uninline-cgroup_has_css_refs.patch memcg-remove-redundant-check-in-move_task.patch cpuset-a-bit-cleanup-for-scan_for_empty_cpusets.patch cpuset-speed-up-sched-domain-partition.patch cpuset-fix-wrong-calculation-of-relax-domain-level.patch cpuset-clean-up-cpuset-hierarchy-traversal-code.patch vmscan-second-chance-replacement-for-anonymous-pages.patch mmap-handle-mlocked-pages-during-map-remap-unmap.patch fix-double-unlock_page-in-2626-rc5-mm3-kernel-bug-at-mm-filemapc-575.patch restore-patch-failure-of-vmstat-unevictable-and-mlocked-pages-vm-eventspatch.patch memrlimit-add-memrlimit-controller-documentation.patch memrlimit-setup-the-memrlimit-controller.patch memrlimit-cgroup-mm-owner-callback-changes-to-add-task-info.patch memrlimit-add-memrlimit-controller-accounting-and-control.patch memrlimit-improve-error-handling.patch memrlimit-improve-error-handling-update.patch memrlimit-handle-attach_task-failure-add-can_attach-callback.patch -- To unsubscribe from this list: send the line "unsubscribe mm-commits" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html