diff options
author | iabdalkader <i.abdalkader@gmail.com> | 2014-09-11 07:49:21 +0200 |
---|---|---|
committer | iabdalkader <i.abdalkader@gmail.com> | 2014-09-11 07:49:21 +0200 |
commit | 81b2ddf5d175ee810b93925da49754ca18a3e607 (patch) | |
tree | df3ac215bdf3538994149e9ebdf4e040b06a0376 | |
parent | 953074315e594f5a30f455dc6a1a67340a3e6ea7 (diff) | |
download | micropython-81b2ddf5d175ee810b93925da49754ca18a3e607.tar.gz micropython-81b2ddf5d175ee810b93925da49754ca18a3e607.zip |
Memcpy: copy words
-rw-r--r-- | stmhal/string0.c | 28 |
1 files changed, 21 insertions, 7 deletions
diff --git a/stmhal/string0.c b/stmhal/string0.c index c605e0a9e8..2f28de097c 100644 --- a/stmhal/string0.c +++ b/stmhal/string0.c @@ -27,14 +27,28 @@ #include <stdint.h> #include "std.h" -void *memcpy(void *dest, const void *src, size_t n) { - // TODO align and copy 32 bits at a time - uint8_t *d = dest; - const uint8_t *s = src; - for (; n > 0; n--) { - *d++ = *s++; +#define likely(x) __builtin_expect((x), 1) + +void *memcpy(void *dst, const void *src, size_t n) { + if (likely(!(n&3) && !((long)dst&3) && !((long)src&3))) { + //aligned access, copy words + long *d = dst; + const long *s = src; + + for (n=(n>>2); n; n--) { + *d++ = *s++; + } + } else { + //unaligned access, copy bytes + char *d = dst; + const char *s = src; + + for (; n; n--) { + *d++ = *s++; + } } - return dest; + + return dst; } void *memmove(void *dest, const void *src, size_t n) { |