1 /*
2 * Copyright (c) 2006-2023, RT-Thread Development Team
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 *
6 * Change Logs:
7 * Date Author Notes
8 * 2023-03-20 WangXiaoyao Complete testcase for mm_aspace.c
9 */
10 #ifndef __TEST_MM_COMMON_H__
11 #define __TEST_MM_COMMON_H__
12
13 #include <stddef.h>
14 #include <stdint.h>
15 #include <string.h>
16
17 #include <utest.h>
18
19 #include <board.h>
20 #include <rtthread.h>
21 #include <rthw.h>
22 #include <mmu.h>
23 #include <tlb.h>
24
25 #ifdef RT_USING_SMART
26 #include <lwp_arch.h>
27 #endif
28
29 #include <ioremap.h>
30 #include <mm_aspace.h>
31 #include <mm_flag.h>
32 #include <mm_page.h>
33 #include <mm_private.h>
34
35 extern rt_base_t rt_heap_lock(void);
36 extern void rt_heap_unlock(rt_base_t level);
37
38 #define __int_compare(a, b, operator) do{long _a = (long)(a); long _b = (long)(b); __utest_assert((_a) operator (_b), "Assertion Failed: (" #a ") "#operator" (" #b ")"); if (!((_a) operator (_b)))LOG_E("\t"#a"=%ld(0x%lx), "#b"=%ld(0x%lx)", _a, _a, _b, _b);} while (0)
39 #define utest_int_equal(a, b) __int_compare(a, b, ==)
40 #define utest_int_less(a, b) __int_compare(a, b, <)
41 #define utest_int_less_equal(a, b) __int_compare(a, b, <=)
42
43 /**
44 * @brief During the operations, is heap still the same;
45 */
46 #define CONSIST_HEAP(statement) do { \
47 rt_size_t total, used, max_used; \
48 rt_size_t totala, useda, max_useda; \
49 rt_ubase_t level = rt_heap_lock(); \
50 rt_memory_info(&total, &used, &max_used); \
51 statement; \
52 rt_memory_info(&totala, &useda, &max_useda); \
53 rt_heap_unlock(level); \
54 utest_int_equal(total, totala); \
55 utest_int_equal(used, useda); \
56 } while (0)
57
58 #ifdef STANDALONE_TC
59 #define TC_ASSERT(expr) \
60 ((expr) \
61 ? 0 \
62 : rt_kprintf("AssertFault(%d): %s\n", __LINE__, RT_STRINGIFY(expr)))
63 #else
64 #define TC_ASSERT(expr) uassert_true(expr)
65 #endif
66
memtest(volatile char * buf,int value,size_t buf_sz)67 rt_inline int memtest(volatile char *buf, int value, size_t buf_sz)
68 {
69 int ret = 0;
70 for (size_t i = 0; i < buf_sz; i++)
71 {
72 if (buf[i] != value)
73 {
74 ret = -1;
75 break;
76 }
77 }
78 return ret;
79 }
80
81 #endif /* __TEST_MM_COMMON_H__ */
82