forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[PATCH] kdump: Routines for copying dump pages
This patch provides the interfaces necessary to read the dump contents, treating it as a high memory device. Signed off by Hariprasad Nellitheertha <[email protected]> Signed-off-by: Eric Biederman <[email protected]> Signed-off-by: Vivek Goyal <[email protected]> Signed-off-by: Andrew Morton <[email protected]> Signed-off-by: Linus Torvalds <[email protected]>
- Loading branch information
Vivek Goyal
authored and
Linus Torvalds
committed
Jun 25, 2005
1 parent
5f01645
commit 60e64d4
Showing
6 changed files
with
83 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
#ifndef LINUX_CRASH_DUMP_H | ||
#define LINUX_CRASH_DUMP_H | ||
|
||
#ifdef CONFIG_CRASH_DUMP | ||
#include <linux/kexec.h> | ||
#include <linux/smp_lock.h> | ||
#include <linux/device.h> | ||
#include <linux/proc_fs.h> | ||
|
||
extern ssize_t copy_oldmem_page(unsigned long, char *, size_t, | ||
unsigned long, int); | ||
#endif /* CONFIG_CRASH_DUMP */ | ||
#endif /* LINUX_CRASHDUMP_H */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
/* | ||
* kernel/crash_dump.c - Memory preserving reboot related code. | ||
* | ||
* Created by: Hariprasad Nellitheertha ([email protected]) | ||
* Copyright (C) IBM Corporation, 2004. All rights reserved | ||
*/ | ||
|
||
#include <linux/smp_lock.h> | ||
#include <linux/errno.h> | ||
#include <linux/proc_fs.h> | ||
#include <linux/bootmem.h> | ||
#include <linux/highmem.h> | ||
#include <linux/crash_dump.h> | ||
|
||
#include <asm/io.h> | ||
#include <asm/uaccess.h> | ||
|
||
/* | ||
* Copy a page from "oldmem". For this page, there is no pte mapped | ||
* in the current kernel. We stitch up a pte, similar to kmap_atomic. | ||
*/ | ||
ssize_t copy_oldmem_page(unsigned long pfn, char *buf, | ||
size_t csize, unsigned long offset, int userbuf) | ||
{ | ||
void *page, *vaddr; | ||
|
||
if (!csize) | ||
return 0; | ||
|
||
page = kmalloc(PAGE_SIZE, GFP_KERNEL); | ||
if (!page) | ||
return -ENOMEM; | ||
|
||
vaddr = kmap_atomic_pfn(pfn, KM_PTE0); | ||
copy_page(page, vaddr); | ||
kunmap_atomic(vaddr, KM_PTE0); | ||
|
||
if (userbuf) { | ||
if (copy_to_user(buf, (page + offset), csize)) { | ||
kfree(page); | ||
return -EFAULT; | ||
} | ||
} else { | ||
memcpy(buf, (page + offset), csize); | ||
} | ||
|
||
kfree(page); | ||
return csize; | ||
} |