DFGCallCreateDirectArgumentsSlowPathGenerator.h [plain text]
#ifndef DFGCallCreateDirectArgumentsSlowPathGenerator_h
#define DFGCallCreateDirectArgumentsSlowPathGenerator_h
#if ENABLE(DFG_JIT)
#include "DFGCommon.h"
#include "DFGOperations.h"
#include "DFGSlowPathGenerator.h"
#include "DFGSpeculativeJIT.h"
#include "DirectArguments.h"
namespace JSC { namespace DFG {
class CallCreateDirectArgumentsSlowPathGenerator : public JumpingSlowPathGenerator<MacroAssembler::JumpList> {
public:
CallCreateDirectArgumentsSlowPathGenerator(
MacroAssembler::JumpList from, SpeculativeJIT* jit, GPRReg resultGPR, Structure* structure,
GPRReg lengthGPR, unsigned minCapacity)
: JumpingSlowPathGenerator<MacroAssembler::JumpList>(from, jit)
, m_resultGPR(resultGPR)
, m_structure(structure)
, m_lengthGPR(lengthGPR)
, m_minCapacity(minCapacity)
{
jit->silentSpillAllRegistersImpl(false, m_plans, resultGPR);
}
protected:
void generateInternal(SpeculativeJIT* jit) override
{
linkFrom(jit);
for (unsigned i = 0; i < m_plans.size(); ++i)
jit->silentSpill(m_plans[i]);
jit->callOperation(
operationCreateDirectArguments, m_resultGPR, m_structure, m_lengthGPR, m_minCapacity);
GPRReg canTrample = SpeculativeJIT::pickCanTrample(m_resultGPR);
for (unsigned i = m_plans.size(); i--;)
jit->silentFill(m_plans[i], canTrample);
jit->m_jit.loadPtr(
MacroAssembler::Address(m_resultGPR, DirectArguments::offsetOfLength()), m_lengthGPR);
jumpTo(jit);
}
private:
GPRReg m_resultGPR;
Structure* m_structure;
GPRReg m_lengthGPR;
unsigned m_minCapacity;
Vector<SilentRegisterSavePlan, 2> m_plans;
};
} }
#endif // ENABLE(DFG_JIT)
#endif // DFGCallCreateDirectArgumentsSlowPathGenerator_h