]>
git.saurik.com Git - apple/javascriptcore.git/blob - runtime/BasicBlockLocation.cpp
2 * Copyright (C) 2014 Apple Inc. All rights reserved.
3 * Copyright (C) 2014 Saam Barati. <saambarati1@gmail.com>
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
14 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
15 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
17 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
18 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
19 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
20 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
21 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
22 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
24 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 #include "BasicBlockLocation.h"
30 #include "CCallHelpers.h"
32 #include <wtf/DataLog.h>
36 BasicBlockLocation::BasicBlockLocation(int startOffset
, int endOffset
)
37 : m_startOffset(startOffset
)
38 , m_endOffset(endOffset
)
39 , m_hasExecuted(false)
43 void BasicBlockLocation::insertGap(int startOffset
, int endOffset
)
45 std::pair
<int, int> gap(startOffset
, endOffset
);
46 if (!m_gaps
.contains(gap
))
50 Vector
<std::pair
<int, int>> BasicBlockLocation::getExecutedRanges() const
53 Vector
<Gap
> gaps
= m_gaps
;
54 int nextRangeStart
= m_startOffset
;
56 Gap
minGap(INT_MAX
, 0);
57 unsigned minIdx
= std::numeric_limits
<unsigned>::max();
58 for (unsigned idx
= 0; idx
< gaps
.size(); idx
++) {
59 // Because we know that the Gaps inside m_gaps aren't enclosed within one another, it suffices to just check the first element to test ordering.
60 if (gaps
[idx
].first
< minGap
.first
) {
65 result
.append(Gap(nextRangeStart
, minGap
.first
- 1));
66 nextRangeStart
= minGap
.second
+ 1;
70 result
.append(Gap(nextRangeStart
, m_endOffset
));
74 void BasicBlockLocation::dumpData() const
76 Vector
<Gap
> executedRanges
= getExecutedRanges();
77 for (Gap gap
: executedRanges
)
78 dataLogF("\tBasicBlock: [%d, %d] hasExecuted: %s\n", gap
.first
, gap
.second
, hasExecuted() ? "true" : "false");
82 void BasicBlockLocation::emitExecuteCode(CCallHelpers
& jit
, MacroAssembler::RegisterID ptrReg
) const
84 jit
.move(CCallHelpers::TrustedImmPtr(&m_hasExecuted
), ptrReg
);
85 jit
.store8(CCallHelpers::TrustedImm32(true), CCallHelpers::Address(ptrReg
, 0));