[CRIU] [PATCH 4/4] x86/compat: provide optimized memcpy_x86
Pavel Emelyanov
xemul at virtuozzo.com
Tue Nov 22 05:26:57 PST 2016
On 11/22/2016 02:42 PM, Dmitry Safonov wrote:
> Implementation for PIE's builtin_memcpy located at
> criu/arch/x86/include/asm/string.h
>
> Signed-off-by: Dmitry Safonov <dsafonov at virtuozzo.com>
> ---
> criu/arch/x86/compat/memcpy-compat.c | 25 +++++++++++++++++++++++++
> 1 file changed, 25 insertions(+)
> create mode 100644 criu/arch/x86/compat/memcpy-compat.c
>
> diff --git a/criu/arch/x86/compat/memcpy-compat.c b/criu/arch/x86/compat/memcpy-compat.c
> new file mode 100644
> index 000000000000..793c27dcaa7d
> --- /dev/null
> +++ b/criu/arch/x86/compat/memcpy-compat.c
Another memcpy for pie? Shouldn't they all be in compel?
> @@ -0,0 +1,25 @@
> +#include <stddef.h>
> +
> +/*
> + * This provides an optimized implementation of memcpy, and a simplified
> + * implementation of memset and memmove. These are used here because the
> + * standard kernel runtime versions are not yet available and we don't
> + * trust the gcc built-in implementations as they may do unexpected things
> + * (e.g. FPU ops) in the minimal decompression stub execution environment.
> + *
> + * From Linux kernel boot helpers: arch/x86/boot/compressed/string.c
> + */
> +
> +void *memcpy_x86(void *dest, const void *src, size_t n)
> +{
> + int d0, d1, d2;
> + asm volatile(
> + "rep ; movsl\n\t"
> + "movl %4,%%ecx\n\t"
> + "rep ; movsb\n\t"
> + : "=&c" (d0), "=&D" (d1), "=&S" (d2)
> + : "0" (n >> 2), "g" (n & 3), "1" (dest), "2" (src)
> + : "memory");
> +
> + return dest;
> +}
>
More information about the CRIU
mailing list