|  | /* | 
|  | * Copyright (C) 2017-2021 Apple Inc. All rights reserved. | 
|  | * | 
|  | * Redistribution and use in source and binary forms, with or without | 
|  | * modification, are permitted provided that the following conditions | 
|  | * are met: | 
|  | * 1. Redistributions of source code must retain the above copyright | 
|  | *    notice, this list of conditions and the following disclaimer. | 
|  | * 2. Redistributions in binary form must reproduce the above copyright | 
|  | *    notice, this list of conditions and the following disclaimer in the | 
|  | *    documentation and/or other materials provided with the distribution. | 
|  | * | 
|  | * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' | 
|  | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, | 
|  | * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 
|  | * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS | 
|  | * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | 
|  | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | 
|  | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | 
|  | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | 
|  | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | 
|  | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF | 
|  | * THE POSSIBILITY OF SUCH DAMAGE. | 
|  | */ | 
|  |  | 
|  | #pragma once | 
|  |  | 
|  | #include "ConstraintConcurrency.h" | 
|  | #include "ConstraintParallelism.h" | 
|  | #include "ConstraintVolatility.h" | 
|  | #include <limits.h> | 
|  | #include <wtf/FastMalloc.h> | 
|  | #include <wtf/Lock.h> | 
|  | #include <wtf/Noncopyable.h> | 
|  | #include <wtf/SharedTask.h> | 
|  | #include <wtf/text/CString.h> | 
|  |  | 
|  | namespace JSC { | 
|  |  | 
|  | class MarkingConstraintSet; | 
|  | class AbstractSlotVisitor; | 
|  | class SlotVisitor; | 
|  |  | 
|  | class MarkingConstraint { | 
|  | WTF_MAKE_NONCOPYABLE(MarkingConstraint); | 
|  | WTF_MAKE_FAST_ALLOCATED; | 
|  | public: | 
|  | JS_EXPORT_PRIVATE MarkingConstraint( | 
|  | CString abbreviatedName, CString name, ConstraintVolatility, | 
|  | ConstraintConcurrency = ConstraintConcurrency::Concurrent, | 
|  | ConstraintParallelism = ConstraintParallelism::Sequential); | 
|  |  | 
|  | JS_EXPORT_PRIVATE virtual ~MarkingConstraint(); | 
|  |  | 
|  | unsigned index() const { return m_index; } | 
|  |  | 
|  | const char* abbreviatedName() const { return m_abbreviatedName.data(); } | 
|  | const char* name() const { return m_name.data(); } | 
|  |  | 
|  | void resetStats(); | 
|  |  | 
|  | size_t lastVisitCount() const { return m_lastVisitCount; } | 
|  |  | 
|  | // The following functions are only used by the real GC via the MarkingConstraintSolver. | 
|  | // Hence, we only need the SlotVisitor version. | 
|  | void execute(SlotVisitor&); | 
|  |  | 
|  | JS_EXPORT_PRIVATE virtual double quickWorkEstimate(SlotVisitor&); | 
|  |  | 
|  | double workEstimate(SlotVisitor&); | 
|  |  | 
|  | void prepareToExecute(const AbstractLocker& constraintSolvingLocker, SlotVisitor&); | 
|  |  | 
|  | void doParallelWork(SlotVisitor&, SharedTask<void(SlotVisitor&)>&); | 
|  |  | 
|  | ConstraintVolatility volatility() const { return m_volatility; } | 
|  |  | 
|  | ConstraintConcurrency concurrency() const { return m_concurrency; } | 
|  | ConstraintParallelism parallelism() const { return m_parallelism; } | 
|  |  | 
|  | protected: | 
|  | virtual void executeImpl(AbstractSlotVisitor&) = 0; | 
|  | virtual void executeImpl(SlotVisitor&) = 0; | 
|  | JS_EXPORT_PRIVATE virtual void prepareToExecuteImpl(const AbstractLocker& constraintSolvingLocker, AbstractSlotVisitor&); | 
|  |  | 
|  | // This function is only used by the verifier GC via Heap::verifyGC(). | 
|  | // Hence, we only need the AbstractSlotVisitor version. | 
|  | void executeSynchronously(AbstractSlotVisitor&); | 
|  |  | 
|  | private: | 
|  | friend class MarkingConstraintSet; // So it can set m_index. | 
|  |  | 
|  | CString m_abbreviatedName; | 
|  | CString m_name; | 
|  | size_t m_lastVisitCount { 0 }; | 
|  | unsigned m_index { UINT_MAX }; | 
|  | ConstraintVolatility m_volatility; | 
|  | ConstraintConcurrency m_concurrency; | 
|  | ConstraintParallelism m_parallelism; | 
|  | Lock m_lock; | 
|  | }; | 
|  |  | 
|  | } // namespace JSC | 
|  |  |