summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2012-09-10 19:04:24 -0400
committerRich Felker <dalias@aerifal.cx>2012-09-10 19:04:24 -0400
commit2bf469310de6793228c103691859ed4d3158b117 (patch)
treeb292372faf231031dbe9404efb081fdf341ff719
parenta9555a995cea8aa67da571c95af61109140f2c8d (diff)
downloadmusl-2bf469310de6793228c103691859ed4d3158b117.tar.gz
musl-2bf469310de6793228c103691859ed4d3158b117.tar.bz2
musl-2bf469310de6793228c103691859ed4d3158b117.tar.xz
musl-2bf469310de6793228c103691859ed4d3158b117.zip
asm for memmove on i386 and x86_64
for the sake of simplicity, I've only used rep movsb rather than breaking up the copy for using rep movsd/q. on all modern cpus, this seems to be fine, but if there are performance problems, there might be a need to go back and add support for rep movsd/q.
-rw-r--r--src/string/i386/memmove.s21
-rw-r--r--src/string/x86_64/memmove.s15
2 files changed, 36 insertions, 0 deletions
diff --git a/src/string/i386/memmove.s b/src/string/i386/memmove.s
new file mode 100644
index 00000000..6e6cc8e3
--- /dev/null
+++ b/src/string/i386/memmove.s
@@ -0,0 +1,21 @@
+.global memmove
+.type memmove,@function
+memmove:
+ mov 4(%esp),%eax
+ sub 8(%esp),%eax
+ cmp 12(%esp),%eax
+ jae memcpy
+ push %esi
+ push %edi
+ mov 12(%esp),%edi
+ mov 16(%esp),%esi
+ mov 20(%esp),%ecx
+ lea -1(%edi,%ecx),%edi
+ lea -1(%esi,%ecx),%esi
+ std
+ rep movsb
+ cld
+ lea 1(%edi),%eax
+ pop %edi
+ pop %esi
+ ret
diff --git a/src/string/x86_64/memmove.s b/src/string/x86_64/memmove.s
new file mode 100644
index 00000000..247f0ac3
--- /dev/null
+++ b/src/string/x86_64/memmove.s
@@ -0,0 +1,15 @@
+.global memmove
+.type memmove,@function
+memmove:
+ mov %rdi,%rax
+ sub %rsi,%rax
+ cmp %rdx,%rax
+ jae memcpy
+ mov %rdx,%rcx
+ lea -1(%rdi,%rdx),%rdi
+ lea -1(%rsi,%rdx),%rsi
+ std
+ rep movsb
+ cld
+ lea 1(%rdi),%rax
+ ret