/ bytecode / FullBytecodeLiveness.h
FullBytecodeLiveness.h
 1  /*
 2   * Copyright (C) 2013, 2015 Apple Inc. All rights reserved.
 3   *
 4   * Redistribution and use in source and binary forms, with or without
 5   * modification, are permitted provided that the following conditions
 6   * are met:
 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.
12   *
13   * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14   * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15   * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16   * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17   * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18   * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19   * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20   * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21   * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23   * THE POSSIBILITY OF SUCH DAMAGE.
24   */
25  
26  #pragma once
27  
28  #include "BytecodeLivenessAnalysis.h"
29  #include "Operands.h"
30  #include <wtf/FastBitVector.h>
31  
32  namespace JSC {
33  
34  class BytecodeLivenessAnalysis;
35  class CodeBlock;
36  
37  // Note: Full bytecode liveness does not track any information about the liveness of temps.
38  // If you want tmp liveness for a checkpoint ask tmpLivenessForCheckpoint.
39  class FullBytecodeLiveness {
40      WTF_MAKE_FAST_ALLOCATED;
41  public:
42      const FastBitVector& getLiveness(BytecodeIndex bytecodeIndex, LivenessCalculationPoint point) const
43      {
44          // We don't have to worry about overflowing into the next bytecodeoffset in our vectors because we
45          // static assert that bytecode length is greater than the number of checkpoints in BytecodeStructs.h
46          switch (point) {
47          case LivenessCalculationPoint::BeforeUse:
48              return m_usesBefore[toIndex(bytecodeIndex)];
49          case LivenessCalculationPoint::AfterUse:
50              return m_usesAfter[toIndex(bytecodeIndex)];
51          }
52          RELEASE_ASSERT_NOT_REACHED();
53      }
54      
55      bool virtualRegisterIsLive(VirtualRegister reg, BytecodeIndex bytecodeIndex, LivenessCalculationPoint point) const
56      {
57          return virtualRegisterIsAlwaysLive(reg) || virtualRegisterThatIsNotAlwaysLiveIsLive(getLiveness(bytecodeIndex, point), reg);
58      }
59      
60  private:
61      friend class BytecodeLivenessAnalysis;
62      
63      static size_t toIndex(BytecodeIndex bytecodeIndex) { return bytecodeIndex.offset() + bytecodeIndex.checkpoint(); }
64  
65      // FIXME: Use FastBitVector's view mechanism to make them compact.
66      // https://bugs.webkit.org/show_bug.cgi?id=204427
67      Vector<FastBitVector, 0, UnsafeVectorOverflow> m_usesBefore;
68      Vector<FastBitVector, 0, UnsafeVectorOverflow> m_usesAfter;
69  };
70  
71  } // namespace JSC