Commit 86d2545f authored by neis's avatar neis Committed by Commit bot

[cleanup] Minor cleanups concerning assemblers and code generation.

- Use Assembler in a few places that unneccessarily used MacroAssembler before.
- Fix some comments.

R=jarin@chromium.org
BUG=v8:6048

Review-Url: https://codereview.chromium.org/2843933002
Cr-Commit-Position: refs/heads/master@{#44894}
parent 6b4b0624
...@@ -325,7 +325,7 @@ class RelocInfo { ...@@ -325,7 +325,7 @@ class RelocInfo {
enum Mode { enum Mode {
// Please note the order is important (see IsCodeTarget, IsGCRelocMode). // Please note the order is important (see IsCodeTarget, IsGCRelocMode).
CODE_TARGET, // Code target which is not any of the above. CODE_TARGET,
CODE_TARGET_WITH_ID, CODE_TARGET_WITH_ID,
EMBEDDED_OBJECT, EMBEDDED_OBJECT,
// To relocate pointers into the wasm memory embedded in wasm code // To relocate pointers into the wasm memory embedded in wasm code
......
...@@ -69,24 +69,20 @@ UNARY_MATH_FUNCTION(sqrt, CreateSqrtFunction) ...@@ -69,24 +69,20 @@ UNARY_MATH_FUNCTION(sqrt, CreateSqrtFunction)
#undef UNARY_MATH_FUNCTION #undef UNARY_MATH_FUNCTION
#define __ ACCESS_MASM(masm_)
#ifdef DEBUG #ifdef DEBUG
Comment::Comment(MacroAssembler* masm, const char* msg) Comment::Comment(Assembler* assembler, const char* msg)
: masm_(masm), msg_(msg) { : assembler_(assembler), msg_(msg) {
__ RecordComment(msg); assembler_->RecordComment(msg);
} }
Comment::~Comment() { Comment::~Comment() {
if (msg_[0] == '[') __ RecordComment("]"); if (msg_[0] == '[') assembler_->RecordComment("]");
} }
#endif // DEBUG #endif // DEBUG
#undef __
void CodeGenerator::MakeCodePrologue(CompilationInfo* info, const char* kind) { void CodeGenerator::MakeCodePrologue(CompilationInfo* info, const char* kind) {
bool print_ast = false; bool print_ast = false;
......
...@@ -762,7 +762,7 @@ void CodeGenerator::AssemblePopArgumentsAdaptorFrame(Register args_reg, ...@@ -762,7 +762,7 @@ void CodeGenerator::AssemblePopArgumentsAdaptorFrame(Register args_reg,
namespace { namespace {
void AdjustStackPointerForTailCall(MacroAssembler* masm, void AdjustStackPointerForTailCall(Assembler* assembler,
FrameAccessState* state, FrameAccessState* state,
int new_slot_above_sp, int new_slot_above_sp,
bool allow_shrinkage = true) { bool allow_shrinkage = true) {
...@@ -770,10 +770,10 @@ void AdjustStackPointerForTailCall(MacroAssembler* masm, ...@@ -770,10 +770,10 @@ void AdjustStackPointerForTailCall(MacroAssembler* masm,
StandardFrameConstants::kFixedSlotCountAboveFp; StandardFrameConstants::kFixedSlotCountAboveFp;
int stack_slot_delta = new_slot_above_sp - current_sp_offset; int stack_slot_delta = new_slot_above_sp - current_sp_offset;
if (stack_slot_delta > 0) { if (stack_slot_delta > 0) {
masm->subq(rsp, Immediate(stack_slot_delta * kPointerSize)); assembler->subq(rsp, Immediate(stack_slot_delta * kPointerSize));
state->IncreaseSPDelta(stack_slot_delta); state->IncreaseSPDelta(stack_slot_delta);
} else if (allow_shrinkage && stack_slot_delta < 0) { } else if (allow_shrinkage && stack_slot_delta < 0) {
masm->addq(rsp, Immediate(-stack_slot_delta * kPointerSize)); assembler->addq(rsp, Immediate(-stack_slot_delta * kPointerSize));
state->IncreaseSPDelta(stack_slot_delta); state->IncreaseSPDelta(stack_slot_delta);
} }
} }
......
...@@ -148,22 +148,22 @@ class FrameAndConstantPoolScope { ...@@ -148,22 +148,22 @@ class FrameAndConstantPoolScope {
// Class for scoping the the unavailability of constant pool access. // Class for scoping the the unavailability of constant pool access.
class ConstantPoolUnavailableScope { class ConstantPoolUnavailableScope {
public: public:
explicit ConstantPoolUnavailableScope(MacroAssembler* masm) explicit ConstantPoolUnavailableScope(Assembler* assembler)
: masm_(masm), : assembler_(assembler),
old_constant_pool_available_(FLAG_enable_embedded_constant_pool && old_constant_pool_available_(FLAG_enable_embedded_constant_pool &&
masm->is_constant_pool_available()) { assembler->is_constant_pool_available()) {
if (FLAG_enable_embedded_constant_pool) { if (FLAG_enable_embedded_constant_pool) {
masm_->set_constant_pool_available(false); assembler->set_constant_pool_available(false);
} }
} }
~ConstantPoolUnavailableScope() { ~ConstantPoolUnavailableScope() {
if (FLAG_enable_embedded_constant_pool) { if (FLAG_enable_embedded_constant_pool) {
masm_->set_constant_pool_available(old_constant_pool_available_); assembler_->set_constant_pool_available(old_constant_pool_available_);
} }
} }
private: private:
MacroAssembler* masm_; Assembler* assembler_;
int old_constant_pool_available_; int old_constant_pool_available_;
DISALLOW_IMPLICIT_CONSTRUCTORS(ConstantPoolUnavailableScope); DISALLOW_IMPLICIT_CONSTRUCTORS(ConstantPoolUnavailableScope);
...@@ -199,11 +199,11 @@ class NoCurrentFrameScope { ...@@ -199,11 +199,11 @@ class NoCurrentFrameScope {
class Comment { class Comment {
public: public:
Comment(MacroAssembler* masm, const char* msg); Comment(Assembler* assembler, const char* msg);
~Comment(); ~Comment();
private: private:
MacroAssembler* masm_; Assembler* assembler_;
const char* msg_; const char* msg_;
}; };
...@@ -211,7 +211,7 @@ class Comment { ...@@ -211,7 +211,7 @@ class Comment {
class Comment { class Comment {
public: public:
Comment(MacroAssembler*, const char*) {} Comment(Assembler*, const char*) {}
}; };
#endif // DEBUG #endif // DEBUG
......
...@@ -13988,7 +13988,6 @@ void Code::CopyFrom(const CodeDesc& desc) { ...@@ -13988,7 +13988,6 @@ void Code::CopyFrom(const CodeDesc& desc) {
static_cast<size_t>(desc.reloc_size)); static_cast<size_t>(desc.reloc_size));
// unbox handles and relocate // unbox handles and relocate
intptr_t delta = instruction_start() - desc.buffer;
int mode_mask = RelocInfo::kCodeTargetMask | int mode_mask = RelocInfo::kCodeTargetMask |
RelocInfo::ModeMask(RelocInfo::EMBEDDED_OBJECT) | RelocInfo::ModeMask(RelocInfo::EMBEDDED_OBJECT) |
RelocInfo::ModeMask(RelocInfo::CELL) | RelocInfo::ModeMask(RelocInfo::CELL) |
...@@ -14008,8 +14007,8 @@ void Code::CopyFrom(const CodeDesc& desc) { ...@@ -14008,8 +14007,8 @@ void Code::CopyFrom(const CodeDesc& desc) {
it.rinfo()->set_target_cell(*cell, UPDATE_WRITE_BARRIER, it.rinfo()->set_target_cell(*cell, UPDATE_WRITE_BARRIER,
SKIP_ICACHE_FLUSH); SKIP_ICACHE_FLUSH);
} else if (RelocInfo::IsCodeTarget(mode)) { } else if (RelocInfo::IsCodeTarget(mode)) {
// rewrite code handles in inline cache targets to direct // rewrite code handles to direct pointers to the first instruction in the
// pointers to the first instruction in the code object // code object
Handle<Object> p = it.rinfo()->target_object_handle(origin); Handle<Object> p = it.rinfo()->target_object_handle(origin);
Code* code = Code::cast(*p); Code* code = Code::cast(*p);
it.rinfo()->set_target_address(GetIsolate(), code->instruction_start(), it.rinfo()->set_target_address(GetIsolate(), code->instruction_start(),
...@@ -14023,6 +14022,7 @@ void Code::CopyFrom(const CodeDesc& desc) { ...@@ -14023,6 +14022,7 @@ void Code::CopyFrom(const CodeDesc& desc) {
Code* code = Code::cast(*p); Code* code = Code::cast(*p);
it.rinfo()->set_code_age_stub(code, SKIP_ICACHE_FLUSH); it.rinfo()->set_code_age_stub(code, SKIP_ICACHE_FLUSH);
} else { } else {
intptr_t delta = instruction_start() - desc.buffer;
it.rinfo()->apply(delta); it.rinfo()->apply(delta);
} }
} }
......
...@@ -3525,10 +3525,9 @@ TYPED_ARRAYS(FIXED_TYPED_ARRAY_TRAITS) ...@@ -3525,10 +3525,9 @@ TYPED_ARRAYS(FIXED_TYPED_ARRAY_TRAITS)
#undef FIXED_TYPED_ARRAY_TRAITS #undef FIXED_TYPED_ARRAY_TRAITS
// DeoptimizationInputData is a fixed array used to hold the deoptimization // DeoptimizationInputData is a fixed array used to hold the deoptimization
// data for code generated by the Hydrogen/Lithium compiler. It also // data for optimized code. It also contains information about functions that
// contains information about functions that were inlined. If N different // were inlined. If N different functions were inlined then first N elements of
// functions were inlined then first N elements of the literal array will // the literal array will contain these functions.
// contain these functions.
// //
// It can be empty. // It can be empty.
class DeoptimizationInputData: public FixedArray { class DeoptimizationInputData: public FixedArray {
......
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