crash_dump_64.c 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Memory preserving reboot related code.
  4. *
  5. * Created by: Hariprasad Nellitheertha ([email protected])
  6. * Copyright (C) IBM Corporation, 2004. All rights reserved
  7. */
  8. #include <linux/errno.h>
  9. #include <linux/crash_dump.h>
  10. #include <linux/uio.h>
  11. #include <linux/io.h>
  12. #include <linux/cc_platform.h>
  13. static ssize_t __copy_oldmem_page(struct iov_iter *iter, unsigned long pfn,
  14. size_t csize, unsigned long offset,
  15. bool encrypted)
  16. {
  17. void *vaddr;
  18. if (!csize)
  19. return 0;
  20. if (encrypted)
  21. vaddr = (__force void *)ioremap_encrypted(pfn << PAGE_SHIFT, PAGE_SIZE);
  22. else
  23. vaddr = (__force void *)ioremap_cache(pfn << PAGE_SHIFT, PAGE_SIZE);
  24. if (!vaddr)
  25. return -ENOMEM;
  26. csize = copy_to_iter(vaddr + offset, csize, iter);
  27. iounmap((void __iomem *)vaddr);
  28. return csize;
  29. }
  30. ssize_t copy_oldmem_page(struct iov_iter *iter, unsigned long pfn, size_t csize,
  31. unsigned long offset)
  32. {
  33. return __copy_oldmem_page(iter, pfn, csize, offset, false);
  34. }
  35. /*
  36. * copy_oldmem_page_encrypted - same as copy_oldmem_page() above but ioremap the
  37. * memory with the encryption mask set to accommodate kdump on SME-enabled
  38. * machines.
  39. */
  40. ssize_t copy_oldmem_page_encrypted(struct iov_iter *iter, unsigned long pfn,
  41. size_t csize, unsigned long offset)
  42. {
  43. return __copy_oldmem_page(iter, pfn, csize, offset, true);
  44. }
  45. ssize_t elfcorehdr_read(char *buf, size_t count, u64 *ppos)
  46. {
  47. struct kvec kvec = { .iov_base = buf, .iov_len = count };
  48. struct iov_iter iter;
  49. iov_iter_kvec(&iter, ITER_DEST, &kvec, 1, count);
  50. return read_from_oldmem(&iter, count, ppos,
  51. cc_platform_has(CC_ATTR_GUEST_MEM_ENCRYPT));
  52. }