altera_utils.c 813 B

123456789101112131415161718192021222324252627282930313233
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /* Altera TSE SGDMA and MSGDMA Linux driver
  3. * Copyright (C) 2014 Altera Corporation. All rights reserved
  4. */
  5. #include "altera_tse.h"
  6. #include "altera_utils.h"
  7. void tse_set_bit(void __iomem *ioaddr, size_t offs, u32 bit_mask)
  8. {
  9. u32 value = csrrd32(ioaddr, offs);
  10. value |= bit_mask;
  11. csrwr32(value, ioaddr, offs);
  12. }
  13. void tse_clear_bit(void __iomem *ioaddr, size_t offs, u32 bit_mask)
  14. {
  15. u32 value = csrrd32(ioaddr, offs);
  16. value &= ~bit_mask;
  17. csrwr32(value, ioaddr, offs);
  18. }
  19. int tse_bit_is_set(void __iomem *ioaddr, size_t offs, u32 bit_mask)
  20. {
  21. u32 value = csrrd32(ioaddr, offs);
  22. return (value & bit_mask) ? 1 : 0;
  23. }
  24. int tse_bit_is_clear(void __iomem *ioaddr, size_t offs, u32 bit_mask)
  25. {
  26. u32 value = csrrd32(ioaddr, offs);
  27. return (value & bit_mask) ? 0 : 1;
  28. }