jdk/test/hotspot/gtest/gc/z/test_zNUMA.cpp
Joel Sikström 7e69b98e05 8350441: ZGC: Overhaul Page Allocation
Co-authored-by: Axel Boldt-Christmas <aboldtch@openjdk.org>
Co-authored-by: Erik Österlund <eosterlund@openjdk.org>
Co-authored-by: Stefan Karlsson <stefank@openjdk.org>
Co-authored-by: Stefan Johansson <sjohanss@openjdk.org>
Reviewed-by: stefank, aboldtch, eosterlund
2025-04-10 11:37:20 +00:00

116 lines
3.4 KiB
C++

/*
* Copyright (c) 2025, 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 "gc/shared/gc_globals.hpp"
#include "gc/z/zNUMA.inline.hpp"
#include "zunittest.hpp"
using namespace testing;
#ifdef ASSERT
class ZNUMATest : public ZTest {
protected:
const uint32_t nodes = 4;
uint32_t _original_count;
uint _original_ZFakeNUMA;
public:
virtual void SetUp() {
_original_count = ZNUMA::_count;
_original_ZFakeNUMA = ZFakeNUMA;
// Setup number of NUMA nodes through faking
ZFakeNUMA = nodes;
ZNUMA::_count = nodes;
}
virtual void TearDown() {
ZNUMA::_count = _original_count;
ZFakeNUMA = _original_ZFakeNUMA;
}
};
TEST_F(ZNUMATest, calculate_share) {
{
// Test even spread
const size_t total = nodes * ZGranuleSize;
for (uint32_t numa_id = 0; numa_id < nodes; ++numa_id) {
EXPECT_EQ(ZNUMA::calculate_share(numa_id, total), ZGranuleSize);
}
}
{
// Test not enough for every node (WITHOUT ignore_count)
const size_t total = (nodes - 1) * ZGranuleSize;
for (uint32_t numa_id = 0; numa_id < (nodes - 1); ++numa_id) {
EXPECT_EQ(ZNUMA::calculate_share(numa_id, total), ZGranuleSize);
}
EXPECT_EQ(ZNUMA::calculate_share(nodes - 1, total), (size_t)0);
}
{
// Test not enough for every node (WITH ignore_count)
const size_t ignore_count = 2;
const size_t total = nodes * ZGranuleSize;
for (uint32_t numa_id = 0; numa_id < (nodes - ignore_count); ++numa_id) {
EXPECT_EQ(ZNUMA::calculate_share(numa_id, total, ZGranuleSize, ignore_count), nodes * ZGranuleSize / (nodes - ignore_count));
}
}
{
// Test no size
const size_t total = 0;
for (uint32_t numa_id = 0; numa_id < (nodes - 1); ++numa_id) {
EXPECT_EQ(ZNUMA::calculate_share(numa_id, total), (size_t)0);
}
}
{
// Test one more than even
const size_t total = (nodes + 1) * ZGranuleSize;
EXPECT_EQ(ZNUMA::calculate_share(0, total), ZGranuleSize * 2);
for (uint32_t numa_id = 1; numa_id < nodes; ++numa_id) {
EXPECT_EQ(ZNUMA::calculate_share(numa_id, total), ZGranuleSize);
}
}
{
// Test one less than even
const size_t total = (nodes * 2 - 1) * ZGranuleSize;
for (uint32_t numa_id = 0; numa_id < (nodes - 1); ++numa_id) {
EXPECT_EQ(ZNUMA::calculate_share(numa_id, total), 2 * ZGranuleSize);
}
EXPECT_EQ(ZNUMA::calculate_share(nodes - 1, total), ZGranuleSize);
}
}
#endif // ASSERT