Commit 0aeaf0cb authored by mstarzinger's avatar mstarzinger Committed by Commit bot

Move SourcePosition into separate header file.

This splits out the SourcePosition class into a separate header file.
Reason for this refactoring is that said class is mostly used by the
Crankshaft compiler and not needed for all compilers. Also having the
assembler depend on the class creates a dependency cycle.

R=bmeurer@chromium.org

Review URL: https://codereview.chromium.org/1581083009

Cr-Commit-Position: refs/heads/master@{#33325}
parent a89d41f0
...@@ -1262,6 +1262,7 @@ source_set("v8_base") { ...@@ -1262,6 +1262,7 @@ source_set("v8_base") {
"src/snapshot/snapshot-common.cc", "src/snapshot/snapshot-common.cc",
"src/snapshot/snapshot-source-sink.cc", "src/snapshot/snapshot-source-sink.cc",
"src/snapshot/snapshot-source-sink.h", "src/snapshot/snapshot-source-sink.h",
"src/source-position.h",
"src/splay-tree.h", "src/splay-tree.h",
"src/splay-tree-inl.h", "src/splay-tree-inl.h",
"src/snapshot/snapshot.h", "src/snapshot/snapshot.h",
......
...@@ -1336,7 +1336,7 @@ class Assembler : public AssemblerBase { ...@@ -1336,7 +1336,7 @@ class Assembler : public AssemblerBase {
// Record a deoptimization reason that can be used by a log or cpu profiler. // Record a deoptimization reason that can be used by a log or cpu profiler.
// Use --trace-deopt to enable. // Use --trace-deopt to enable.
void RecordDeoptReason(const int reason, const SourcePosition position); void RecordDeoptReason(const int reason, int raw_position);
// Record the emission of a constant pool. // Record the emission of a constant pool.
// //
......
...@@ -925,7 +925,7 @@ class Assembler : public AssemblerBase { ...@@ -925,7 +925,7 @@ class Assembler : public AssemblerBase {
// Record a deoptimization reason that can be used by a log or cpu profiler. // Record a deoptimization reason that can be used by a log or cpu profiler.
// Use --trace-deopt to enable. // Use --trace-deopt to enable.
void RecordDeoptReason(const int reason, const SourcePosition position); void RecordDeoptReason(const int reason, int raw_position);
int buffer_space() const; int buffer_space() const;
......
...@@ -1837,11 +1837,9 @@ int ConstantPoolBuilder::Emit(Assembler* assm) { ...@@ -1837,11 +1837,9 @@ int ConstantPoolBuilder::Emit(Assembler* assm) {
// Platform specific but identical code for all the platforms. // Platform specific but identical code for all the platforms.
void Assembler::RecordDeoptReason(const int reason, void Assembler::RecordDeoptReason(const int reason, int raw_position) {
const SourcePosition position) {
if (FLAG_trace_deopt || isolate()->cpu_profiler()->is_profiling()) { if (FLAG_trace_deopt || isolate()->cpu_profiler()->is_profiling()) {
EnsureSpace ensure_space(this); EnsureSpace ensure_space(this);
int raw_position = position.IsUnknown() ? 0 : position.raw();
RecordRelocInfo(RelocInfo::POSITION, raw_position); RecordRelocInfo(RelocInfo::POSITION, raw_position);
RecordRelocInfo(RelocInfo::DEOPT_REASON, reason); RecordRelocInfo(RelocInfo::DEOPT_REASON, reason);
} }
......
...@@ -49,7 +49,6 @@ class ApiFunction; ...@@ -49,7 +49,6 @@ class ApiFunction;
namespace internal { namespace internal {
// Forward declarations. // Forward declarations.
class SourcePosition;
class StatsCounter; class StatsCounter;
// ----------------------------------------------------------------------------- // -----------------------------------------------------------------------------
......
...@@ -37,16 +37,6 @@ ...@@ -37,16 +37,6 @@
namespace v8 { namespace v8 {
namespace internal { namespace internal {
std::ostream& operator<<(std::ostream& os, const SourcePosition& p) {
if (p.IsUnknown()) {
return os << "<?>";
} else if (FLAG_hydrogen_track_positions) {
return os << "<" << p.inlining_id() << ":" << p.position() << ">";
} else {
return os << "<0:" << p.raw() << ">";
}
}
#define PARSE_INFO_GETTER(type, name) \ #define PARSE_INFO_GETTER(type, name) \
type CompilationInfo::name() const { \ type CompilationInfo::name() const { \
......
...@@ -10,79 +10,18 @@ ...@@ -10,79 +10,18 @@
#include "src/bailout-reason.h" #include "src/bailout-reason.h"
#include "src/compilation-dependencies.h" #include "src/compilation-dependencies.h"
#include "src/signature.h" #include "src/signature.h"
#include "src/source-position.h"
#include "src/zone.h" #include "src/zone.h"
namespace v8 { namespace v8 {
namespace internal { namespace internal {
class AstValueFactory; // Forward declarations.
class HydrogenCodeStub;
class JavaScriptFrame; class JavaScriptFrame;
class ParseInfo; class ParseInfo;
class ScriptData; class ScriptData;
// This class encapsulates encoding and decoding of sources positions from
// which hydrogen values originated.
// When FLAG_track_hydrogen_positions is set this object encodes the
// identifier of the inlining and absolute offset from the start of the
// inlined function.
// When the flag is not set we simply track absolute offset from the
// script start.
class SourcePosition {
public:
static SourcePosition Unknown() {
return SourcePosition::FromRaw(kNoPosition);
}
bool IsUnknown() const { return value_ == kNoPosition; }
uint32_t position() const { return PositionField::decode(value_); }
void set_position(uint32_t position) {
if (FLAG_hydrogen_track_positions) {
value_ = static_cast<uint32_t>(PositionField::update(value_, position));
} else {
value_ = position;
}
}
uint32_t inlining_id() const { return InliningIdField::decode(value_); }
void set_inlining_id(uint32_t inlining_id) {
if (FLAG_hydrogen_track_positions) {
value_ =
static_cast<uint32_t>(InliningIdField::update(value_, inlining_id));
}
}
uint32_t raw() const { return value_; }
private:
static const uint32_t kNoPosition =
static_cast<uint32_t>(RelocInfo::kNoPosition);
typedef BitField<uint32_t, 0, 9> InliningIdField;
// Offset from the start of the inlined function.
typedef BitField<uint32_t, 9, 23> PositionField;
friend class HPositionInfo;
friend class Deoptimizer;
static SourcePosition FromRaw(uint32_t raw_position) {
SourcePosition position;
position.value_ = raw_position;
return position;
}
// If FLAG_hydrogen_track_positions is set contains bitfields InliningIdField
// and PositionField.
// Otherwise contains absolute offset from the script start.
uint32_t value_;
};
std::ostream& operator<<(std::ostream& os, const SourcePosition& p);
struct InlinedFunctionInfo { struct InlinedFunctionInfo {
InlinedFunctionInfo(int parent_id, SourcePosition inline_position, InlinedFunctionInfo(int parent_id, SourcePosition inline_position,
int script_id, int start_position) int script_id, int start_position)
......
...@@ -154,7 +154,9 @@ void LCodeGenBase::Comment(const char* format, ...) { ...@@ -154,7 +154,9 @@ void LCodeGenBase::Comment(const char* format, ...) {
void LCodeGenBase::DeoptComment(const Deoptimizer::DeoptInfo& deopt_info) { void LCodeGenBase::DeoptComment(const Deoptimizer::DeoptInfo& deopt_info) {
masm()->RecordDeoptReason(deopt_info.deopt_reason, deopt_info.position); SourcePosition position = deopt_info.position;
int raw_position = position.IsUnknown() ? 0 : position.raw();
masm()->RecordDeoptReason(deopt_info.deopt_reason, raw_position);
} }
......
...@@ -1408,7 +1408,7 @@ class Assembler : public AssemblerBase { ...@@ -1408,7 +1408,7 @@ class Assembler : public AssemblerBase {
// Record a deoptimization reason that can be used by a log or cpu profiler. // Record a deoptimization reason that can be used by a log or cpu profiler.
// Use --trace-deopt to enable. // Use --trace-deopt to enable.
void RecordDeoptReason(const int reason, const SourcePosition position); void RecordDeoptReason(const int reason, int raw_position);
// Writes a single byte or word of data in the code stream. Used for // Writes a single byte or word of data in the code stream. Used for
// inline tables, e.g., jump-tables. // inline tables, e.g., jump-tables.
......
...@@ -1035,7 +1035,7 @@ class Assembler : public AssemblerBase { ...@@ -1035,7 +1035,7 @@ class Assembler : public AssemblerBase {
// Record a deoptimization reason that can be used by a log or cpu profiler. // Record a deoptimization reason that can be used by a log or cpu profiler.
// Use --trace-deopt to enable. // Use --trace-deopt to enable.
void RecordDeoptReason(const int reason, const SourcePosition position); void RecordDeoptReason(const int reason, int raw_position);
static int RelocateInternalReference(RelocInfo::Mode rmode, byte* pc, static int RelocateInternalReference(RelocInfo::Mode rmode, byte* pc,
......
...@@ -1092,7 +1092,7 @@ class Assembler : public AssemblerBase { ...@@ -1092,7 +1092,7 @@ class Assembler : public AssemblerBase {
// Record a deoptimization reason that can be used by a log or cpu profiler. // Record a deoptimization reason that can be used by a log or cpu profiler.
// Use --trace-deopt to enable. // Use --trace-deopt to enable.
void RecordDeoptReason(const int reason, const SourcePosition position); void RecordDeoptReason(const int reason, int raw_position);
static int RelocateInternalReference(RelocInfo::Mode rmode, byte* pc, static int RelocateInternalReference(RelocInfo::Mode rmode, byte* pc,
intptr_t pc_delta); intptr_t pc_delta);
......
...@@ -1203,7 +1203,7 @@ class Assembler : public AssemblerBase { ...@@ -1203,7 +1203,7 @@ class Assembler : public AssemblerBase {
// Record a deoptimization reason that can be used by a log or cpu profiler. // Record a deoptimization reason that can be used by a log or cpu profiler.
// Use --trace-deopt to enable. // Use --trace-deopt to enable.
void RecordDeoptReason(const int reason, const SourcePosition position); void RecordDeoptReason(const int reason, int raw_position);
// Writes a single byte or word of data in the code stream. Used // Writes a single byte or word of data in the code stream. Used
// for inline tables, e.g., jump-tables. // for inline tables, e.g., jump-tables.
......
// Copyright 2016 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef V8_SOURCE_POSITION_H_
#define V8_SOURCE_POSITION_H_
#include <ostream>
#include "src/assembler.h"
#include "src/flags.h"
#include "src/utils.h"
namespace v8 {
namespace internal {
// This class encapsulates encoding and decoding of sources positions from
// which hydrogen values originated.
// When FLAG_track_hydrogen_positions is set this object encodes the
// identifier of the inlining and absolute offset from the start of the
// inlined function.
// When the flag is not set we simply track absolute offset from the
// script start.
class SourcePosition {
public:
static SourcePosition Unknown() {
return SourcePosition::FromRaw(kNoPosition);
}
bool IsUnknown() const { return value_ == kNoPosition; }
uint32_t position() const { return PositionField::decode(value_); }
void set_position(uint32_t position) {
if (FLAG_hydrogen_track_positions) {
value_ = static_cast<uint32_t>(PositionField::update(value_, position));
} else {
value_ = position;
}
}
uint32_t inlining_id() const { return InliningIdField::decode(value_); }
void set_inlining_id(uint32_t inlining_id) {
if (FLAG_hydrogen_track_positions) {
value_ =
static_cast<uint32_t>(InliningIdField::update(value_, inlining_id));
}
}
uint32_t raw() const { return value_; }
private:
static const uint32_t kNoPosition =
static_cast<uint32_t>(RelocInfo::kNoPosition);
typedef BitField<uint32_t, 0, 9> InliningIdField;
// Offset from the start of the inlined function.
typedef BitField<uint32_t, 9, 23> PositionField;
friend class HPositionInfo;
friend class Deoptimizer;
static SourcePosition FromRaw(uint32_t raw_position) {
SourcePosition position;
position.value_ = raw_position;
return position;
}
// If FLAG_hydrogen_track_positions is set contains bitfields InliningIdField
// and PositionField.
// Otherwise contains absolute offset from the script start.
uint32_t value_;
};
inline std::ostream& operator<<(std::ostream& os, const SourcePosition& p) {
if (p.IsUnknown()) {
return os << "<?>";
} else if (FLAG_hydrogen_track_positions) {
return os << "<" << p.inlining_id() << ":" << p.position() << ">";
} else {
return os << "<0:" << p.raw() << ">";
}
}
} // namespace internal
} // namespace v8
#endif // V8_SOURCE_POSITION_H_
...@@ -1660,7 +1660,7 @@ class Assembler : public AssemblerBase { ...@@ -1660,7 +1660,7 @@ class Assembler : public AssemblerBase {
// Record a deoptimization reason that can be used by a log or cpu profiler. // Record a deoptimization reason that can be used by a log or cpu profiler.
// Use --trace-deopt to enable. // Use --trace-deopt to enable.
void RecordDeoptReason(const int reason, const SourcePosition position); void RecordDeoptReason(const int reason, int raw_position);
void PatchConstantPoolAccessInstruction(int pc_offset, int offset, void PatchConstantPoolAccessInstruction(int pc_offset, int offset,
ConstantPoolEntry::Access access, ConstantPoolEntry::Access access,
......
...@@ -935,7 +935,7 @@ class Assembler : public AssemblerBase { ...@@ -935,7 +935,7 @@ class Assembler : public AssemblerBase {
// Record a deoptimization reason that can be used by a log or cpu profiler. // Record a deoptimization reason that can be used by a log or cpu profiler.
// Use --trace-deopt to enable. // Use --trace-deopt to enable.
void RecordDeoptReason(const int reason, const SourcePosition position); void RecordDeoptReason(const int reason, int raw_position);
// Writes a single byte or word of data in the code stream. Used for // Writes a single byte or word of data in the code stream. Used for
// inline tables, e.g., jump-tables. // inline tables, e.g., jump-tables.
......
...@@ -1033,6 +1033,7 @@ ...@@ -1033,6 +1033,7 @@
'../../src/snapshot/snapshot-common.cc', '../../src/snapshot/snapshot-common.cc',
'../../src/snapshot/snapshot-source-sink.cc', '../../src/snapshot/snapshot-source-sink.cc',
'../../src/snapshot/snapshot-source-sink.h', '../../src/snapshot/snapshot-source-sink.h',
'../../src/source-position.h',
'../../src/splay-tree.h', '../../src/splay-tree.h',
'../../src/splay-tree-inl.h', '../../src/splay-tree-inl.h',
'../../src/startup-data-util.cc', '../../src/startup-data-util.cc',
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment