0267788ffeff2667e72b8b112bcf513333511939
[WebKit-https.git] / Source / JavaScriptCore / ftl / FTLWeight.h
1 /*
2  * Copyright (C) 2014 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. ``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. 
24  */
25
26 #ifndef FTLWeight_h
27 #define FTLWeight_h
28
29 #if ENABLE(FTL_JIT)
30
31 #include "B3FrequencyClass.h"
32 #include <wtf/MathExtras.h>
33 #include <wtf/StdLibExtras.h>
34
35 namespace JSC { namespace FTL {
36
37 class Weight {
38 public:
39     Weight()
40         : m_value(std::numeric_limits<float>::quiet_NaN())
41     {
42     }
43     
44     explicit Weight(float value)
45         : m_value(value)
46     {
47     }
48     
49     bool isSet() const { return m_value == m_value; }
50     bool operator!() const { return !isSet(); }
51     
52     float value() const { return m_value; }
53
54     B3::FrequencyClass frequencyClass() const { return value() ? B3::FrequencyClass::Normal : B3::FrequencyClass::Rare; }
55     
56     unsigned scaleToTotal(double total) const
57     {
58         // LLVM accepts 32-bit unsigned branch weights but in dumps it might display them
59         // as signed values. We don't need all 32 bits, so we just use the 31 bits.
60         double result = static_cast<double>(m_value) * INT_MAX / total;
61         if (result < 0)
62             return 0;
63         if (result > INT_MAX)
64             return INT_MAX;
65         return static_cast<unsigned>(result);
66     }
67     
68     // Inverse weight for a two-target branch.
69     Weight inverse() const
70     {
71         if (!isSet())
72             return Weight();
73         if (value())
74             return Weight(0);
75         return Weight(1);
76     }
77     
78 private:
79     float m_value;
80 };
81
82 } } // namespace JSC::FTL
83
84 #endif // ENABLE(FTL_JIT)
85
86 #endif // FTLWeight_h
87