1 /*
2 * Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
3 * Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without modification,
6 * are permitted provided that the following conditions are met:
7 *
8 * 1. Redistributions of source code must retain the above copyright notice, this list of
9 * conditions and the following disclaimer.
10 *
11 * 2. Redistributions in binary form must reproduce the above copyright notice, this list
12 * of conditions and the following disclaimer in the documentation and/or other materials
13 * provided with the distribution.
14 *
15 * 3. Neither the name of the copyright holder nor the names of its contributors may be used
16 * to endorse or promote products derived from this software without specific prior written
17 * permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
21 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
26 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
27 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
28 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
29 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
32 #include "los_lms_pri.h"
33
LmsFree(void *ptr)34 ATTRIBUTE_NO_SANITIZE_ADDRESS void LmsFree(void *ptr)
35 {
36 if (ptr == NULL) {
37 return;
38 }
39
40 size_t allocSize = malloc_usable_size(ptr);
41 uintptr_t shadowAddr, offset;
42 LmsMem2Shadow((uintptr_t)ptr, &shadowAddr, &offset);
43
44 LmsLock(&g_lmsMutex);
45 if (LmsIsShadowAddrMapped(shadowAddr, shadowAddr) == LMS_OK) {
46 uint32_t acShadowValue;
47 LmsGetShadowValue((uintptr_t)ptr, &acShadowValue);
48 if (acShadowValue != LMS_SHADOW_ACCESSIBLE) {
49 char erroMode = (acShadowValue == LMS_SHADOW_AFTERFREE ? FREE_ERRORMODE : UNKNOWN_ERROR);
50 LmsReportError((uintptr_t)ptr, MEM_REGION_SIZE_1, erroMode);
51 goto UNLOCK_OUT;
52 }
53 } else {
54 LMS_OUTPUT_ERROR("Error! Free an unallocated memory:%p!\n", ptr);
55 goto UNLOCK_OUT;
56 }
57
58 __real_free(ptr);
59 LmsSetShadowValue((uintptr_t)ptr, (uintptr_t)ptr + allocSize, LMS_SHADOW_AFTERFREE_U8);
60
61 UNLOCK_OUT:
62 LmsUnlock(&g_lmsMutex);
63 }
64
LmsMalloc(size_t size)65 ATTRIBUTE_NO_SANITIZE_ADDRESS void *LmsMalloc(size_t size)
66 {
67 void *ptr = __real_malloc(size);
68 if (ptr == NULL) {
69 return ptr;
70 }
71 return LmsTagMem(ptr, size);
72 }
73
LmsRealloc(void *ptr, size_t size)74 ATTRIBUTE_NO_SANITIZE_ADDRESS void *LmsRealloc(void *ptr, size_t size)
75 {
76 void *p = __real_realloc(ptr, size);
77 if (p == NULL) {
78 return p;
79 }
80 return LmsTagMem(p, size);
81 }
82
LmsCalloc(size_t m, size_t n)83 ATTRIBUTE_NO_SANITIZE_ADDRESS void *LmsCalloc(size_t m, size_t n)
84 {
85 void *p = __real_calloc(m, n);
86 if (p == NULL) {
87 return p;
88 }
89 return LmsTagMem(p, n * m);
90 }
91
LmsValloc(size_t size)92 ATTRIBUTE_NO_SANITIZE_ADDRESS void *LmsValloc(size_t size)
93 {
94 void *p = __real_valloc(size);
95 if (p == NULL) {
96 return p;
97 }
98 return LmsTagMem(p, size);
99 }
100
LmsAlignedAlloc(size_t align, size_t len)101 ATTRIBUTE_NO_SANITIZE_ADDRESS void *LmsAlignedAlloc(size_t align, size_t len)
102 {
103 void *p = __real_aligned_alloc(align, len);
104 if (p == NULL) {
105 return p;
106 }
107 return LmsTagMem(p, len);
108 }
109
__wrap_aligned_alloc(size_t align, size_t len)110 ATTRIBUTE_NO_SANITIZE_ADDRESS void *__wrap_aligned_alloc(size_t align, size_t len)
111 {
112 return LmsAlignedAlloc(align, len);
113 }
114
__wrap_valloc(size_t size)115 ATTRIBUTE_NO_SANITIZE_ADDRESS void *__wrap_valloc(size_t size)
116 {
117 return LmsValloc(size);
118 }
119
__wrap_calloc(size_t m, size_t n)120 ATTRIBUTE_NO_SANITIZE_ADDRESS void *__wrap_calloc(size_t m, size_t n)
121 {
122 return LmsCalloc(m, n);
123 }
124
__wrap_realloc(void *p, size_t n)125 ATTRIBUTE_NO_SANITIZE_ADDRESS void *__wrap_realloc(void *p, size_t n)
126 {
127 return LmsRealloc(p, n);
128 }
129
__wrap_malloc(size_t size)130 ATTRIBUTE_NO_SANITIZE_ADDRESS void *__wrap_malloc(size_t size)
131 {
132 return LmsMalloc(size);
133 }
134
__wrap_free(void *ptr)135 ATTRIBUTE_NO_SANITIZE_ADDRESS void __wrap_free(void *ptr)
136 {
137 return LmsFree(ptr);
138 }
139
LmsMemset(void *p, int n, size_t size)140 ATTRIBUTE_NO_SANITIZE_ADDRESS void *LmsMemset(void *p, int n, size_t size)
141 {
142 __asan_storeN_noabort((uintptr_t)p, size);
143
144 return __real_memset(p, n, size);
145 }
146
__wrap_memset(void *p, int n, size_t size)147 ATTRIBUTE_NO_SANITIZE_ADDRESS void *__wrap_memset(void *p, int n, size_t size)
148 {
149 return LmsMemset(p, n, size);
150 }
151
LmsMemcpy(void *__restrict dest, const void *__restrict src, size_t size)152 ATTRIBUTE_NO_SANITIZE_ADDRESS void *LmsMemcpy(void *__restrict dest, const void *__restrict src, size_t size)
153 {
154 __asan_loadN_noabort((uintptr_t)src, size);
155 __asan_storeN_noabort((uintptr_t)dest, size);
156
157 return __real_memcpy(dest, src, size);
158 }
159
__wrap_memcpy(void *__restrict dest, const void *__restrict src, size_t size)160 ATTRIBUTE_NO_SANITIZE_ADDRESS void *__wrap_memcpy(void *__restrict dest, const void *__restrict src, size_t size)
161 {
162 return LmsMemcpy(dest, src, size);
163 }
164
LmsMemmove(void *dest, const void *src, size_t len)165 ATTRIBUTE_NO_SANITIZE_ADDRESS void *LmsMemmove(void *dest, const void *src, size_t len)
166 {
167 __asan_loadN_noabort((uintptr_t)src, len);
168 __asan_storeN_noabort((uintptr_t)dest, len);
169
170 return __real_memmove(dest, src, len);
171 }
172
__wrap_memmove(void *dest, const void *src, size_t len)173 ATTRIBUTE_NO_SANITIZE_ADDRESS void *__wrap_memmove(void *dest, const void *src, size_t len)
174 {
175 return LmsMemmove(dest, src, len);
176 }
177
LmsStrcat(char *s, const char *append)178 ATTRIBUTE_NO_SANITIZE_ADDRESS char *LmsStrcat(char *s, const char *append)
179 {
180 if ((s == NULL) || (append == NULL)) {
181 return NULL;
182 }
183
184 char *save = s;
185 for (; *s != '\0'; ++s) {
186 }
187 LmsCheckValid(s, append);
188
189 return __real_strcat(save, append);
190 }
191
__wrap_strcat(char *s, const char *append)192 ATTRIBUTE_NO_SANITIZE_ADDRESS char *__wrap_strcat(char *s, const char *append)
193 {
194 return LmsStrcat(s, append);
195 }
196
LmsStrcpy(char *dest, const char *src)197 ATTRIBUTE_NO_SANITIZE_ADDRESS char *LmsStrcpy(char *dest, const char *src)
198 {
199 if ((dest == NULL) || (src == NULL)) {
200 return NULL;
201 }
202
203 LmsCheckValid(dest, src);
204 return __real_strcpy(dest, src);
205 }
206
__wrap_strcpy(char *dest, const char *src)207 ATTRIBUTE_NO_SANITIZE_ADDRESS char *__wrap_strcpy(char *dest, const char *src)
208 {
209 return LmsStrcpy(dest, src);
210 }