summaryrefslogtreecommitdiff
path: root/arch/arm64/lib/memchr.S
diff options
context:
space:
mode:
authorCatalin Marinas <catalin.marinas@arm.com>2013-03-28 20:13:26 +0400
committerCatalin Marinas <catalin.marinas@arm.com>2013-03-28 20:13:26 +0400
commitd4784be3b20ed0dd19bbde3b2d58df023ae1dc86 (patch)
tree951aa2f45d2acd1b244bd3eabdf78c7d1e75d0f2 /arch/arm64/lib/memchr.S
parente851b58cb77b47a5c14267723bd6b76655d21840 (diff)
parent62479586532715b6da4777374a6f53b32453385e (diff)
downloadlinux-d4784be3b20ed0dd19bbde3b2d58df023ae1dc86.tar.xz
Merge branch 'arm64-klib' into upstream
* arm64-klib: arm64: klib: Optimised atomic bitops arm64: klib: Optimised string functions arm64: klib: Optimised memory functions
Diffstat (limited to 'arch/arm64/lib/memchr.S')
-rw-r--r--arch/arm64/lib/memchr.S44
1 files changed, 44 insertions, 0 deletions
diff --git a/arch/arm64/lib/memchr.S b/arch/arm64/lib/memchr.S
new file mode 100644
index 000000000000..8636b7549163
--- /dev/null
+++ b/arch/arm64/lib/memchr.S
@@ -0,0 +1,44 @@
+/*
+ * Based on arch/arm/lib/memchr.S
+ *
+ * Copyright (C) 1995-2000 Russell King
+ * Copyright (C) 2013 ARM Ltd.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include <linux/linkage.h>
+#include <asm/assembler.h>
+
+/*
+ * Find a character in an area of memory.
+ *
+ * Parameters:
+ * x0 - buf
+ * x1 - c
+ * x2 - n
+ * Returns:
+ * x0 - address of first occurrence of 'c' or 0
+ */
+ENTRY(memchr)
+ and w1, w1, #0xff
+1: subs x2, x2, #1
+ b.mi 2f
+ ldrb w3, [x0], #1
+ cmp w3, w1
+ b.ne 1b
+ sub x0, x0, #1
+ ret
+2: mov x0, #0
+ ret
+ENDPROC(memchr)