mirror of
https://gitee.com/openharmony/arkcompiler_ets_runtime
synced 2024-10-07 16:13:49 +00:00
97e03ede3a
Signed-off-by: yanpeng <yanpeng51@h-partners.com>
123 lines
4.7 KiB
C++
123 lines
4.7 KiB
C++
/*
|
|
* Copyright (c) 2021 Huawei Device Co., Ltd.
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#include "ecmascript/tests/test_helper.h"
|
|
|
|
#include "ecmascript/ecma_vm.h"
|
|
#include "ecmascript/global_env.h"
|
|
#include "ecmascript/js_handle.h"
|
|
#include "ecmascript/mem/clock_scope.h"
|
|
#include "ecmascript/mem/concurrent_marker.h"
|
|
#include "ecmascript/mem/verification.h"
|
|
|
|
using namespace panda::ecmascript;
|
|
|
|
namespace panda::test {
|
|
class ConcurrentMarkingTest : public BaseTestWithScope<false> {
|
|
public:
|
|
void SetUp() override
|
|
{
|
|
JSRuntimeOptions options;
|
|
instance = JSNApi::CreateEcmaVM(options);
|
|
ASSERT_TRUE(instance != nullptr) << "Cannot create EcmaVM";
|
|
thread = instance->GetJSThread();
|
|
thread->ManagedCodeBegin();
|
|
scope = new EcmaHandleScope(thread);
|
|
instance->SetEnableForceGC(false);
|
|
auto heap = const_cast<Heap *>(thread->GetEcmaVM()->GetHeap());
|
|
heap->GetConcurrentMarker()->EnableConcurrentMarking(EnableConcurrentMarkType::ENABLE);
|
|
}
|
|
|
|
JSHandle<TaggedArray> CreateTaggedArray(uint32_t length, JSTaggedValue initVal, MemSpaceType spaceType)
|
|
{
|
|
ObjectFactory *factory = thread->GetEcmaVM()->GetFactory();
|
|
return factory->NewTaggedArray(length, initVal, spaceType);
|
|
}
|
|
};
|
|
|
|
HWTEST_F_L0(ConcurrentMarkingTest, PerformanceWithConcurrentMarking)
|
|
{
|
|
uint32_t length = 1_KB;
|
|
JSHandle<TaggedArray> rootArray =
|
|
CreateTaggedArray(length, JSTaggedValue::Undefined(), MemSpaceType::OLD_SPACE);
|
|
for (uint32_t i = 0; i < length; i++) {
|
|
auto array = CreateTaggedArray(length, JSTaggedValue::Undefined(), MemSpaceType::OLD_SPACE);
|
|
rootArray->Set(thread, i, array);
|
|
}
|
|
auto heap = const_cast<Heap *>(thread->GetEcmaVM()->GetHeap());
|
|
heap->TriggerConcurrentMarking(); // concurrent mark
|
|
for (uint32_t i = 0; i < length; i++) {
|
|
auto array = CreateTaggedArray(length, JSTaggedValue::Undefined(), MemSpaceType::OLD_SPACE);
|
|
rootArray->Set(thread, i, array);
|
|
}
|
|
heap->CollectGarbage(TriggerGCType::OLD_GC);
|
|
}
|
|
|
|
HWTEST_F_L0(ConcurrentMarkingTest, PerformanceWithoutConcurrentMarking)
|
|
{
|
|
uint32_t length = 1_KB;
|
|
JSHandle<TaggedArray> rootArray =
|
|
CreateTaggedArray(length, JSTaggedValue::Undefined(), MemSpaceType::OLD_SPACE);
|
|
for (uint32_t i = 0; i < length; i++) {
|
|
auto array = CreateTaggedArray(length, JSTaggedValue::Undefined(), MemSpaceType::OLD_SPACE);
|
|
rootArray->Set(thread, i, array);
|
|
}
|
|
auto heap = const_cast<Heap *>(thread->GetEcmaVM()->GetHeap());
|
|
for (uint32_t i = 0; i < length; i++) {
|
|
auto array = CreateTaggedArray(length, JSTaggedValue::Undefined(), MemSpaceType::OLD_SPACE);
|
|
rootArray->Set(thread, i, array);
|
|
}
|
|
heap->CollectGarbage(TriggerGCType::OLD_GC);
|
|
}
|
|
|
|
HWTEST_F_L0(ConcurrentMarkingTest, ConcurrentMarkingWithOldSpace)
|
|
{
|
|
auto heap = const_cast<Heap *>(thread->GetEcmaVM()->GetHeap());
|
|
heap->SetFullMarkRequestedState(false);
|
|
{
|
|
[[maybe_unused]] ecmascript::EcmaHandleScope baseScope(thread);
|
|
uint32_t length = 1_KB;
|
|
for (uint32_t i = 0; i < length * 2; i++) {
|
|
[[maybe_unused]] auto array =
|
|
CreateTaggedArray(length, JSTaggedValue::Undefined(), MemSpaceType::OLD_SPACE);
|
|
}
|
|
|
|
heap->GetOldSpace()->SetInitialCapacity(static_cast<size_t>(length));
|
|
EXPECT_FALSE(heap->IsConcurrentFullMark());
|
|
heap->TryTriggerConcurrentMarking();
|
|
EXPECT_TRUE(heap->IsConcurrentFullMark());
|
|
}
|
|
}
|
|
|
|
HWTEST_F_L0(ConcurrentMarkingTest, ConcurrentMarkingWithNewSpace)
|
|
{
|
|
auto heap = const_cast<Heap *>(thread->GetEcmaVM()->GetHeap());
|
|
heap->SetFullMarkRequestedState(false);
|
|
{
|
|
[[maybe_unused]] ecmascript::EcmaHandleScope baseScope(thread);
|
|
uint32_t length = 1_KB;
|
|
for (uint32_t i = 0; i < length * 2; i++) {
|
|
[[maybe_unused]] auto array =
|
|
CreateTaggedArray(length, JSTaggedValue::Undefined(), MemSpaceType::SEMI_SPACE);
|
|
}
|
|
|
|
heap->GetNewSpace()->SetInitialCapacity(static_cast<size_t>(length));
|
|
EXPECT_FALSE(heap->IsConcurrentFullMark());
|
|
heap->TryTriggerConcurrentMarking();
|
|
EXPECT_TRUE(!heap->IsConcurrentFullMark());
|
|
}
|
|
}
|
|
} // namespace panda::test
|