2 * Copyright (C) 2013, 2016 Apple Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 #include "DFGAbstractValue.h"
31 #include "DFGBasicBlock.h"
32 #include "DFGBlockMap.h"
34 #include "DFGNodeFlowProjection.h"
36 namespace JSC { namespace DFG {
38 class AtTailAbstractState {
40 AtTailAbstractState(Graph&);
42 ~AtTailAbstractState();
44 explicit operator bool() const { return true; }
46 void initializeTo(BasicBlock* block)
51 void createValueForNode(NodeFlowProjection);
52 AbstractValue& forNode(NodeFlowProjection);
53 AbstractValue& forNode(Edge edge) { return forNode(edge.node()); }
54 Operands<AbstractValue>& variables() { return m_block->valuesAtTail; }
56 BasicBlock* block() const { return m_block; }
58 bool isValid() { return m_block->cfaDidFinish; }
60 StructureClobberState structureClobberState() const { return m_block->cfaStructureClobberStateAtTail; }
62 void setDidClobber(bool) { }
63 void setStructureClobberState(StructureClobberState state) { RELEASE_ASSERT(state == m_block->cfaStructureClobberStateAtTail); }
64 void setIsValid(bool isValid) { m_block->cfaDidFinish = isValid; }
65 void setBranchDirection(BranchDirection) { }
66 void setFoundConstants(bool) { }
68 void trustEdgeProofs() { m_trustEdgeProofs = true; }
69 void dontTrustEdgeProofs() { m_trustEdgeProofs = false; }
70 void setProofStatus(Edge& edge, ProofStatus status)
72 if (m_trustEdgeProofs)
73 edge.setProofStatus(status);
78 BlockMap<HashMap<NodeFlowProjection, AbstractValue>> m_valuesAtTailMap;
79 BasicBlock* m_block { nullptr };
80 bool m_trustEdgeProofs { false };
83 } } // namespace JSC::DFG
85 #endif // ENABLE(DFG_JIT)