This repository has been archived on 2023-11-05. You can view files and clone it, but cannot push or open issues or pull requests.
wasm-micro-runtime/core/shared/utils/bh_common.c
dongsheng28849455 e517dbc7b2
XIP adaptation for xtensa platform (#1636)
Add macro WASM_ENABLE_WORD_ALING_READ to enable reading
1/2/4 and n bytes data from vram buffer, which requires 4-byte addr
alignment reading.

Eliminate XIP AOT relocations related to the below ones:
   i32_div_u, f32_min, f32_max, f32_ceil, f32_floor, f32_trunc, f32_rint
2022-10-31 17:25:24 +08:00

164 lines
3.3 KiB
C

/*
* Copyright (C) 2019 Intel Corporation. All rights reserved.
* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
*/
#include "bh_common.h"
static char *
align_ptr(char *src, unsigned int b)
{
uintptr_t v = (uintptr_t)src;
uintptr_t m = b - 1;
return (char *)((v + m) & ~m);
}
/*
Memory copy, with word alignment
*/
int
b_memcpy_wa(void *s1, unsigned int s1max, const void *s2, unsigned int n)
{
char *dest = (char *)s1;
char *src = (char *)s2;
char *pa = align_ptr(src, 4);
char *pb = align_ptr((src + n), 4);
unsigned int buff;
const char *p_byte_read;
unsigned int *p;
char *ps;
if (pa > src) {
pa -= 4;
}
for (p = (unsigned int *)pa; p < (unsigned int *)pb; p++) {
buff = *(p);
p_byte_read = ((char *)&buff);
/* read leading word */
if ((char *)p <= src) {
for (ps = src; ps < ((char *)p + 4); ps++) {
if (ps >= src + n) {
break;
}
p_byte_read = ((char *)&buff) + (ps - (char *)p);
*dest++ = *p_byte_read;
}
}
/* read trailing word */
else if ((char *)p >= pb - 4) {
for (ps = (char *)p; ps < src + n; ps++) {
*dest++ = *p_byte_read++;
}
}
/* read meaning word(s) */
else {
if ((char *)p + 4 >= src + n) {
for (ps = (char *)p; ps < src + n; ps++) {
*dest++ = *p_byte_read++;
}
}
else {
*(unsigned int *)dest = buff;
dest += 4;
}
}
}
return 0;
}
int
b_memcpy_s(void *s1, unsigned int s1max, const void *s2, unsigned int n)
{
char *dest = (char *)s1;
char *src = (char *)s2;
if (n == 0) {
return 0;
}
if (s1 == NULL) {
return -1;
}
if (s2 == NULL || n > s1max) {
memset(dest, 0, s1max);
return -1;
}
memcpy(dest, src, n);
return 0;
}
int
b_memmove_s(void *s1, unsigned int s1max, const void *s2, unsigned int n)
{
char *dest = (char *)s1;
char *src = (char *)s2;
if (n == 0) {
return 0;
}
if (s1 == NULL) {
return -1;
}
if (s2 == NULL || n > s1max) {
memset(dest, 0, s1max);
return -1;
}
memmove(dest, src, n);
return 0;
}
int
b_strcat_s(char *s1, unsigned int s1max, const char *s2)
{
if (NULL == s1 || NULL == s2 || s1max < (strlen(s1) + strlen(s2) + 1)) {
return -1;
}
memcpy(s1 + strlen(s1), s2, strlen(s2) + 1);
return 0;
}
int
b_strcpy_s(char *s1, unsigned int s1max, const char *s2)
{
if (NULL == s1 || NULL == s2 || s1max < (strlen(s2) + 1)) {
return -1;
}
memcpy(s1, s2, strlen(s2) + 1);
return 0;
}
char *
bh_strdup(const char *s)
{
uint32 size;
char *s1 = NULL;
if (s) {
size = (uint32)(strlen(s) + 1);
if ((s1 = BH_MALLOC(size)))
bh_memcpy_s(s1, size, s, size);
}
return s1;
}
char *
wa_strdup(const char *s)
{
uint32 size;
char *s1 = NULL;
if (s) {
size = (uint32)(strlen(s) + 1);
if ((s1 = WA_MALLOC(size)))
bh_memcpy_s(s1, size, s, size);
}
return s1;
}