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

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

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ 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.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /include/soc/arc/aux.h (Version linux-6.12-rc7) and /include/soc/arc/aux.h (Version linux-5.4.285)


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