mirror of
https://github.com/torvalds/linux.git
synced 2024-11-22 20:22:09 +00:00
de4eda9de2
READ/WRITE proved to be actively confusing - the meanings are "data destination, as used with read(2)" and "data source, as used with write(2)", but people keep interpreting those as "we read data from it" and "we write data to it", i.e. exactly the wrong way. Call them ITER_DEST and ITER_SOURCE - at least that is harder to misinterpret... Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
65 lines
1.6 KiB
C
65 lines
1.6 KiB
C
// 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));
|
|
}
|