aux.h 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (C) 2016-2017 Synopsys, Inc. (www.synopsys.com)
  4. */
  5. #ifndef __SOC_ARC_AUX_H__
  6. #define __SOC_ARC_AUX_H__
  7. #ifdef CONFIG_ARC
  8. #define read_aux_reg(r) __builtin_arc_lr(r)
  9. /* gcc builtin sr needs reg param to be long immediate */
  10. #define write_aux_reg(r, v) __builtin_arc_sr((unsigned int)(v), r)
  11. #else /* !CONFIG_ARC */
  12. static inline int read_aux_reg(u32 r)
  13. {
  14. return 0;
  15. }
  16. /*
  17. * function helps elide unused variable warning
  18. * see: https://lists.infradead.org/pipermail/linux-snps-arc/2016-November/001748.html
  19. */
  20. static inline void write_aux_reg(u32 r, u32 v)
  21. {
  22. ;
  23. }
  24. #endif
  25. #define READ_BCR(reg, into) \
  26. { \
  27. unsigned int tmp; \
  28. tmp = read_aux_reg(reg); \
  29. if (sizeof(tmp) == sizeof(into)) { \
  30. into = *((typeof(into) *)&tmp); \
  31. } else { \
  32. extern void bogus_undefined(void); \
  33. bogus_undefined(); \
  34. } \
  35. }
  36. #define WRITE_AUX(reg, into) \
  37. { \
  38. unsigned int tmp; \
  39. if (sizeof(tmp) == sizeof(into)) { \
  40. tmp = (*(unsigned int *)&(into)); \
  41. write_aux_reg(reg, tmp); \
  42. } else { \
  43. extern void bogus_undefined(void); \
  44. bogus_undefined(); \
  45. } \
  46. }
  47. #endif