irqflags.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /*
  3. * Copyright (C) 2020-2022 Loongson Technology Corporation Limited
  4. */
  5. #ifndef _ASM_IRQFLAGS_H
  6. #define _ASM_IRQFLAGS_H
  7. #ifndef __ASSEMBLY__
  8. #include <linux/compiler.h>
  9. #include <linux/stringify.h>
  10. #include <asm/loongarch.h>
  11. static inline void arch_local_irq_enable(void)
  12. {
  13. u32 flags = CSR_CRMD_IE;
  14. __asm__ __volatile__(
  15. "csrxchg %[val], %[mask], %[reg]\n\t"
  16. : [val] "+r" (flags)
  17. : [mask] "r" (CSR_CRMD_IE), [reg] "i" (LOONGARCH_CSR_CRMD)
  18. : "memory");
  19. }
  20. static inline void arch_local_irq_disable(void)
  21. {
  22. u32 flags = 0;
  23. __asm__ __volatile__(
  24. "csrxchg %[val], %[mask], %[reg]\n\t"
  25. : [val] "+r" (flags)
  26. : [mask] "r" (CSR_CRMD_IE), [reg] "i" (LOONGARCH_CSR_CRMD)
  27. : "memory");
  28. }
  29. static inline unsigned long arch_local_irq_save(void)
  30. {
  31. u32 flags = 0;
  32. __asm__ __volatile__(
  33. "csrxchg %[val], %[mask], %[reg]\n\t"
  34. : [val] "+r" (flags)
  35. : [mask] "r" (CSR_CRMD_IE), [reg] "i" (LOONGARCH_CSR_CRMD)
  36. : "memory");
  37. return flags;
  38. }
  39. static inline void arch_local_irq_restore(unsigned long flags)
  40. {
  41. __asm__ __volatile__(
  42. "csrxchg %[val], %[mask], %[reg]\n\t"
  43. : [val] "+r" (flags)
  44. : [mask] "r" (CSR_CRMD_IE), [reg] "i" (LOONGARCH_CSR_CRMD)
  45. : "memory");
  46. }
  47. static inline unsigned long arch_local_save_flags(void)
  48. {
  49. u32 flags;
  50. __asm__ __volatile__(
  51. "csrrd %[val], %[reg]\n\t"
  52. : [val] "=r" (flags)
  53. : [reg] "i" (LOONGARCH_CSR_CRMD)
  54. : "memory");
  55. return flags;
  56. }
  57. static inline int arch_irqs_disabled_flags(unsigned long flags)
  58. {
  59. return !(flags & CSR_CRMD_IE);
  60. }
  61. static inline int arch_irqs_disabled(void)
  62. {
  63. return arch_irqs_disabled_flags(arch_local_save_flags());
  64. }
  65. #endif /* #ifndef __ASSEMBLY__ */
  66. #endif /* _ASM_IRQFLAGS_H */