/* * Copyright (c) 2016, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ #include "precompiled.hpp" #include "gc/x/xPhysicalMemory.inline.hpp" #include "unittest.hpp" TEST(XPhysicalMemoryTest, copy) { const XPhysicalMemorySegment seg0(0, 100, true); const XPhysicalMemorySegment seg1(200, 100, true); XPhysicalMemory pmem0; pmem0.add_segment(seg0); EXPECT_EQ(pmem0.nsegments(), 1); EXPECT_EQ(pmem0.segment(0).size(), 100u); XPhysicalMemory pmem1; pmem1.add_segment(seg0); pmem1.add_segment(seg1); EXPECT_EQ(pmem1.nsegments(), 2); EXPECT_EQ(pmem1.segment(0).size(), 100u); EXPECT_EQ(pmem1.segment(1).size(), 100u); XPhysicalMemory pmem2(pmem0); EXPECT_EQ(pmem2.nsegments(), 1); EXPECT_EQ(pmem2.segment(0).size(), 100u); pmem2 = pmem1; EXPECT_EQ(pmem2.nsegments(), 2); EXPECT_EQ(pmem2.segment(0).size(), 100u); EXPECT_EQ(pmem2.segment(1).size(), 100u); } TEST(XPhysicalMemoryTest, add) { const XPhysicalMemorySegment seg0(0, 1, true); const XPhysicalMemorySegment seg1(1, 1, true); const XPhysicalMemorySegment seg2(2, 1, true); const XPhysicalMemorySegment seg3(3, 1, true); const XPhysicalMemorySegment seg4(4, 1, true); const XPhysicalMemorySegment seg5(5, 1, true); const XPhysicalMemorySegment seg6(6, 1, true); XPhysicalMemory pmem0; EXPECT_EQ(pmem0.nsegments(), 0); EXPECT_EQ(pmem0.is_null(), true); XPhysicalMemory pmem1; pmem1.add_segment(seg0); pmem1.add_segment(seg1); pmem1.add_segment(seg2); pmem1.add_segment(seg3); pmem1.add_segment(seg4); pmem1.add_segment(seg5); pmem1.add_segment(seg6); EXPECT_EQ(pmem1.nsegments(), 1); EXPECT_EQ(pmem1.segment(0).size(), 7u); EXPECT_EQ(pmem1.is_null(), false); XPhysicalMemory pmem2; pmem2.add_segment(seg0); pmem2.add_segment(seg1); pmem2.add_segment(seg2); pmem2.add_segment(seg4); pmem2.add_segment(seg5); pmem2.add_segment(seg6); EXPECT_EQ(pmem2.nsegments(), 2); EXPECT_EQ(pmem2.segment(0).size(), 3u); EXPECT_EQ(pmem2.segment(1).size(), 3u); EXPECT_EQ(pmem2.is_null(), false); XPhysicalMemory pmem3; pmem3.add_segment(seg0); pmem3.add_segment(seg2); pmem3.add_segment(seg3); pmem3.add_segment(seg4); pmem3.add_segment(seg6); EXPECT_EQ(pmem3.nsegments(), 3); EXPECT_EQ(pmem3.segment(0).size(), 1u); EXPECT_EQ(pmem3.segment(1).size(), 3u); EXPECT_EQ(pmem3.segment(2).size(), 1u); EXPECT_EQ(pmem3.is_null(), false); XPhysicalMemory pmem4; pmem4.add_segment(seg0); pmem4.add_segment(seg2); pmem4.add_segment(seg4); pmem4.add_segment(seg6); EXPECT_EQ(pmem4.nsegments(), 4); EXPECT_EQ(pmem4.segment(0).size(), 1u); EXPECT_EQ(pmem4.segment(1).size(), 1u); EXPECT_EQ(pmem4.segment(2).size(), 1u); EXPECT_EQ(pmem4.segment(3).size(), 1u); EXPECT_EQ(pmem4.is_null(), false); } TEST(XPhysicalMemoryTest, remove) { XPhysicalMemory pmem; pmem.add_segment(XPhysicalMemorySegment(10, 10, true)); pmem.add_segment(XPhysicalMemorySegment(30, 10, true)); pmem.add_segment(XPhysicalMemorySegment(50, 10, true)); EXPECT_EQ(pmem.nsegments(), 3); EXPECT_EQ(pmem.size(), 30u); EXPECT_FALSE(pmem.is_null()); pmem.remove_segments(); EXPECT_EQ(pmem.nsegments(), 0); EXPECT_EQ(pmem.size(), 0u); EXPECT_TRUE(pmem.is_null()); } TEST(XPhysicalMemoryTest, split) { XPhysicalMemory pmem; pmem.add_segment(XPhysicalMemorySegment(0, 10, true)); pmem.add_segment(XPhysicalMemorySegment(10, 10, true)); pmem.add_segment(XPhysicalMemorySegment(30, 10, true)); EXPECT_EQ(pmem.nsegments(), 2); EXPECT_EQ(pmem.size(), 30u); XPhysicalMemory pmem0 = pmem.split(1); EXPECT_EQ(pmem0.nsegments(), 1); EXPECT_EQ(pmem0.size(), 1u); EXPECT_EQ(pmem.nsegments(), 2); EXPECT_EQ(pmem.size(), 29u); XPhysicalMemory pmem1 = pmem.split(25); EXPECT_EQ(pmem1.nsegments(), 2); EXPECT_EQ(pmem1.size(), 25u); EXPECT_EQ(pmem.nsegments(), 1); EXPECT_EQ(pmem.size(), 4u); XPhysicalMemory pmem2 = pmem.split(4); EXPECT_EQ(pmem2.nsegments(), 1); EXPECT_EQ(pmem2.size(), 4u); EXPECT_EQ(pmem.nsegments(), 0); EXPECT_EQ(pmem.size(), 0u); } TEST(XPhysicalMemoryTest, split_committed) { XPhysicalMemory pmem0; pmem0.add_segment(XPhysicalMemorySegment(0, 10, true)); pmem0.add_segment(XPhysicalMemorySegment(10, 10, false)); pmem0.add_segment(XPhysicalMemorySegment(20, 10, true)); pmem0.add_segment(XPhysicalMemorySegment(30, 10, false)); EXPECT_EQ(pmem0.nsegments(), 4); EXPECT_EQ(pmem0.size(), 40u); XPhysicalMemory pmem1 = pmem0.split_committed(); EXPECT_EQ(pmem0.nsegments(), 2); EXPECT_EQ(pmem0.size(), 20u); EXPECT_EQ(pmem1.nsegments(), 2); EXPECT_EQ(pmem1.size(), 20u); }