~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/include/soc/arc/aux.h

Version: ~ [ linux-6.11-rc3 ] ~ [ linux-6.10.4 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.45 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.104 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.164 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.223 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.281 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.319 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

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

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php