-
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.
This adds support for kexec based crash dumps. Signed-off-by: Paul Mundt <lethal@linux-sh.org>
- Loading branch information
Paul Mundt
authored and
Paul Mundt
committed
May 7, 2007
1 parent
db62e5b
commit 4d5ade5
Showing
6 changed files
with
129 additions
and
9 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,46 @@ | ||
/* | ||
* crash_dump.c - Memory preserving reboot related code. | ||
* | ||
* Created by: Hariprasad Nellitheertha (hari@in.ibm.com) | ||
* Copyright (C) IBM Corporation, 2004. All rights reserved | ||
*/ | ||
|
||
#include <linux/errno.h> | ||
#include <linux/crash_dump.h> | ||
#include <linux/io.h> | ||
#include <asm/uaccess.h> | ||
|
||
/** | ||
* copy_oldmem_page - copy one page from "oldmem" | ||
* @pfn: page frame number to be copied | ||
* @buf: target memory address for the copy; this can be in kernel address | ||
* space or user address space (see @userbuf) | ||
* @csize: number of bytes to copy | ||
* @offset: offset in bytes into the page (based on pfn) to begin the copy | ||
* @userbuf: if set, @buf is in user address space, use copy_to_user(), | ||
* otherwise @buf is in kernel address space, use memcpy(). | ||
* | ||
* 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 *vaddr; | ||
|
||
if (!csize) | ||
return 0; | ||
|
||
vaddr = ioremap(pfn << PAGE_SHIFT, PAGE_SIZE); | ||
|
||
if (userbuf) { | ||
if (copy_to_user(buf, (vaddr + offset), csize)) { | ||
iounmap(vaddr); | ||
return -EFAULT; | ||
} | ||
} else | ||
memcpy(buf, (vaddr + offset), csize); | ||
|
||
iounmap(vaddr); | ||
return csize; | ||
} |
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