blob: 1cfdf891755acebc9b1dfe4fcae9a6a7540c508d [file] [log] [blame]
Patrick Georgi11f00792020-03-04 15:10:45 +01001/* SPDX-License-Identifier: GPL-2.0-only */
Martin Roth9df9e9392016-01-12 15:55:28 -07002
Stefan Reinauer0054afa2011-10-25 23:43:34 +00003#include <string.h>
Harshit Sharma51593dd2020-08-08 17:51:59 -07004#include <stdbool.h>
5#include <asan.h>
Stefan Reinauer0054afa2011-10-25 23:43:34 +00006
Mathias Krausedd30acd2012-03-31 17:23:53 +02007void *memcpy(void *dest, const void *src, size_t n)
Stefan Reinauer0054afa2011-10-25 23:43:34 +00008{
Mathias Krausedd30acd2012-03-31 17:23:53 +02009 unsigned long d0, d1, d2;
10
Harshit Sharma51593dd2020-08-08 17:51:59 -070011#if (ENV_ROMSTAGE && CONFIG(ASAN_IN_ROMSTAGE)) || \
12 (ENV_RAMSTAGE && CONFIG(ASAN_IN_RAMSTAGE))
13 check_memory_region((unsigned long)src, n, false, _RET_IP_);
14 check_memory_region((unsigned long)dest, n, true, _RET_IP_);
15#endif
16
Mathias Krausedd30acd2012-03-31 17:23:53 +020017 asm volatile(
Stefan Reinauer7c35af22015-06-17 16:09:10 -070018#ifdef __x86_64__
19 "rep ; movsd\n\t"
20 "mov %4,%%rcx\n\t"
21#else
Stefan Reinauer31409612012-08-22 17:01:08 -070022 "rep ; movsl\n\t"
23 "movl %4,%%ecx\n\t"
Stefan Reinauer7c35af22015-06-17 16:09:10 -070024#endif
Stefan Reinauer31409612012-08-22 17:01:08 -070025 "rep ; movsb\n\t"
26 : "=&c" (d0), "=&D" (d1), "=&S" (d2)
27 : "0" (n >> 2), "g" (n & 3), "1" (dest), "2" (src)
Mathias Krausedd30acd2012-03-31 17:23:53 +020028 : "memory"
Stefan Reinauer31409612012-08-22 17:01:08 -070029 );
Mathias Krausedd30acd2012-03-31 17:23:53 +020030
31 return dest;
Stefan Reinauer0054afa2011-10-25 23:43:34 +000032}