set_memory.h 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright 2017, Michael Ellerman, IBM Corporation.
  4. */
  5. #ifndef _LINUX_SET_MEMORY_H_
  6. #define _LINUX_SET_MEMORY_H_
  7. #ifdef CONFIG_ARCH_HAS_SET_MEMORY
  8. #include <asm/set_memory.h>
  9. #else
  10. static inline int set_memory_ro(unsigned long addr, int numpages) { return 0; }
  11. static inline int set_memory_rw(unsigned long addr, int numpages) { return 0; }
  12. static inline int set_memory_x(unsigned long addr, int numpages) { return 0; }
  13. static inline int set_memory_nx(unsigned long addr, int numpages) { return 0; }
  14. #endif
  15. #ifndef CONFIG_ARCH_HAS_SET_DIRECT_MAP
  16. static inline int set_direct_map_invalid_noflush(struct page *page)
  17. {
  18. return 0;
  19. }
  20. static inline int set_direct_map_default_noflush(struct page *page)
  21. {
  22. return 0;
  23. }
  24. static inline bool kernel_page_present(struct page *page)
  25. {
  26. return true;
  27. }
  28. #else /* CONFIG_ARCH_HAS_SET_DIRECT_MAP */
  29. /*
  30. * Some architectures, e.g. ARM64 can disable direct map modifications at
  31. * boot time. Let them overrive this query.
  32. */
  33. #ifndef can_set_direct_map
  34. static inline bool can_set_direct_map(void)
  35. {
  36. return true;
  37. }
  38. #define can_set_direct_map can_set_direct_map
  39. #endif
  40. #endif /* CONFIG_ARCH_HAS_SET_DIRECT_MAP */
  41. #ifdef CONFIG_X86_64
  42. int set_mce_nospec(unsigned long pfn);
  43. int clear_mce_nospec(unsigned long pfn);
  44. #else
  45. static inline int set_mce_nospec(unsigned long pfn)
  46. {
  47. return 0;
  48. }
  49. static inline int clear_mce_nospec(unsigned long pfn)
  50. {
  51. return 0;
  52. }
  53. #endif
  54. int set_direct_map_range_uncached(unsigned long addr, unsigned long numpages);
  55. #ifndef CONFIG_ARCH_HAS_MEM_ENCRYPT
  56. static inline int set_memory_encrypted(unsigned long addr, int numpages)
  57. {
  58. return 0;
  59. }
  60. static inline int set_memory_decrypted(unsigned long addr, int numpages)
  61. {
  62. return 0;
  63. }
  64. #endif /* CONFIG_ARCH_HAS_MEM_ENCRYPT */
  65. #endif /* _LINUX_SET_MEMORY_H_ */