14514f5e3Sopenharmony_ci/* 24514f5e3Sopenharmony_ci * Copyright (c) 2021 Huawei Device Co., Ltd. 34514f5e3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License"); 44514f5e3Sopenharmony_ci * you may not use this file except in compliance with the License. 54514f5e3Sopenharmony_ci * You may obtain a copy of the License at 64514f5e3Sopenharmony_ci * 74514f5e3Sopenharmony_ci * http://www.apache.org/licenses/LICENSE-2.0 84514f5e3Sopenharmony_ci * 94514f5e3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software 104514f5e3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS, 114514f5e3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 124514f5e3Sopenharmony_ci * See the License for the specific language governing permissions and 134514f5e3Sopenharmony_ci * limitations under the License. 144514f5e3Sopenharmony_ci */ 154514f5e3Sopenharmony_ci 164514f5e3Sopenharmony_ci#ifndef ECMASCRIPT_COMPILER_VERIFIER_H 174514f5e3Sopenharmony_ci#define ECMASCRIPT_COMPILER_VERIFIER_H 184514f5e3Sopenharmony_ci 194514f5e3Sopenharmony_ci#include <algorithm> 204514f5e3Sopenharmony_ci#include <deque> 214514f5e3Sopenharmony_ci#include <functional> 224514f5e3Sopenharmony_ci#include <numeric> 234514f5e3Sopenharmony_ci#include <unordered_map> 244514f5e3Sopenharmony_ci 254514f5e3Sopenharmony_ci#include "ecmascript/compiler/circuit.h" 264514f5e3Sopenharmony_ci 274514f5e3Sopenharmony_cinamespace panda::ecmascript::kungfu { 284514f5e3Sopenharmony_ciclass Verifier { 294514f5e3Sopenharmony_cipublic: 304514f5e3Sopenharmony_ci static bool RunDataIntegrityCheck(const Circuit *circuit); 314514f5e3Sopenharmony_ci 324514f5e3Sopenharmony_ci static bool RunStateGatesCheck(const Circuit *circuit, const std::vector<GateRef> &bbGatesList, 334514f5e3Sopenharmony_ci const std::string& methodName); 344514f5e3Sopenharmony_ci 354514f5e3Sopenharmony_ci static bool RunCFGSoundnessCheck(const Circuit *circuit, const std::vector<GateRef> &bbGatesList, 364514f5e3Sopenharmony_ci const std::unordered_map<GateRef, size_t> &bbGatesAddrToIdx); 374514f5e3Sopenharmony_ci 384514f5e3Sopenharmony_ci static bool RunCFGIsDAGCheck(const Circuit *circuit); 394514f5e3Sopenharmony_ci 404514f5e3Sopenharmony_ci static bool RunCFGReducibilityCheck(const Circuit *circuit, const std::vector<GateRef> &bbGatesList, 414514f5e3Sopenharmony_ci const std::unordered_map<GateRef, size_t> &bbGatesAddrToIdx, 424514f5e3Sopenharmony_ci const std::function<bool(size_t, size_t)> &isAncestor); 434514f5e3Sopenharmony_ci 444514f5e3Sopenharmony_ci static bool RunFixedGatesCheck(const Circuit *circuit, const std::vector<GateRef> &fixedGatesList); 454514f5e3Sopenharmony_ci 464514f5e3Sopenharmony_ci static bool RunFixedGatesRelationsCheck(const Circuit *circuit, const std::vector<GateRef> &fixedGatesList, 474514f5e3Sopenharmony_ci const std::unordered_map<GateRef, size_t> &bbGatesAddrToIdx, 484514f5e3Sopenharmony_ci const std::function<bool(size_t, size_t)> &isAncestor); 494514f5e3Sopenharmony_ci 504514f5e3Sopenharmony_ci static bool RunFlowCyclesFind(const Circuit *circuit, std::vector<GateRef> *schedulableGatesListPtr, 514514f5e3Sopenharmony_ci const std::vector<GateRef> &bbGatesList, 524514f5e3Sopenharmony_ci const std::vector<GateRef> &fixedGatesList); 534514f5e3Sopenharmony_ci 544514f5e3Sopenharmony_ci static bool RunSchedulableGatesCheck(const Circuit *circuit, const std::vector<GateRef> &schedulableGatesList); 554514f5e3Sopenharmony_ci 564514f5e3Sopenharmony_ci static bool RunPrologGatesCheck(const Circuit *circuit, const std::vector<GateRef> &schedulableGatesList); 574514f5e3Sopenharmony_ci 584514f5e3Sopenharmony_ci static bool RunSchedulingBoundsCheck(const Circuit *circuit, const std::vector<GateRef> &schedulableGatesList, 594514f5e3Sopenharmony_ci const std::unordered_map<GateRef, size_t> &bbGatesAddrToIdx, 604514f5e3Sopenharmony_ci const std::function<bool(size_t, size_t)> &isAncestor, 614514f5e3Sopenharmony_ci const std::function<size_t(size_t, size_t)> &lowestCommonAncestor); 624514f5e3Sopenharmony_ci 634514f5e3Sopenharmony_ci static void FindFixedGates(const Circuit *circuit, const std::vector<GateRef> &bbGatesList, 644514f5e3Sopenharmony_ci std::vector<GateRef> &fixedGatesList); 654514f5e3Sopenharmony_ci 664514f5e3Sopenharmony_ci static bool RunFlowCyclesFind(const Circuit* circuit); 674514f5e3Sopenharmony_ci 684514f5e3Sopenharmony_ci static bool Run(const Circuit *circuit, const std::string& methodName = "", bool enableLog = false); 694514f5e3Sopenharmony_ci}; 704514f5e3Sopenharmony_ci} // namespace panda::ecmascript::kungfu 714514f5e3Sopenharmony_ci 724514f5e3Sopenharmony_ci#endif // ECMASCRIPT_COMPILER_VERIFIER_H 73