Contributors: 14
Author |
Tokens |
Token Proportion |
Commits |
Commit Proportion |
Vivek Goyal |
91 |
34.47% |
4 |
20.00% |
Lianbo Jiang |
71 |
26.89% |
1 |
5.00% |
Matthew Wilcox |
61 |
23.11% |
2 |
10.00% |
Michael Holzheu |
8 |
3.03% |
1 |
5.00% |
Tom Lendacky |
7 |
2.65% |
2 |
10.00% |
Thiago Jung Bauermann |
7 |
2.65% |
1 |
5.00% |
Akinobu Mita |
7 |
2.65% |
1 |
5.00% |
Linus Torvalds (pre-git) |
5 |
1.89% |
2 |
10.00% |
Michael Ellerman |
2 |
0.76% |
1 |
5.00% |
Cliff Wickman |
1 |
0.38% |
1 |
5.00% |
Al Viro |
1 |
0.38% |
1 |
5.00% |
Greg Kroah-Hartman |
1 |
0.38% |
1 |
5.00% |
Gustavo Padovan |
1 |
0.38% |
1 |
5.00% |
Dave Jones |
1 |
0.38% |
1 |
5.00% |
Total |
264 |
|
20 |
|
// SPDX-License-Identifier: GPL-2.0
/*
* 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/uio.h>
#include <linux/io.h>
#include <linux/cc_platform.h>
static ssize_t __copy_oldmem_page(struct iov_iter *iter, unsigned long pfn,
size_t csize, unsigned long offset,
bool encrypted)
{
void *vaddr;
if (!csize)
return 0;
if (encrypted)
vaddr = (__force void *)ioremap_encrypted(pfn << PAGE_SHIFT, PAGE_SIZE);
else
vaddr = (__force void *)ioremap_cache(pfn << PAGE_SHIFT, PAGE_SIZE);
if (!vaddr)
return -ENOMEM;
csize = copy_to_iter(vaddr + offset, csize, iter);
iounmap((void __iomem *)vaddr);
return csize;
}
ssize_t copy_oldmem_page(struct iov_iter *iter, unsigned long pfn, size_t csize,
unsigned long offset)
{
return __copy_oldmem_page(iter, pfn, csize, offset, false);
}
/*
* copy_oldmem_page_encrypted - same as copy_oldmem_page() above but ioremap the
* memory with the encryption mask set to accommodate kdump on SME-enabled
* machines.
*/
ssize_t copy_oldmem_page_encrypted(struct iov_iter *iter, unsigned long pfn,
size_t csize, unsigned long offset)
{
return __copy_oldmem_page(iter, pfn, csize, offset, true);
}
ssize_t elfcorehdr_read(char *buf, size_t count, u64 *ppos)
{
struct kvec kvec = { .iov_base = buf, .iov_len = count };
struct iov_iter iter;
iov_iter_kvec(&iter, ITER_DEST, &kvec, 1, count);
return read_from_oldmem(&iter, count, ppos,
cc_platform_has(CC_ATTR_GUEST_MEM_ENCRYPT));
}