summaryrefslogtreecommitdiff
path: root/arch/openrisc/include/asm/bitops/ffs.h
diff options
context:
space:
mode:
authorJonas Bonn <jonas@southpole.se>2011-06-04 19:43:49 (GMT)
committerJonas Bonn <jonas@southpole.se>2011-07-22 16:46:39 (GMT)
commit58e0166a4772aaeb10c9b0f6d59f19099d2047df (patch)
tree9b4407ee02d1364a98ddb1604143444ff2bf7631 /arch/openrisc/include/asm/bitops/ffs.h
parent769a8a96229e6b2f1e3a2b3b38e27981f7fb9902 (diff)
downloadlinux-fsl-qoriq-58e0166a4772aaeb10c9b0f6d59f19099d2047df.tar.xz
OpenRISC: Headers
Signed-off-by: Jonas Bonn <jonas@southpole.se> Reviewed-by: Arnd Bergmann <arnd@arndb.de>
Diffstat (limited to 'arch/openrisc/include/asm/bitops/ffs.h')
-rw-r--r--arch/openrisc/include/asm/bitops/ffs.h32
1 files changed, 32 insertions, 0 deletions
diff --git a/arch/openrisc/include/asm/bitops/ffs.h b/arch/openrisc/include/asm/bitops/ffs.h
new file mode 100644
index 0000000..9de4624
--- /dev/null
+++ b/arch/openrisc/include/asm/bitops/ffs.h
@@ -0,0 +1,32 @@
+/*
+ * OpenRISC Linux
+ *
+ * Copyright (C) 2010-2011 Jonas Bonn <jonas@southpole.se>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ */
+
+#ifndef __ASM_OPENRISC_FFS_H
+#define __ASM_OPENRISC_FFS_H
+
+#ifdef CONFIG_OPENRISC_HAVE_INST_FF1
+
+static inline int ffs(int x)
+{
+ int ret;
+
+ __asm__ ("l.ff1 %0,%1"
+ : "=r" (ret)
+ : "r" (x));
+
+ return ret;
+}
+
+#else
+#include <asm-generic/bitops/ffs.h>
+#endif
+
+#endif /* __ASM_OPENRISC_FFS_H */