ExecutionCounter.h 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /*
  2. * Copyright (C) 2012 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. #ifndef ExecutionCounter_h
  26. #define ExecutionCounter_h
  27. #include "JSGlobalObject.h"
  28. #include "Options.h"
  29. #include <wtf/PrintStream.h>
  30. #include <wtf/SimpleStats.h>
  31. namespace JSC {
  32. class CodeBlock;
  33. class ExecutionCounter {
  34. public:
  35. ExecutionCounter();
  36. bool checkIfThresholdCrossedAndSet(CodeBlock*);
  37. void setNewThreshold(int32_t threshold, CodeBlock*);
  38. void deferIndefinitely();
  39. double count() const { return static_cast<double>(m_totalCount) + m_counter; }
  40. void dump(PrintStream&) const;
  41. static double applyMemoryUsageHeuristics(int32_t value, CodeBlock*);
  42. static int32_t applyMemoryUsageHeuristicsAndConvertToInt(int32_t value, CodeBlock*);
  43. template<typename T>
  44. static T clippedThreshold(JSGlobalObject* globalObject, T threshold)
  45. {
  46. int32_t maxThreshold;
  47. if (Options::randomizeExecutionCountsBetweenCheckpoints())
  48. maxThreshold = globalObject->weakRandomInteger() % Options::maximumExecutionCountsBetweenCheckpoints();
  49. else
  50. maxThreshold = Options::maximumExecutionCountsBetweenCheckpoints();
  51. if (threshold > maxThreshold)
  52. threshold = maxThreshold;
  53. return threshold;
  54. }
  55. static int32_t formattedTotalCount(float value)
  56. {
  57. union {
  58. int32_t i;
  59. float f;
  60. } u;
  61. u.f = value;
  62. return u.i;
  63. }
  64. private:
  65. bool hasCrossedThreshold(CodeBlock*) const;
  66. bool setThreshold(CodeBlock*);
  67. void reset();
  68. public:
  69. // NB. These are intentionally public because it will be modified from machine code.
  70. // This counter is incremented by the JIT or LLInt. It starts out negative and is
  71. // counted up until it becomes non-negative. At the start of a counting period,
  72. // the threshold we wish to reach is m_totalCount + m_counter, in the sense that
  73. // we will add X to m_totalCount and subtract X from m_counter.
  74. int32_t m_counter;
  75. // Counts the total number of executions we have seen plus the ones we've set a
  76. // threshold for in m_counter. Because m_counter's threshold is negative, the
  77. // total number of actual executions can always be computed as m_totalCount +
  78. // m_counter.
  79. float m_totalCount;
  80. // This is the threshold we were originally targetting, without any correction for
  81. // the memory usage heuristics.
  82. int32_t m_activeThreshold;
  83. };
  84. } // namespace JSC
  85. #endif // ExecutionCounter_h