summaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorSascha Hauer <s.hauer@pengutronix.de>2014-04-04 10:06:14 +0200
committerSascha Hauer <s.hauer@pengutronix.de>2014-04-04 10:06:14 +0200
commit712b555f6cd07cfe3a1c26dc804134d006bf929d (patch)
tree467fa1b174608e19540f40fb8d462ec3976025e8 /include
parenta5a82ca2cd84d3a730025bed7414b35f041750b6 (diff)
parente32abecf6d7bad20ff83d61887b7be7bfa55d8ae (diff)
downloadbarebox-712b555f6cd07cfe3a1c26dc804134d006bf929d.tar.gz
barebox-712b555f6cd07cfe3a1c26dc804134d006bf929d.tar.xz
Merge branch 'for-next/davinci'
Diffstat (limited to 'include')
-rw-r--r--include/linux/const.h27
1 files changed, 27 insertions, 0 deletions
diff --git a/include/linux/const.h b/include/linux/const.h
new file mode 100644
index 0000000000..c872bfd25e
--- /dev/null
+++ b/include/linux/const.h
@@ -0,0 +1,27 @@
+/* const.h: Macros for dealing with constants. */
+
+#ifndef _LINUX_CONST_H
+#define _LINUX_CONST_H
+
+/* Some constant macros are used in both assembler and
+ * C code. Therefore we cannot annotate them always with
+ * 'UL' and other type specifiers unilaterally. We
+ * use the following macros to deal with this.
+ *
+ * Similarly, _AT() will cast an expression with a type in C, but
+ * leave it unchanged in asm.
+ */
+
+#ifdef __ASSEMBLY__
+#define _AC(X,Y) X
+#define _AT(T,X) X
+#else
+#define __AC(X,Y) (X##Y)
+#define _AC(X,Y) __AC(X,Y)
+#define _AT(T,X) ((T)(X))
+#endif
+
+#define _BITUL(x) (_AC(1,UL) << (x))
+#define _BITULL(x) (_AC(1,ULL) << (x))
+
+#endif /* !(_LINUX_CONST_H) */