mem_encrypt.h 780 B

123456789101112131415161718192021222324252627282930313233343536
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * AMD Memory Encryption Support
  4. *
  5. * Copyright (C) 2016 Advanced Micro Devices, Inc.
  6. *
  7. * Author: Tom Lendacky <[email protected]>
  8. */
  9. #ifndef __MEM_ENCRYPT_H__
  10. #define __MEM_ENCRYPT_H__
  11. #ifndef __ASSEMBLY__
  12. #ifdef CONFIG_ARCH_HAS_MEM_ENCRYPT
  13. #include <asm/mem_encrypt.h>
  14. #endif /* CONFIG_ARCH_HAS_MEM_ENCRYPT */
  15. #ifdef CONFIG_AMD_MEM_ENCRYPT
  16. /*
  17. * The __sme_set() and __sme_clr() macros are useful for adding or removing
  18. * the encryption mask from a value (e.g. when dealing with pagetable
  19. * entries).
  20. */
  21. #define __sme_set(x) ((x) | sme_me_mask)
  22. #define __sme_clr(x) ((x) & ~sme_me_mask)
  23. #else
  24. #define __sme_set(x) (x)
  25. #define __sme_clr(x) (x)
  26. #endif
  27. #endif /* __ASSEMBLY__ */
  28. #endif /* __MEM_ENCRYPT_H__ */