1
0

aspace_unmap_range_shrink.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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-08-17 Shell test case for aspace_unmap_range
  9. */
  10. #include "common.h"
  11. #include "lwp_user_mm.h"
  12. #include <mm_aspace.h>
  13. #include <rtthread.h>
  14. static void *vaddr = (void *)0x100000000;
  15. static size_t existed_size = 0x5000;
  16. static char *unmap_start;
  17. static char *unmap_end;
  18. static size_t former_vsz;
  19. static size_t unmap_size = 0x2000;
  20. static struct rt_lwp *lwp;
  21. static void test_unmap_range_shrink(void)
  22. {
  23. /* create an existed mapping */
  24. former_vsz = rt_aspace_count_vsz(lwp->aspace);
  25. uassert_true(!rt_aspace_map(lwp->aspace, &vaddr, existed_size, MMU_MAP_K_RWCB, MMF_PREFETCH, &rt_mm_dummy_mapper, 0));
  26. utest_int_equal(former_vsz + existed_size, rt_aspace_count_vsz(lwp->aspace));
  27. former_vsz += existed_size;
  28. /* test the shrink mode of unmap from LEFT side */
  29. unmap_start = (char *)vaddr - unmap_size/2;
  30. uassert_true(!rt_aspace_unmap_range(lwp->aspace, unmap_start, unmap_size));
  31. unmap_end = unmap_start + unmap_size;
  32. uassert_true(rt_hw_mmu_v2p(lwp->aspace, unmap_end) != ARCH_MAP_FAILED);
  33. utest_int_equal(former_vsz - (unmap_end - (char *)vaddr), rt_aspace_count_vsz(lwp->aspace));
  34. former_vsz -= unmap_end - (char *)vaddr;
  35. /* test the shrink mode of unmap from RIGHT side */
  36. unmap_start = (char *)vaddr + existed_size - unmap_size / 2;
  37. uassert_true(!rt_aspace_unmap_range(lwp->aspace, unmap_start, unmap_size));
  38. uassert_true(rt_hw_mmu_v2p(lwp->aspace, unmap_start - 1) != ARCH_MAP_FAILED);
  39. utest_int_equal(former_vsz - (unmap_end - (char *)vaddr), rt_aspace_count_vsz(lwp->aspace));
  40. former_vsz -= unmap_end - (char *)vaddr;
  41. utest_int_equal(RT_EOK, rt_aspace_unmap_range(lwp->aspace, vaddr, existed_size));
  42. }
  43. static void aspace_unmap_tc(void)
  44. {
  45. CONSIST_HEAP(test_unmap_range_shrink());
  46. }
  47. static rt_err_t utest_tc_init(void)
  48. {
  49. lwp = lwp_create(0);
  50. if (lwp)
  51. lwp_user_space_init(lwp, 1);
  52. else
  53. return -RT_ENOMEM;
  54. return RT_EOK;
  55. }
  56. static rt_err_t utest_tc_cleanup(void)
  57. {
  58. lwp_ref_dec(lwp);
  59. return RT_EOK;
  60. }
  61. static void testcase(void)
  62. {
  63. UTEST_UNIT_RUN(aspace_unmap_tc);
  64. }
  65. UTEST_TC_EXPORT(testcase, "testcases.mm.aspace_unmap_range.shrink", utest_tc_init, utest_tc_cleanup, 10);