interrupts.c 542 B

123456789101112131415161718192021222324252627282930
  1. /*
  2. * Copyright (C) 2006 Atmel Corporation
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #include <common.h>
  7. #include <asm/sysreg.h>
  8. void enable_interrupts(void)
  9. {
  10. asm volatile("csrf %0" : : "n"(SYSREG_GM_OFFSET));
  11. }
  12. int disable_interrupts(void)
  13. {
  14. unsigned long sr;
  15. sr = sysreg_read(SR);
  16. asm volatile("ssrf %0" : : "n"(SYSREG_GM_OFFSET));
  17. #ifdef CONFIG_AT32UC3A0xxx
  18. /* Two NOPs are required after masking interrupts on the
  19. * AT32UC3A0512ES. See errata 41.4.5.5. */
  20. asm("nop");
  21. asm("nop");
  22. #endif
  23. return !SYSREG_BFEXT(GM, sr);
  24. }