// Copyright 2015, VIXL authors
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// * Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// * Neither the name of ARM Limited nor the names of its contributors may be
// used to endorse or promote products derived from this software without
// specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS CONTRIBUTORS "AS IS" AND
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
// FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
// DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
// SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
// CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
// OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#ifndef VIXL_AARCH32_ASSEMBLER_AARCH32_H_
#define VIXL_AARCH32_ASSEMBLER_AARCH32_H_
#include "assembler-base-vixl.h"
#include "aarch32/instructions-aarch32.h"
#include "aarch32/label-aarch32.h"
namespace vixl {
namespace aarch32 {
class Assembler : public internal::AssemblerBase {
InstructionSet isa_;
Condition first_condition_;
uint16_t it_mask_;
bool has_32_dregs_;
bool allow_unpredictable_;
bool allow_strongly_discouraged_;
protected:
void EmitT32_16(uint16_t instr);
void EmitT32_32(uint32_t instr);
void EmitA32(uint32_t instr);
// Check that the condition of the current instruction is consistent with the
// IT state.
void CheckIT(Condition condition) {
#ifdef VIXL_DEBUG
PerformCheckIT(condition);
#else
USE(condition);
#endif
}
#ifdef VIXL_DEBUG
void PerformCheckIT(Condition condition);
#endif
void AdvanceIT() { it_mask_ = (it_mask_ << 1) & 0xf; }
void BindHelper(Label* label);
void PlaceHelper(RawLiteral* literal) {
BindHelper(literal);
GetBuffer()->EmitData(literal->GetDataAddress(), literal->GetSize());
}
uint32_t Link(uint32_t instr,
Label* label,
const Label::LabelEmitOperator& op);
public:
class AllowUnpredictableScope {
Assembler* assembler_;
bool old_;
public:
explicit AllowUnpredictableScope(Assembler* assembler)
: assembler_(assembler), old_(assembler->allow_unpredictable_) {
assembler_->allow_unpredictable_ = true;
}
~AllowUnpredictableScope() { assembler_->allow_unpredictable_ = old_; }
};
class AllowStronglyDiscouragedScope {
Assembler* assembler_;
bool old_;
public:
explicit AllowStronglyDiscouragedScope(Assembler* assembler)
: assembler_(assembler), old_(assembler->allow_strongly_discouraged_) {
assembler_->allow_strongly_discouraged_ = true;
}
~AllowStronglyDiscouragedScope() {
assembler_->allow_strongly_discouraged_ = old_;
}
};
explicit Assembler(InstructionSet isa = kDefaultISA)
: isa_(isa),
first_condition_(al),
it_mask_(0),
has_32_dregs_(true),
allow_unpredictable_(false),
allow_strongly_discouraged_(false) {
#if defined(VIXL_INCLUDE_TARGET_A32_ONLY)
// Avoid compiler warning.
USE(isa_);
VIXL_ASSERT(isa == A32);
#elif defined(VIXL_INCLUDE_TARGET_T32_ONLY)
USE(isa_);
VIXL_ASSERT(isa == T32);
#endif
}
explicit Assembler(size_t capacity, InstructionSet isa = kDefaultISA)
: AssemblerBase(capacity),
isa_(isa),
first_condition_(al),
it_mask_(0),
has_32_dregs_(true),
allow_unpredictable_(false),
allow_strongly_discouraged_(false) {
#if defined(VIXL_INCLUDE_TARGET_A32_ONLY)
VIXL_ASSERT(isa == A32);
#elif defined(VIXL_INCLUDE_TARGET_T32_ONLY)
VIXL_ASSERT(isa == T32);
#endif
}
Assembler(byte* buffer, size_t capacity, InstructionSet isa = kDefaultISA)
: AssemblerBase(buffer, capacity),
isa_(isa),
first_condition_(al),
it_mask_(0),
has_32_dregs_(true),
allow_unpredictable_(false),
allow_strongly_discouraged_(false) {
#if defined(VIXL_INCLUDE_TARGET_A32_ONLY)
VIXL_ASSERT(isa == A32);
#elif defined(VIXL_INCLUDE_TARGET_T32_ONLY)
VIXL_ASSERT(isa == T32);
#endif
}
virtual ~Assembler() {}
void UseInstructionSet(InstructionSet isa) {
#if defined(VIXL_INCLUDE_TARGET_A32_ONLY)
USE(isa);
VIXL_ASSERT(isa == A32);
#elif defined(VIXL_INCLUDE_TARGET_T32_ONLY)
USE(isa);
VIXL_ASSERT(isa == T32);
#else
VIXL_ASSERT((isa_ == isa) || (GetCursorOffset() == 0));
isa_ = isa;
#endif
}
#if defined(VIXL_INCLUDE_TARGET_A32_ONLY)
InstructionSet GetInstructionSetInUse() const { return A32; }
#elif defined(VIXL_INCLUDE_TARGET_T32_ONLY)
InstructionSet GetInstructionSetInUse() const { return T32; }
#else
InstructionSet GetInstructionSetInUse() const { return isa_; }
#endif
void UseT32() { UseInstructionSet(T32); }
void UseA32() { UseInstructionSet(A32); }
bool IsUsingT32() const { return GetInstructionSetInUse() == T32; }
bool IsUsingA32() const { return GetInstructionSetInUse() == A32; }
void SetIT(Condition first_condition, uint16_t it_mask) {
VIXL_ASSERT(it_mask_ == 0);
first_condition_ = first_condition;
it_mask_ = it_mask;
}
bool Is16BitEncoding(uint16_t instr) const {
VIXL_ASSERT(IsUsingT32());
return instr < 0xe800;
}
bool InITBlock() { return it_mask_ != 0; }
bool OutsideITBlock() { return it_mask_ == 0; }
bool OutsideITBlockOrLast() { return (it_mask_ == 0) || (it_mask_ == 0x8); }
bool OutsideITBlockAndAlOrLast(Condition cond) {
return ((it_mask_ == 0) && cond.Is(al)) || (it_mask_ == 0x8);
}
void CheckNotIT() { VIXL_ASSERT(it_mask_ == 0); }
bool Has32DRegs() const { return has_32_dregs_; }
void SetHas32DRegs(bool has_32_dregs) { has_32_dregs_ = has_32_dregs; }
int32_t GetCursorOffset() const {
ptrdiff_t offset = buffer_.GetCursorOffset();
VIXL_ASSERT(IsInt32(offset));
return static_cast<int32_t>(offset);
}
uint32_t GetArchitectureStatePCOffset() const { return IsUsingT32() ? 4 : 8; }
void bind(Label* label) {
VIXL_ASSERT(AllowAssembler());
BindHelper(label);
}
void place(RawLiteral* literal) {
VIXL_ASSERT(AllowAssembler());
VIXL_ASSERT(literal->IsManuallyPlaced());
PlaceHelper(literal);
}
size_t GetSizeOfCodeGeneratedSince(Label* label) const {
VIXL_ASSERT(label->IsBound());
return buffer_.GetOffsetFrom(label->GetLocation());
}
void EncodeLabelFor(const Label::ForwardReference& forward, Label* label);
// Helpers for it instruction.
void it(Condition cond) { it(cond, 0x8); }
void itt(Condition cond) { it(cond, 0x4); }
void ite(Condition cond) { it(cond, 0xc); }
void ittt(Condition cond) { it(cond, 0x2); }
void itet(Condition cond) { it(cond, 0xa); }
void itte(Condition cond) { it(cond, 0x6); }
void itee(Condition cond) { it(cond, 0xe); }
void itttt(Condition cond) { it(cond, 0x1); }
void itett(Condition cond) { it(cond, 0x9); }
void ittet(Condition cond) { it(cond, 0x5); }
void iteet(Condition cond) { it(cond, 0xd); }
void ittte(Condition cond) { it(cond, 0x3); }
void itete(Condition cond) { it(cond, 0xb); }
void ittee(Condition cond) { it(cond, 0x7); }
void iteee(Condition cond) { it(cond, 0xf); }
// Start of generated code.
typedef void (Assembler::*InstructionCondSizeRROp)(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
typedef void (Assembler::*InstructionCondROp)(Condition cond,
Register rd,
const Operand& operand);
typedef void (Assembler::*InstructionROp)(Register rd,
const Operand& operand);
typedef void (Assembler::*InstructionCondRROp)(Condition cond,
Register rd,
Register rn,
const Operand& operand);
typedef void (Assembler::*InstructionCondSizeRL)(Condition cond,
EncodingSize size,
Register rd,
Label* label);
typedef void (Assembler::*InstructionCondSizeL)(Condition cond,
EncodingSize size,
Label* label);
typedef void (Assembler::*InstructionCondRIOp)(Condition cond,
Register rd,
uint32_t lsb,
const Operand& operand);
typedef void (Assembler::*InstructionCondRRIOp)(Condition cond,
Register rd,
Register rn,
uint32_t lsb,
const Operand& operand);
typedef void (Assembler::*InstructionCondI)(Condition cond, uint32_t imm);
typedef void (Assembler::*InstructionCondL)(Condition cond, Label* label);
typedef void (Assembler::*InstructionCondR)(Condition cond, Register rm);
typedef void (Assembler::*InstructionRL)(Register rn, Label* label);
typedef void (Assembler::*InstructionCond)(Condition cond);
typedef void (Assembler::*InstructionCondRR)(Condition cond,
Register rd,
Register rm);
typedef void (Assembler::*InstructionCondSizeROp)(Condition cond,
EncodingSize size,
Register rn,
const Operand& operand);
typedef void (Assembler::*InstructionCondRRR)(Condition cond,
Register rd,
Register rn,
Register rm);
typedef void (Assembler::*InstructionCondBa)(Condition cond,
MemoryBarrier option);
typedef void (Assembler::*InstructionCondRwbDrl)(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
typedef void (Assembler::*InstructionCondRMop)(Condition cond,
Register rt,
const MemOperand& operand);
typedef void (Assembler::*InstructionCondRRMop)(Condition cond,
Register rt,
Register rt2,
const MemOperand& operand);
typedef void (Assembler::*InstructionCondSizeRwbRl)(Condition cond,
EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers);
typedef void (Assembler::*InstructionCondRwbRl)(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
typedef void (Assembler::*InstructionCondSizeRMop)(Condition cond,
EncodingSize size,
Register rt,
const MemOperand& operand);
typedef void (Assembler::*InstructionCondRL)(Condition cond,
Register rt,
Label* label);
typedef void (Assembler::*InstructionCondRRL)(Condition cond,
Register rt,
Register rt2,
Label* label);
typedef void (Assembler::*InstructionCondRRRR)(
Condition cond, Register rd, Register rn, Register rm, Register ra);
typedef void (Assembler::*InstructionCondRSr)(Condition cond,
Register rd,
SpecialRegister spec_reg);
typedef void (Assembler::*InstructionCondMsrOp)(
Condition cond, MaskedSpecialRegister spec_reg, const Operand& operand);
typedef void (Assembler::*InstructionCondSizeRRR)(
Condition cond, EncodingSize size, Register rd, Register rn, Register rm);
typedef void (Assembler::*InstructionCondSize)(Condition cond,
EncodingSize size);
typedef void (Assembler::*InstructionCondMop)(Condition cond,
const MemOperand& operand);
typedef void (Assembler::*InstructionCondSizeRl)(Condition cond,
EncodingSize size,
RegisterList registers);
typedef void (Assembler::*InstructionCondSizeOrl)(Condition cond,
EncodingSize size,
Register rt);
typedef void (Assembler::*InstructionCondSizeRR)(Condition cond,
EncodingSize size,
Register rd,
Register rm);
typedef void (Assembler::*InstructionDtQQQ)(DataType dt,
QRegister rd,
QRegister rn,
QRegister rm);
typedef void (Assembler::*InstructionCondRIR)(Condition cond,
Register rd,
uint32_t imm,
Register rn);
typedef void (Assembler::*InstructionCondRRRMop)(Condition cond,
Register rd,
Register rt,
Register rt2,
const MemOperand& operand);
typedef void (Assembler::*InstructionCondSizeI)(Condition cond,
EncodingSize size,
uint32_t imm);
typedef void (Assembler::*InstructionCondDtDDD)(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
typedef void (Assembler::*InstructionCondDtQQQ)(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
typedef void (Assembler::*InstructionCondDtQDD)(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
typedef void (Assembler::*InstructionCondDtDD)(Condition cond,
DataType dt,
DRegister rd,
DRegister rm);
typedef void (Assembler::*InstructionCondDtQQ)(Condition cond,
DataType dt,
QRegister rd,
QRegister rm);
typedef void (Assembler::*InstructionCondDtSS)(Condition cond,
DataType dt,
SRegister rd,
SRegister rm);
typedef void (Assembler::*InstructionCondDtSSS)(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
typedef void (Assembler::*InstructionCondDtDQQ)(
Condition cond, DataType dt, DRegister rd, QRegister rn, QRegister rm);
typedef void (Assembler::*InstructionCondDtQQD)(
Condition cond, DataType dt, QRegister rd, QRegister rn, DRegister rm);
typedef void (Assembler::*InstructionCondDtDDDop)(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
const DOperand& operand);
typedef void (Assembler::*InstructionCondDtQQQop)(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
const QOperand& operand);
typedef void (Assembler::*InstructionCondDtSFi)(Condition cond,
DataType dt,
SRegister rd,
double imm);
typedef void (Assembler::*InstructionCondDtDFi)(Condition cond,
DataType dt,
DRegister rd,
double imm);
typedef void (Assembler::*InstructionCondDtDtDS)(
Condition cond, DataType dt1, DataType dt2, DRegister rd, SRegister rm);
typedef void (Assembler::*InstructionCondDtDtSD)(
Condition cond, DataType dt1, DataType dt2, SRegister rd, DRegister rm);
typedef void (Assembler::*InstructionCondDtDtDDSi)(Condition cond,
DataType dt1,
DataType dt2,
DRegister rd,
DRegister rm,
int32_t fbits);
typedef void (Assembler::*InstructionCondDtDtQQSi)(Condition cond,
DataType dt1,
DataType dt2,
QRegister rd,
QRegister rm,
int32_t fbits);
typedef void (Assembler::*InstructionCondDtDtSSSi)(Condition cond,
DataType dt1,
DataType dt2,
SRegister rd,
SRegister rm,
int32_t fbits);
typedef void (Assembler::*InstructionCondDtDtDD)(
Condition cond, DataType dt1, DataType dt2, DRegister rd, DRegister rm);
typedef void (Assembler::*InstructionCondDtDtQQ)(
Condition cond, DataType dt1, DataType dt2, QRegister rd, QRegister rm);
typedef void (Assembler::*InstructionCondDtDtDQ)(
Condition cond, DataType dt1, DataType dt2, DRegister rd, QRegister rm);
typedef void (Assembler::*InstructionCondDtDtQD)(
Condition cond, DataType dt1, DataType dt2, QRegister rd, DRegister rm);
typedef void (Assembler::*InstructionCondDtDtSS)(
Condition cond, DataType dt1, DataType dt2, SRegister rd, SRegister rm);
typedef void (Assembler::*InstructionDtDtDD)(DataType dt1,
DataType dt2,
DRegister rd,
DRegister rm);
typedef void (Assembler::*InstructionDtDtQQ)(DataType dt1,
DataType dt2,
QRegister rd,
QRegister rm);
typedef void (Assembler::*InstructionDtDtSS)(DataType dt1,
DataType dt2,
SRegister rd,
SRegister rm);
typedef void (Assembler::*InstructionDtDtSD)(DataType dt1,
DataType dt2,
SRegister rd,
DRegister rm);
typedef void (Assembler::*InstructionCondDtQR)(Condition cond,
DataType dt,
QRegister rd,
Register rt);
typedef void (Assembler::*InstructionCondDtDR)(Condition cond,
DataType dt,
DRegister rd,
Register rt);
typedef void (Assembler::*InstructionCondDtDDx)(Condition cond,
DataType dt,
DRegister rd,
DRegisterLane rm);
typedef void (Assembler::*InstructionCondDtQDx)(Condition cond,
DataType dt,
QRegister rd,
DRegisterLane rm);
typedef void (Assembler::*InstructionCondDtDDDDop)(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
DRegister rm,
const DOperand& operand);
typedef void (Assembler::*InstructionCondDtQQQQop)(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
QRegister rm,
const QOperand& operand);
typedef void (Assembler::*InstructionCondDtNrlAmop)(
Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand);
typedef void (Assembler::*InstructionCondDtNrlMop)(
Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const MemOperand& operand);
typedef void (Assembler::*InstructionCondDtRwbDrl)(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
typedef void (Assembler::*InstructionCondDtRwbSrl)(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist);
typedef void (Assembler::*InstructionCondDtDL)(Condition cond,
DataType dt,
DRegister rd,
Label* label);
typedef void (Assembler::*InstructionCondDtDMop)(Condition cond,
DataType dt,
DRegister rd,
const MemOperand& operand);
typedef void (Assembler::*InstructionCondDtSL)(Condition cond,
DataType dt,
SRegister rd,
Label* label);
typedef void (Assembler::*InstructionCondDtSMop)(Condition cond,
DataType dt,
SRegister rd,
const MemOperand& operand);
typedef void (Assembler::*InstructionDtDDD)(DataType dt,
DRegister rd,
DRegister rn,
DRegister rm);
typedef void (Assembler::*InstructionDtSSS)(DataType dt,
SRegister rd,
SRegister rn,
SRegister rm);
typedef void (Assembler::*InstructionCondDtDDDx)(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
DRegisterLane rm);
typedef void (Assembler::*InstructionCondDtQQDx)(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
DRegisterLane rm);
typedef void (Assembler::*InstructionCondDtQDDx)(Condition cond,
DataType dt,
QRegister rd,
DRegister rn,
DRegisterLane rm);
typedef void (Assembler::*InstructionCondRS)(Condition cond,
Register rt,
SRegister rn);
typedef void (Assembler::*InstructionCondSR)(Condition cond,
SRegister rn,
Register rt);
typedef void (Assembler::*InstructionCondRRD)(Condition cond,
Register rt,
Register rt2,
DRegister rm);
typedef void (Assembler::*InstructionCondDRR)(Condition cond,
DRegister rm,
Register rt,
Register rt2);
typedef void (Assembler::*InstructionCondRRSS)(
Condition cond, Register rt, Register rt2, SRegister rm, SRegister rm1);
typedef void (Assembler::*InstructionCondSSRR)(
Condition cond, SRegister rm, SRegister rm1, Register rt, Register rt2);
typedef void (Assembler::*InstructionCondDtDxR)(Condition cond,
DataType dt,
DRegisterLane rd,
Register rt);
typedef void (Assembler::*InstructionCondDtDDop)(Condition cond,
DataType dt,
DRegister rd,
const DOperand& operand);
typedef void (Assembler::*InstructionCondDtQQop)(Condition cond,
DataType dt,
QRegister rd,
const QOperand& operand);
typedef void (Assembler::*InstructionCondDtSSop)(Condition cond,
DataType dt,
SRegister rd,
const SOperand& operand);
typedef void (Assembler::*InstructionCondDtRDx)(Condition cond,
DataType dt,
Register rt,
DRegisterLane rn);
typedef void (Assembler::*InstructionCondDtQD)(Condition cond,
DataType dt,
QRegister rd,
DRegister rm);
typedef void (Assembler::*InstructionCondDtDQ)(Condition cond,
DataType dt,
DRegister rd,
QRegister rm);
typedef void (Assembler::*InstructionCondRoaSfp)(Condition cond,
RegisterOrAPSR_nzcv rt,
SpecialFPRegister spec_reg);
typedef void (Assembler::*InstructionCondSfpR)(Condition cond,
SpecialFPRegister spec_reg,
Register rt);
typedef void (Assembler::*InstructionCondDtDDIr)(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
DRegister dm,
unsigned index);
typedef void (Assembler::*InstructionCondDtQQIr)(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
DRegister dm,
unsigned index);
typedef void (Assembler::*InstructionCondDtQDIr)(Condition cond,
DataType dt,
QRegister rd,
DRegister rn,
DRegister dm,
unsigned index);
typedef void (Assembler::*InstructionCondDtDrl)(Condition cond,
DataType dt,
DRegisterList dreglist);
typedef void (Assembler::*InstructionCondDtSrl)(Condition cond,
DataType dt,
SRegisterList sreglist);
typedef void (Assembler::*InstructionCondDtDQQop)(Condition cond,
DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand);
typedef void (Assembler::*InstructionCondDtQDDop)(Condition cond,
DataType dt,
QRegister rd,
DRegister rm,
const DOperand& operand);
typedef void (Assembler::*InstructionCondDtDNrlD)(
Condition cond,
DataType dt,
DRegister rd,
const NeonRegisterList& nreglist,
DRegister rm);
virtual void Delegate(InstructionType type,
InstructionCondSizeRROp /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
Register /*rd*/,
Register /*rn*/,
const Operand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kAdc) || (type == kAdcs) || (type == kAdd) ||
(type == kAdds) || (type == kAnd) || (type == kAnds) ||
(type == kAsr) || (type == kAsrs) || (type == kBic) ||
(type == kBics) || (type == kEor) || (type == kEors) ||
(type == kLsl) || (type == kLsls) || (type == kLsr) ||
(type == kLsrs) || (type == kOrr) || (type == kOrrs) ||
(type == kRor) || (type == kRors) || (type == kRsb) ||
(type == kRsbs) || (type == kSbc) || (type == kSbcs) ||
(type == kSub) || (type == kSubs));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondROp /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
const Operand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kAdd) || (type == kMovt) || (type == kMovw) ||
(type == kSub) || (type == kSxtb16) || (type == kTeq) ||
(type == kUxtb16));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionROp /*instruction*/,
Register /*rd*/,
const Operand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kAdds) || (type == kSubs));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRROp /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
Register /*rn*/,
const Operand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kAddw) || (type == kOrn) || (type == kOrns) ||
(type == kPkhbt) || (type == kPkhtb) || (type == kRsc) ||
(type == kRscs) || (type == kSubw) || (type == kSxtab) ||
(type == kSxtab16) || (type == kSxtah) || (type == kUxtab) ||
(type == kUxtab16) || (type == kUxtah));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeRL /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
Register /*rd*/,
Label* /*label*/) {
USE(type);
VIXL_ASSERT((type == kAdr) || (type == kLdr));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeL /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
Label* /*label*/) {
USE(type);
VIXL_ASSERT((type == kB));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRIOp /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
uint32_t /*lsb*/,
const Operand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kBfc) || (type == kSsat) || (type == kUsat));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRRIOp /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
Register /*rn*/,
uint32_t /*lsb*/,
const Operand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kBfi) || (type == kSbfx) || (type == kUbfx));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondI /*instruction*/,
Condition /*cond*/,
uint32_t /*imm*/) {
USE(type);
VIXL_ASSERT((type == kBkpt) || (type == kHlt) || (type == kHvc) ||
(type == kSvc));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondL /*instruction*/,
Condition /*cond*/,
Label* /*label*/) {
USE(type);
VIXL_ASSERT((type == kBl) || (type == kBlx) || (type == kPld) ||
(type == kPli));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondR /*instruction*/,
Condition /*cond*/,
Register /*rm*/) {
USE(type);
VIXL_ASSERT((type == kBlx) || (type == kBx) || (type == kBxj));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionRL /*instruction*/,
Register /*rn*/,
Label* /*label*/) {
USE(type);
VIXL_ASSERT((type == kCbnz) || (type == kCbz));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCond /*instruction*/,
Condition /*cond*/) {
USE(type);
VIXL_ASSERT((type == kClrex));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRR /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
Register /*rm*/) {
USE(type);
VIXL_ASSERT((type == kClz) || (type == kRbit) || (type == kRrx) ||
(type == kRrxs));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeROp /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
Register /*rn*/,
const Operand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kCmn) || (type == kCmp) || (type == kMov) ||
(type == kMovs) || (type == kMvn) || (type == kMvns) ||
(type == kSxtb) || (type == kSxth) || (type == kTst) ||
(type == kUxtb) || (type == kUxth));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRRR /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
Register /*rn*/,
Register /*rm*/) {
USE(type);
VIXL_ASSERT((type == kCrc32b) || (type == kCrc32cb) || (type == kCrc32ch) ||
(type == kCrc32cw) || (type == kCrc32h) || (type == kCrc32w) ||
(type == kMuls) || (type == kQadd) || (type == kQadd16) ||
(type == kQadd8) || (type == kQasx) || (type == kQdadd) ||
(type == kQdsub) || (type == kQsax) || (type == kQsub) ||
(type == kQsub16) || (type == kQsub8) || (type == kSadd16) ||
(type == kSadd8) || (type == kSasx) || (type == kSdiv) ||
(type == kSel) || (type == kShadd16) || (type == kShadd8) ||
(type == kShasx) || (type == kShsax) || (type == kShsub16) ||
(type == kShsub8) || (type == kSmmul) || (type == kSmmulr) ||
(type == kSmuad) || (type == kSmuadx) || (type == kSmulbb) ||
(type == kSmulbt) || (type == kSmultb) || (type == kSmultt) ||
(type == kSmulwb) || (type == kSmulwt) || (type == kSmusd) ||
(type == kSmusdx) || (type == kSsax) || (type == kSsub16) ||
(type == kSsub8) || (type == kUadd16) || (type == kUadd8) ||
(type == kUasx) || (type == kUdiv) || (type == kUhadd16) ||
(type == kUhadd8) || (type == kUhasx) || (type == kUhsax) ||
(type == kUhsub16) || (type == kUhsub8) || (type == kUqadd16) ||
(type == kUqadd8) || (type == kUqasx) || (type == kUqsax) ||
(type == kUqsub16) || (type == kUqsub8) || (type == kUsad8) ||
(type == kUsax) || (type == kUsub16) || (type == kUsub8));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondBa /*instruction*/,
Condition /*cond*/,
MemoryBarrier /*option*/) {
USE(type);
VIXL_ASSERT((type == kDmb) || (type == kDsb) || (type == kIsb));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRwbDrl /*instruction*/,
Condition /*cond*/,
Register /*rn*/,
WriteBack /*write_back*/,
DRegisterList /*dreglist*/) {
USE(type);
VIXL_ASSERT((type == kFldmdbx) || (type == kFldmiax) ||
(type == kFstmdbx) || (type == kFstmiax));
UnimplementedDelegate(type);
}
virtual void DelegateIt(Condition /*cond*/, uint16_t /*mask*/) {
UnimplementedDelegate(kIt);
}
virtual void Delegate(InstructionType type,
InstructionCondRMop /*instruction*/,
Condition /*cond*/,
Register /*rt*/,
const MemOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kLda) || (type == kLdab) || (type == kLdaex) ||
(type == kLdaexb) || (type == kLdaexh) || (type == kLdah) ||
(type == kLdrex) || (type == kLdrexb) || (type == kLdrexh) ||
(type == kStl) || (type == kStlb) || (type == kStlh));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRRMop /*instruction*/,
Condition /*cond*/,
Register /*rt*/,
Register /*rt2*/,
const MemOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kLdaexd) || (type == kLdrd) || (type == kLdrexd) ||
(type == kStlex) || (type == kStlexb) || (type == kStlexh) ||
(type == kStrd) || (type == kStrex) || (type == kStrexb) ||
(type == kStrexh));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeRwbRl /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
Register /*rn*/,
WriteBack /*write_back*/,
RegisterList /*registers*/) {
USE(type);
VIXL_ASSERT((type == kLdm) || (type == kLdmfd) || (type == kStm) ||
(type == kStmdb) || (type == kStmea));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRwbRl /*instruction*/,
Condition /*cond*/,
Register /*rn*/,
WriteBack /*write_back*/,
RegisterList /*registers*/) {
USE(type);
VIXL_ASSERT((type == kLdmda) || (type == kLdmdb) || (type == kLdmea) ||
(type == kLdmed) || (type == kLdmfa) || (type == kLdmib) ||
(type == kStmda) || (type == kStmed) || (type == kStmfa) ||
(type == kStmfd) || (type == kStmib));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeRMop /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
Register /*rt*/,
const MemOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kLdr) || (type == kLdrb) || (type == kLdrh) ||
(type == kLdrsb) || (type == kLdrsh) || (type == kStr) ||
(type == kStrb) || (type == kStrh));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRL /*instruction*/,
Condition /*cond*/,
Register /*rt*/,
Label* /*label*/) {
USE(type);
VIXL_ASSERT((type == kLdrb) || (type == kLdrh) || (type == kLdrsb) ||
(type == kLdrsh));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRRL /*instruction*/,
Condition /*cond*/,
Register /*rt*/,
Register /*rt2*/,
Label* /*label*/) {
USE(type);
VIXL_ASSERT((type == kLdrd));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRRRR /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
Register /*rn*/,
Register /*rm*/,
Register /*ra*/) {
USE(type);
VIXL_ASSERT((type == kMla) || (type == kMlas) || (type == kMls) ||
(type == kSmlabb) || (type == kSmlabt) || (type == kSmlad) ||
(type == kSmladx) || (type == kSmlal) || (type == kSmlalbb) ||
(type == kSmlalbt) || (type == kSmlald) || (type == kSmlaldx) ||
(type == kSmlals) || (type == kSmlaltb) || (type == kSmlaltt) ||
(type == kSmlatb) || (type == kSmlatt) || (type == kSmlawb) ||
(type == kSmlawt) || (type == kSmlsd) || (type == kSmlsdx) ||
(type == kSmlsld) || (type == kSmlsldx) || (type == kSmmla) ||
(type == kSmmlar) || (type == kSmmls) || (type == kSmmlsr) ||
(type == kSmull) || (type == kSmulls) || (type == kUmaal) ||
(type == kUmlal) || (type == kUmlals) || (type == kUmull) ||
(type == kUmulls) || (type == kUsada8));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRSr /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
SpecialRegister /*spec_reg*/) {
USE(type);
VIXL_ASSERT((type == kMrs));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondMsrOp /*instruction*/,
Condition /*cond*/,
MaskedSpecialRegister /*spec_reg*/,
const Operand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kMsr));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeRRR /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
Register /*rd*/,
Register /*rn*/,
Register /*rm*/) {
USE(type);
VIXL_ASSERT((type == kMul));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSize /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/) {
USE(type);
VIXL_ASSERT((type == kNop) || (type == kYield));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondMop /*instruction*/,
Condition /*cond*/,
const MemOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kPld) || (type == kPldw) || (type == kPli));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeRl /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
RegisterList /*registers*/) {
USE(type);
VIXL_ASSERT((type == kPop) || (type == kPush));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeOrl /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
Register /*rt*/) {
USE(type);
VIXL_ASSERT((type == kPop) || (type == kPush));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeRR /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
Register /*rd*/,
Register /*rm*/) {
USE(type);
VIXL_ASSERT((type == kRev) || (type == kRev16) || (type == kRevsh));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionDtQQQ /*instruction*/,
DataType /*dt*/,
QRegister /*rd*/,
QRegister /*rn*/,
QRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVmaxnm) || (type == kVminnm));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRIR /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
uint32_t /*imm*/,
Register /*rn*/) {
USE(type);
VIXL_ASSERT((type == kSsat16) || (type == kUsat16));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRRRMop /*instruction*/,
Condition /*cond*/,
Register /*rd*/,
Register /*rt*/,
Register /*rt2*/,
const MemOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kStlexd) || (type == kStrexd));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSizeI /*instruction*/,
Condition /*cond*/,
EncodingSize /*size*/,
uint32_t /*imm*/) {
USE(type);
VIXL_ASSERT((type == kUdf));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDDD /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
DRegister /*rn*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVaba) || (type == kVabd) || (type == kVacge) ||
(type == kVacgt) || (type == kVacle) || (type == kVaclt) ||
(type == kVadd) || (type == kVbif) || (type == kVbit) ||
(type == kVbsl) || (type == kVceq) || (type == kVcge) ||
(type == kVcgt) || (type == kVcle) || (type == kVclt) ||
(type == kVdiv) || (type == kVeor) || (type == kVfma) ||
(type == kVfms) || (type == kVfnma) || (type == kVfnms) ||
(type == kVhadd) || (type == kVhsub) || (type == kVmax) ||
(type == kVmin) || (type == kVmla) || (type == kVmls) ||
(type == kVmul) || (type == kVnmla) || (type == kVnmls) ||
(type == kVnmul) || (type == kVpadd) || (type == kVpmax) ||
(type == kVpmin) || (type == kVqadd) || (type == kVqdmulh) ||
(type == kVqrdmulh) || (type == kVqrshl) || (type == kVqsub) ||
(type == kVrecps) || (type == kVrhadd) || (type == kVrshl) ||
(type == kVrsqrts) || (type == kVsub) || (type == kVtst));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQQQ /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
QRegister /*rn*/,
QRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVaba) || (type == kVabd) || (type == kVacge) ||
(type == kVacgt) || (type == kVacle) || (type == kVaclt) ||
(type == kVadd) || (type == kVbif) || (type == kVbit) ||
(type == kVbsl) || (type == kVceq) || (type == kVcge) ||
(type == kVcgt) || (type == kVcle) || (type == kVclt) ||
(type == kVeor) || (type == kVfma) || (type == kVfms) ||
(type == kVhadd) || (type == kVhsub) || (type == kVmax) ||
(type == kVmin) || (type == kVmla) || (type == kVmls) ||
(type == kVmul) || (type == kVqadd) || (type == kVqdmulh) ||
(type == kVqrdmulh) || (type == kVqrshl) || (type == kVqsub) ||
(type == kVrecps) || (type == kVrhadd) || (type == kVrshl) ||
(type == kVrsqrts) || (type == kVsub) || (type == kVtst));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQDD /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
DRegister /*rn*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVabal) || (type == kVabdl) || (type == kVaddl) ||
(type == kVmlal) || (type == kVmlsl) || (type == kVmull) ||
(type == kVqdmlal) || (type == kVqdmlsl) ||
(type == kVqdmull) || (type == kVsubl));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDD /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVabs) || (type == kVcls) || (type == kVclz) ||
(type == kVcmp) || (type == kVcmpe) || (type == kVcnt) ||
(type == kVneg) || (type == kVpadal) || (type == kVpaddl) ||
(type == kVqabs) || (type == kVqneg) || (type == kVrecpe) ||
(type == kVrev16) || (type == kVrev32) || (type == kVrev64) ||
(type == kVrsqrte) || (type == kVsqrt) || (type == kVswp) ||
(type == kVtrn) || (type == kVuzp) || (type == kVzip));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQQ /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
QRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVabs) || (type == kVcls) || (type == kVclz) ||
(type == kVcnt) || (type == kVneg) || (type == kVpadal) ||
(type == kVpaddl) || (type == kVqabs) || (type == kVqneg) ||
(type == kVrecpe) || (type == kVrev16) || (type == kVrev32) ||
(type == kVrev64) || (type == kVrsqrte) || (type == kVswp) ||
(type == kVtrn) || (type == kVuzp) || (type == kVzip));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtSS /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
SRegister /*rd*/,
SRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVabs) || (type == kVcmp) || (type == kVcmpe) ||
(type == kVneg) || (type == kVsqrt));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtSSS /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
SRegister /*rd*/,
SRegister /*rn*/,
SRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVadd) || (type == kVdiv) || (type == kVfma) ||
(type == kVfms) || (type == kVfnma) || (type == kVfnms) ||
(type == kVmla) || (type == kVmls) || (type == kVmul) ||
(type == kVnmla) || (type == kVnmls) || (type == kVnmul) ||
(type == kVsub));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDQQ /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
QRegister /*rn*/,
QRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVaddhn) || (type == kVraddhn) || (type == kVrsubhn) ||
(type == kVsubhn));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQQD /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
QRegister /*rn*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVaddw) || (type == kVsubw));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDDDop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
DRegister /*rn*/,
const DOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVand) || (type == kVbic) || (type == kVceq) ||
(type == kVcge) || (type == kVcgt) || (type == kVcle) ||
(type == kVclt) || (type == kVorn) || (type == kVorr) ||
(type == kVqshl) || (type == kVqshlu) || (type == kVrshr) ||
(type == kVrsra) || (type == kVshl) || (type == kVshr) ||
(type == kVsli) || (type == kVsra) || (type == kVsri));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQQQop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
QRegister /*rn*/,
const QOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVand) || (type == kVbic) || (type == kVceq) ||
(type == kVcge) || (type == kVcgt) || (type == kVcle) ||
(type == kVclt) || (type == kVorn) || (type == kVorr) ||
(type == kVqshl) || (type == kVqshlu) || (type == kVrshr) ||
(type == kVrsra) || (type == kVshl) || (type == kVshr) ||
(type == kVsli) || (type == kVsra) || (type == kVsri));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtSFi /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
SRegister /*rd*/,
double /*imm*/) {
USE(type);
VIXL_ASSERT((type == kVcmp) || (type == kVcmpe));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDFi /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
double /*imm*/) {
USE(type);
VIXL_ASSERT((type == kVcmp) || (type == kVcmpe));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtDS /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
DRegister /*rd*/,
SRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvt) || (type == kVcvtb) || (type == kVcvtt));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtSD /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
SRegister /*rd*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvt) || (type == kVcvtb) || (type == kVcvtr) ||
(type == kVcvtt));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtDDSi /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
DRegister /*rd*/,
DRegister /*rm*/,
int32_t /*fbits*/) {
USE(type);
VIXL_ASSERT((type == kVcvt));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtQQSi /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
QRegister /*rd*/,
QRegister /*rm*/,
int32_t /*fbits*/) {
USE(type);
VIXL_ASSERT((type == kVcvt));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtSSSi /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
SRegister /*rd*/,
SRegister /*rm*/,
int32_t /*fbits*/) {
USE(type);
VIXL_ASSERT((type == kVcvt));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtDD /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
DRegister /*rd*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvt) || (type == kVrintr) || (type == kVrintx) ||
(type == kVrintz));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtQQ /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
QRegister /*rd*/,
QRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvt));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtDQ /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
DRegister /*rd*/,
QRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvt));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtQD /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
QRegister /*rd*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvt));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDtSS /*instruction*/,
Condition /*cond*/,
DataType /*dt1*/,
DataType /*dt2*/,
SRegister /*rd*/,
SRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvt) || (type == kVcvtb) || (type == kVcvtr) ||
(type == kVcvtt) || (type == kVrintr) || (type == kVrintx) ||
(type == kVrintz));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionDtDtDD /*instruction*/,
DataType /*dt1*/,
DataType /*dt2*/,
DRegister /*rd*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvta) || (type == kVcvtm) || (type == kVcvtn) ||
(type == kVcvtp) || (type == kVrinta) || (type == kVrintm) ||
(type == kVrintn) || (type == kVrintp));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionDtDtQQ /*instruction*/,
DataType /*dt1*/,
DataType /*dt2*/,
QRegister /*rd*/,
QRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvta) || (type == kVcvtm) || (type == kVcvtn) ||
(type == kVcvtp) || (type == kVrinta) || (type == kVrintm) ||
(type == kVrintn) || (type == kVrintp) || (type == kVrintx) ||
(type == kVrintz));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionDtDtSS /*instruction*/,
DataType /*dt1*/,
DataType /*dt2*/,
SRegister /*rd*/,
SRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvta) || (type == kVcvtm) || (type == kVcvtn) ||
(type == kVcvtp) || (type == kVrinta) || (type == kVrintm) ||
(type == kVrintn) || (type == kVrintp));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionDtDtSD /*instruction*/,
DataType /*dt1*/,
DataType /*dt2*/,
SRegister /*rd*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVcvta) || (type == kVcvtm) || (type == kVcvtn) ||
(type == kVcvtp));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQR /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
Register /*rt*/) {
USE(type);
VIXL_ASSERT((type == kVdup));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDR /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
Register /*rt*/) {
USE(type);
VIXL_ASSERT((type == kVdup));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDDx /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
DRegisterLane /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVdup));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQDx /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
DRegisterLane /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVdup));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDDDDop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
DRegister /*rn*/,
DRegister /*rm*/,
const DOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVext));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQQQQop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
QRegister /*rn*/,
QRegister /*rm*/,
const QOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVext));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtNrlAmop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
const NeonRegisterList& /*nreglist*/,
const AlignedMemOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVld1) || (type == kVld2) || (type == kVld3) ||
(type == kVld4) || (type == kVst1) || (type == kVst2) ||
(type == kVst3) || (type == kVst4));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtNrlMop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
const NeonRegisterList& /*nreglist*/,
const MemOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVld3) || (type == kVst3));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtRwbDrl /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
Register /*rn*/,
WriteBack /*write_back*/,
DRegisterList /*dreglist*/) {
USE(type);
VIXL_ASSERT((type == kVldm) || (type == kVldmdb) || (type == kVldmia) ||
(type == kVstm) || (type == kVstmdb) || (type == kVstmia));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtRwbSrl /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
Register /*rn*/,
WriteBack /*write_back*/,
SRegisterList /*sreglist*/) {
USE(type);
VIXL_ASSERT((type == kVldm) || (type == kVldmdb) || (type == kVldmia) ||
(type == kVstm) || (type == kVstmdb) || (type == kVstmia));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDL /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
Label* /*label*/) {
USE(type);
VIXL_ASSERT((type == kVldr));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDMop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
const MemOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVldr) || (type == kVstr));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtSL /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
SRegister /*rd*/,
Label* /*label*/) {
USE(type);
VIXL_ASSERT((type == kVldr));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtSMop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
SRegister /*rd*/,
const MemOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVldr) || (type == kVstr));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionDtDDD /*instruction*/,
DataType /*dt*/,
DRegister /*rd*/,
DRegister /*rn*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVmaxnm) || (type == kVminnm) || (type == kVseleq) ||
(type == kVselge) || (type == kVselgt) || (type == kVselvs));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionDtSSS /*instruction*/,
DataType /*dt*/,
SRegister /*rd*/,
SRegister /*rn*/,
SRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVmaxnm) || (type == kVminnm) || (type == kVseleq) ||
(type == kVselge) || (type == kVselgt) || (type == kVselvs));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDDDx /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
DRegister /*rn*/,
DRegisterLane /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVmla) || (type == kVmls) || (type == kVqdmulh) ||
(type == kVqrdmulh));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQQDx /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
QRegister /*rn*/,
DRegisterLane /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVmla) || (type == kVmls) || (type == kVqdmulh) ||
(type == kVqrdmulh));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQDDx /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
DRegister /*rn*/,
DRegisterLane /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVmlal) || (type == kVmlsl) || (type == kVqdmull));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRS /*instruction*/,
Condition /*cond*/,
Register /*rt*/,
SRegister /*rn*/) {
USE(type);
VIXL_ASSERT((type == kVmov));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSR /*instruction*/,
Condition /*cond*/,
SRegister /*rn*/,
Register /*rt*/) {
USE(type);
VIXL_ASSERT((type == kVmov));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRRD /*instruction*/,
Condition /*cond*/,
Register /*rt*/,
Register /*rt2*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVmov));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDRR /*instruction*/,
Condition /*cond*/,
DRegister /*rm*/,
Register /*rt*/,
Register /*rt2*/) {
USE(type);
VIXL_ASSERT((type == kVmov));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRRSS /*instruction*/,
Condition /*cond*/,
Register /*rt*/,
Register /*rt2*/,
SRegister /*rm*/,
SRegister /*rm1*/) {
USE(type);
VIXL_ASSERT((type == kVmov));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSSRR /*instruction*/,
Condition /*cond*/,
SRegister /*rm*/,
SRegister /*rm1*/,
Register /*rt*/,
Register /*rt2*/) {
USE(type);
VIXL_ASSERT((type == kVmov));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDxR /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegisterLane /*rd*/,
Register /*rt*/) {
USE(type);
VIXL_ASSERT((type == kVmov));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDDop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
const DOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVmov) || (type == kVmvn));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQQop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
const QOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVmov) || (type == kVmvn));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtSSop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
SRegister /*rd*/,
const SOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVmov));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtRDx /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
Register /*rt*/,
DRegisterLane /*rn*/) {
USE(type);
VIXL_ASSERT((type == kVmov));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQD /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVmovl));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDQ /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
QRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVmovn) || (type == kVqmovn) || (type == kVqmovun));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondRoaSfp /*instruction*/,
Condition /*cond*/,
RegisterOrAPSR_nzcv /*rt*/,
SpecialFPRegister /*spec_reg*/) {
USE(type);
VIXL_ASSERT((type == kVmrs));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondSfpR /*instruction*/,
Condition /*cond*/,
SpecialFPRegister /*spec_reg*/,
Register /*rt*/) {
USE(type);
VIXL_ASSERT((type == kVmsr));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDDIr /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
DRegister /*rn*/,
DRegister /*dm*/,
unsigned /*index*/) {
USE(type);
VIXL_ASSERT((type == kVmul));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQQIr /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
QRegister /*rn*/,
DRegister /*dm*/,
unsigned /*index*/) {
USE(type);
VIXL_ASSERT((type == kVmul));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQDIr /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
DRegister /*rn*/,
DRegister /*dm*/,
unsigned /*index*/) {
USE(type);
VIXL_ASSERT((type == kVmull) || (type == kVqdmlal) || (type == kVqdmlsl));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDrl /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegisterList /*dreglist*/) {
USE(type);
VIXL_ASSERT((type == kVpop) || (type == kVpush));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtSrl /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
SRegisterList /*sreglist*/) {
USE(type);
VIXL_ASSERT((type == kVpop) || (type == kVpush));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDQQop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
QRegister /*rm*/,
const QOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVqrshrn) || (type == kVqrshrun) ||
(type == kVqshrn) || (type == kVqshrun) || (type == kVrshrn) ||
(type == kVshrn));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtQDDop /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
QRegister /*rd*/,
DRegister /*rm*/,
const DOperand& /*operand*/) {
USE(type);
VIXL_ASSERT((type == kVshll));
UnimplementedDelegate(type);
}
virtual void Delegate(InstructionType type,
InstructionCondDtDNrlD /*instruction*/,
Condition /*cond*/,
DataType /*dt*/,
DRegister /*rd*/,
const NeonRegisterList& /*nreglist*/,
DRegister /*rm*/) {
USE(type);
VIXL_ASSERT((type == kVtbl) || (type == kVtbx));
UnimplementedDelegate(type);
}
void adc(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void adc(Register rd, Register rn, const Operand& operand) {
adc(al, Best, rd, rn, operand);
}
void adc(Condition cond, Register rd, Register rn, const Operand& operand) {
adc(cond, Best, rd, rn, operand);
}
void adc(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
adc(al, size, rd, rn, operand);
}
void adcs(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void adcs(Register rd, Register rn, const Operand& operand) {
adcs(al, Best, rd, rn, operand);
}
void adcs(Condition cond, Register rd, Register rn, const Operand& operand) {
adcs(cond, Best, rd, rn, operand);
}
void adcs(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
adcs(al, size, rd, rn, operand);
}
void add(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void add(Register rd, Register rn, const Operand& operand) {
add(al, Best, rd, rn, operand);
}
void add(Condition cond, Register rd, Register rn, const Operand& operand) {
add(cond, Best, rd, rn, operand);
}
void add(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
add(al, size, rd, rn, operand);
}
void add(Condition cond, Register rd, const Operand& operand);
void add(Register rd, const Operand& operand) { add(al, rd, operand); }
void adds(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void adds(Register rd, Register rn, const Operand& operand) {
adds(al, Best, rd, rn, operand);
}
void adds(Condition cond, Register rd, Register rn, const Operand& operand) {
adds(cond, Best, rd, rn, operand);
}
void adds(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
adds(al, size, rd, rn, operand);
}
void adds(Register rd, const Operand& operand);
void addw(Condition cond, Register rd, Register rn, const Operand& operand);
void addw(Register rd, Register rn, const Operand& operand) {
addw(al, rd, rn, operand);
}
void adr(Condition cond, EncodingSize size, Register rd, Label* label);
void adr(Register rd, Label* label) { adr(al, Best, rd, label); }
void adr(Condition cond, Register rd, Label* label) {
adr(cond, Best, rd, label);
}
void adr(EncodingSize size, Register rd, Label* label) {
adr(al, size, rd, label);
}
void and_(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void and_(Register rd, Register rn, const Operand& operand) {
and_(al, Best, rd, rn, operand);
}
void and_(Condition cond, Register rd, Register rn, const Operand& operand) {
and_(cond, Best, rd, rn, operand);
}
void and_(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
and_(al, size, rd, rn, operand);
}
void ands(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void ands(Register rd, Register rn, const Operand& operand) {
ands(al, Best, rd, rn, operand);
}
void ands(Condition cond, Register rd, Register rn, const Operand& operand) {
ands(cond, Best, rd, rn, operand);
}
void ands(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
ands(al, size, rd, rn, operand);
}
void asr(Condition cond,
EncodingSize size,
Register rd,
Register rm,
const Operand& operand);
void asr(Register rd, Register rm, const Operand& operand) {
asr(al, Best, rd, rm, operand);
}
void asr(Condition cond, Register rd, Register rm, const Operand& operand) {
asr(cond, Best, rd, rm, operand);
}
void asr(EncodingSize size,
Register rd,
Register rm,
const Operand& operand) {
asr(al, size, rd, rm, operand);
}
void asrs(Condition cond,
EncodingSize size,
Register rd,
Register rm,
const Operand& operand);
void asrs(Register rd, Register rm, const Operand& operand) {
asrs(al, Best, rd, rm, operand);
}
void asrs(Condition cond, Register rd, Register rm, const Operand& operand) {
asrs(cond, Best, rd, rm, operand);
}
void asrs(EncodingSize size,
Register rd,
Register rm,
const Operand& operand) {
asrs(al, size, rd, rm, operand);
}
void b(Condition cond, EncodingSize size, Label* label);
void b(Label* label) { b(al, Best, label); }
void b(Condition cond, Label* label) { b(cond, Best, label); }
void b(EncodingSize size, Label* label) { b(al, size, label); }
void bfc(Condition cond, Register rd, uint32_t lsb, const Operand& operand);
void bfc(Register rd, uint32_t lsb, const Operand& operand) {
bfc(al, rd, lsb, operand);
}
void bfi(Condition cond,
Register rd,
Register rn,
uint32_t lsb,
const Operand& operand);
void bfi(Register rd, Register rn, uint32_t lsb, const Operand& operand) {
bfi(al, rd, rn, lsb, operand);
}
void bic(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void bic(Register rd, Register rn, const Operand& operand) {
bic(al, Best, rd, rn, operand);
}
void bic(Condition cond, Register rd, Register rn, const Operand& operand) {
bic(cond, Best, rd, rn, operand);
}
void bic(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
bic(al, size, rd, rn, operand);
}
void bics(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void bics(Register rd, Register rn, const Operand& operand) {
bics(al, Best, rd, rn, operand);
}
void bics(Condition cond, Register rd, Register rn, const Operand& operand) {
bics(cond, Best, rd, rn, operand);
}
void bics(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
bics(al, size, rd, rn, operand);
}
void bkpt(Condition cond, uint32_t imm);
void bkpt(uint32_t imm) { bkpt(al, imm); }
void bl(Condition cond, Label* label);
void bl(Label* label) { bl(al, label); }
void blx(Condition cond, Label* label);
void blx(Label* label) { blx(al, label); }
void blx(Condition cond, Register rm);
void blx(Register rm) { blx(al, rm); }
void bx(Condition cond, Register rm);
void bx(Register rm) { bx(al, rm); }
void bxj(Condition cond, Register rm);
void bxj(Register rm) { bxj(al, rm); }
void cbnz(Register rn, Label* label);
void cbz(Register rn, Label* label);
void clrex(Condition cond);
void clrex() { clrex(al); }
void clz(Condition cond, Register rd, Register rm);
void clz(Register rd, Register rm) { clz(al, rd, rm); }
void cmn(Condition cond,
EncodingSize size,
Register rn,
const Operand& operand);
void cmn(Register rn, const Operand& operand) { cmn(al, Best, rn, operand); }
void cmn(Condition cond, Register rn, const Operand& operand) {
cmn(cond, Best, rn, operand);
}
void cmn(EncodingSize size, Register rn, const Operand& operand) {
cmn(al, size, rn, operand);
}
void cmp(Condition cond,
EncodingSize size,
Register rn,
const Operand& operand);
void cmp(Register rn, const Operand& operand) { cmp(al, Best, rn, operand); }
void cmp(Condition cond, Register rn, const Operand& operand) {
cmp(cond, Best, rn, operand);
}
void cmp(EncodingSize size, Register rn, const Operand& operand) {
cmp(al, size, rn, operand);
}
void crc32b(Condition cond, Register rd, Register rn, Register rm);
void crc32b(Register rd, Register rn, Register rm) { crc32b(al, rd, rn, rm); }
void crc32cb(Condition cond, Register rd, Register rn, Register rm);
void crc32cb(Register rd, Register rn, Register rm) {
crc32cb(al, rd, rn, rm);
}
void crc32ch(Condition cond, Register rd, Register rn, Register rm);
void crc32ch(Register rd, Register rn, Register rm) {
crc32ch(al, rd, rn, rm);
}
void crc32cw(Condition cond, Register rd, Register rn, Register rm);
void crc32cw(Register rd, Register rn, Register rm) {
crc32cw(al, rd, rn, rm);
}
void crc32h(Condition cond, Register rd, Register rn, Register rm);
void crc32h(Register rd, Register rn, Register rm) { crc32h(al, rd, rn, rm); }
void crc32w(Condition cond, Register rd, Register rn, Register rm);
void crc32w(Register rd, Register rn, Register rm) { crc32w(al, rd, rn, rm); }
void dmb(Condition cond, MemoryBarrier option);
void dmb(MemoryBarrier option) { dmb(al, option); }
void dsb(Condition cond, MemoryBarrier option);
void dsb(MemoryBarrier option) { dsb(al, option); }
void eor(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void eor(Register rd, Register rn, const Operand& operand) {
eor(al, Best, rd, rn, operand);
}
void eor(Condition cond, Register rd, Register rn, const Operand& operand) {
eor(cond, Best, rd, rn, operand);
}
void eor(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
eor(al, size, rd, rn, operand);
}
void eors(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void eors(Register rd, Register rn, const Operand& operand) {
eors(al, Best, rd, rn, operand);
}
void eors(Condition cond, Register rd, Register rn, const Operand& operand) {
eors(cond, Best, rd, rn, operand);
}
void eors(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
eors(al, size, rd, rn, operand);
}
void fldmdbx(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void fldmdbx(Register rn, WriteBack write_back, DRegisterList dreglist) {
fldmdbx(al, rn, write_back, dreglist);
}
void fldmiax(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void fldmiax(Register rn, WriteBack write_back, DRegisterList dreglist) {
fldmiax(al, rn, write_back, dreglist);
}
void fstmdbx(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void fstmdbx(Register rn, WriteBack write_back, DRegisterList dreglist) {
fstmdbx(al, rn, write_back, dreglist);
}
void fstmiax(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void fstmiax(Register rn, WriteBack write_back, DRegisterList dreglist) {
fstmiax(al, rn, write_back, dreglist);
}
void hlt(Condition cond, uint32_t imm);
void hlt(uint32_t imm) { hlt(al, imm); }
void hvc(Condition cond, uint32_t imm);
void hvc(uint32_t imm) { hvc(al, imm); }
void isb(Condition cond, MemoryBarrier option);
void isb(MemoryBarrier option) { isb(al, option); }
void it(Condition cond, uint16_t mask);
void lda(Condition cond, Register rt, const MemOperand& operand);
void lda(Register rt, const MemOperand& operand) { lda(al, rt, operand); }
void ldab(Condition cond, Register rt, const MemOperand& operand);
void ldab(Register rt, const MemOperand& operand) { ldab(al, rt, operand); }
void ldaex(Condition cond, Register rt, const MemOperand& operand);
void ldaex(Register rt, const MemOperand& operand) { ldaex(al, rt, operand); }
void ldaexb(Condition cond, Register rt, const MemOperand& operand);
void ldaexb(Register rt, const MemOperand& operand) {
ldaexb(al, rt, operand);
}
void ldaexd(Condition cond,
Register rt,
Register rt2,
const MemOperand& operand);
void ldaexd(Register rt, Register rt2, const MemOperand& operand) {
ldaexd(al, rt, rt2, operand);
}
void ldaexh(Condition cond, Register rt, const MemOperand& operand);
void ldaexh(Register rt, const MemOperand& operand) {
ldaexh(al, rt, operand);
}
void ldah(Condition cond, Register rt, const MemOperand& operand);
void ldah(Register rt, const MemOperand& operand) { ldah(al, rt, operand); }
void ldm(Condition cond,
EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers);
void ldm(Register rn, WriteBack write_back, RegisterList registers) {
ldm(al, Best, rn, write_back, registers);
}
void ldm(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers) {
ldm(cond, Best, rn, write_back, registers);
}
void ldm(EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers) {
ldm(al, size, rn, write_back, registers);
}
void ldmda(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void ldmda(Register rn, WriteBack write_back, RegisterList registers) {
ldmda(al, rn, write_back, registers);
}
void ldmdb(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void ldmdb(Register rn, WriteBack write_back, RegisterList registers) {
ldmdb(al, rn, write_back, registers);
}
void ldmea(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void ldmea(Register rn, WriteBack write_back, RegisterList registers) {
ldmea(al, rn, write_back, registers);
}
void ldmed(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void ldmed(Register rn, WriteBack write_back, RegisterList registers) {
ldmed(al, rn, write_back, registers);
}
void ldmfa(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void ldmfa(Register rn, WriteBack write_back, RegisterList registers) {
ldmfa(al, rn, write_back, registers);
}
void ldmfd(Condition cond,
EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers);
void ldmfd(Register rn, WriteBack write_back, RegisterList registers) {
ldmfd(al, Best, rn, write_back, registers);
}
void ldmfd(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers) {
ldmfd(cond, Best, rn, write_back, registers);
}
void ldmfd(EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers) {
ldmfd(al, size, rn, write_back, registers);
}
void ldmib(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void ldmib(Register rn, WriteBack write_back, RegisterList registers) {
ldmib(al, rn, write_back, registers);
}
void ldr(Condition cond,
EncodingSize size,
Register rt,
const MemOperand& operand);
void ldr(Register rt, const MemOperand& operand) {
ldr(al, Best, rt, operand);
}
void ldr(Condition cond, Register rt, const MemOperand& operand) {
ldr(cond, Best, rt, operand);
}
void ldr(EncodingSize size, Register rt, const MemOperand& operand) {
ldr(al, size, rt, operand);
}
void ldr(Condition cond, EncodingSize size, Register rt, Label* label);
void ldr(Register rt, Label* label) { ldr(al, Best, rt, label); }
void ldr(Condition cond, Register rt, Label* label) {
ldr(cond, Best, rt, label);
}
void ldr(EncodingSize size, Register rt, Label* label) {
ldr(al, size, rt, label);
}
void ldrb(Condition cond,
EncodingSize size,
Register rt,
const MemOperand& operand);
void ldrb(Register rt, const MemOperand& operand) {
ldrb(al, Best, rt, operand);
}
void ldrb(Condition cond, Register rt, const MemOperand& operand) {
ldrb(cond, Best, rt, operand);
}
void ldrb(EncodingSize size, Register rt, const MemOperand& operand) {
ldrb(al, size, rt, operand);
}
void ldrb(Condition cond, Register rt, Label* label);
void ldrb(Register rt, Label* label) { ldrb(al, rt, label); }
void ldrd(Condition cond,
Register rt,
Register rt2,
const MemOperand& operand);
void ldrd(Register rt, Register rt2, const MemOperand& operand) {
ldrd(al, rt, rt2, operand);
}
void ldrd(Condition cond, Register rt, Register rt2, Label* label);
void ldrd(Register rt, Register rt2, Label* label) {
ldrd(al, rt, rt2, label);
}
void ldrex(Condition cond, Register rt, const MemOperand& operand);
void ldrex(Register rt, const MemOperand& operand) { ldrex(al, rt, operand); }
void ldrexb(Condition cond, Register rt, const MemOperand& operand);
void ldrexb(Register rt, const MemOperand& operand) {
ldrexb(al, rt, operand);
}
void ldrexd(Condition cond,
Register rt,
Register rt2,
const MemOperand& operand);
void ldrexd(Register rt, Register rt2, const MemOperand& operand) {
ldrexd(al, rt, rt2, operand);
}
void ldrexh(Condition cond, Register rt, const MemOperand& operand);
void ldrexh(Register rt, const MemOperand& operand) {
ldrexh(al, rt, operand);
}
void ldrh(Condition cond,
EncodingSize size,
Register rt,
const MemOperand& operand);
void ldrh(Register rt, const MemOperand& operand) {
ldrh(al, Best, rt, operand);
}
void ldrh(Condition cond, Register rt, const MemOperand& operand) {
ldrh(cond, Best, rt, operand);
}
void ldrh(EncodingSize size, Register rt, const MemOperand& operand) {
ldrh(al, size, rt, operand);
}
void ldrh(Condition cond, Register rt, Label* label);
void ldrh(Register rt, Label* label) { ldrh(al, rt, label); }
void ldrsb(Condition cond,
EncodingSize size,
Register rt,
const MemOperand& operand);
void ldrsb(Register rt, const MemOperand& operand) {
ldrsb(al, Best, rt, operand);
}
void ldrsb(Condition cond, Register rt, const MemOperand& operand) {
ldrsb(cond, Best, rt, operand);
}
void ldrsb(EncodingSize size, Register rt, const MemOperand& operand) {
ldrsb(al, size, rt, operand);
}
void ldrsb(Condition cond, Register rt, Label* label);
void ldrsb(Register rt, Label* label) { ldrsb(al, rt, label); }
void ldrsh(Condition cond,
EncodingSize size,
Register rt,
const MemOperand& operand);
void ldrsh(Register rt, const MemOperand& operand) {
ldrsh(al, Best, rt, operand);
}
void ldrsh(Condition cond, Register rt, const MemOperand& operand) {
ldrsh(cond, Best, rt, operand);
}
void ldrsh(EncodingSize size, Register rt, const MemOperand& operand) {
ldrsh(al, size, rt, operand);
}
void ldrsh(Condition cond, Register rt, Label* label);
void ldrsh(Register rt, Label* label) { ldrsh(al, rt, label); }
void lsl(Condition cond,
EncodingSize size,
Register rd,
Register rm,
const Operand& operand);
void lsl(Register rd, Register rm, const Operand& operand) {
lsl(al, Best, rd, rm, operand);
}
void lsl(Condition cond, Register rd, Register rm, const Operand& operand) {
lsl(cond, Best, rd, rm, operand);
}
void lsl(EncodingSize size,
Register rd,
Register rm,
const Operand& operand) {
lsl(al, size, rd, rm, operand);
}
void lsls(Condition cond,
EncodingSize size,
Register rd,
Register rm,
const Operand& operand);
void lsls(Register rd, Register rm, const Operand& operand) {
lsls(al, Best, rd, rm, operand);
}
void lsls(Condition cond, Register rd, Register rm, const Operand& operand) {
lsls(cond, Best, rd, rm, operand);
}
void lsls(EncodingSize size,
Register rd,
Register rm,
const Operand& operand) {
lsls(al, size, rd, rm, operand);
}
void lsr(Condition cond,
EncodingSize size,
Register rd,
Register rm,
const Operand& operand);
void lsr(Register rd, Register rm, const Operand& operand) {
lsr(al, Best, rd, rm, operand);
}
void lsr(Condition cond, Register rd, Register rm, const Operand& operand) {
lsr(cond, Best, rd, rm, operand);
}
void lsr(EncodingSize size,
Register rd,
Register rm,
const Operand& operand) {
lsr(al, size, rd, rm, operand);
}
void lsrs(Condition cond,
EncodingSize size,
Register rd,
Register rm,
const Operand& operand);
void lsrs(Register rd, Register rm, const Operand& operand) {
lsrs(al, Best, rd, rm, operand);
}
void lsrs(Condition cond, Register rd, Register rm, const Operand& operand) {
lsrs(cond, Best, rd, rm, operand);
}
void lsrs(EncodingSize size,
Register rd,
Register rm,
const Operand& operand) {
lsrs(al, size, rd, rm, operand);
}
void mla(Condition cond, Register rd, Register rn, Register rm, Register ra);
void mla(Register rd, Register rn, Register rm, Register ra) {
mla(al, rd, rn, rm, ra);
}
void mlas(Condition cond, Register rd, Register rn, Register rm, Register ra);
void mlas(Register rd, Register rn, Register rm, Register ra) {
mlas(al, rd, rn, rm, ra);
}
void mls(Condition cond, Register rd, Register rn, Register rm, Register ra);
void mls(Register rd, Register rn, Register rm, Register ra) {
mls(al, rd, rn, rm, ra);
}
void mov(Condition cond,
EncodingSize size,
Register rd,
const Operand& operand);
void mov(Register rd, const Operand& operand) { mov(al, Best, rd, operand); }
void mov(Condition cond, Register rd, const Operand& operand) {
mov(cond, Best, rd, operand);
}
void mov(EncodingSize size, Register rd, const Operand& operand) {
mov(al, size, rd, operand);
}
void movs(Condition cond,
EncodingSize size,
Register rd,
const Operand& operand);
void movs(Register rd, const Operand& operand) {
movs(al, Best, rd, operand);
}
void movs(Condition cond, Register rd, const Operand& operand) {
movs(cond, Best, rd, operand);
}
void movs(EncodingSize size, Register rd, const Operand& operand) {
movs(al, size, rd, operand);
}
void movt(Condition cond, Register rd, const Operand& operand);
void movt(Register rd, const Operand& operand) { movt(al, rd, operand); }
void movw(Condition cond, Register rd, const Operand& operand);
void movw(Register rd, const Operand& operand) { movw(al, rd, operand); }
void mrs(Condition cond, Register rd, SpecialRegister spec_reg);
void mrs(Register rd, SpecialRegister spec_reg) { mrs(al, rd, spec_reg); }
void msr(Condition cond,
MaskedSpecialRegister spec_reg,
const Operand& operand);
void msr(MaskedSpecialRegister spec_reg, const Operand& operand) {
msr(al, spec_reg, operand);
}
void mul(
Condition cond, EncodingSize size, Register rd, Register rn, Register rm);
void mul(Register rd, Register rn, Register rm) { mul(al, Best, rd, rn, rm); }
void mul(Condition cond, Register rd, Register rn, Register rm) {
mul(cond, Best, rd, rn, rm);
}
void mul(EncodingSize size, Register rd, Register rn, Register rm) {
mul(al, size, rd, rn, rm);
}
void muls(Condition cond, Register rd, Register rn, Register rm);
void muls(Register rd, Register rn, Register rm) { muls(al, rd, rn, rm); }
void mvn(Condition cond,
EncodingSize size,
Register rd,
const Operand& operand);
void mvn(Register rd, const Operand& operand) { mvn(al, Best, rd, operand); }
void mvn(Condition cond, Register rd, const Operand& operand) {
mvn(cond, Best, rd, operand);
}
void mvn(EncodingSize size, Register rd, const Operand& operand) {
mvn(al, size, rd, operand);
}
void mvns(Condition cond,
EncodingSize size,
Register rd,
const Operand& operand);
void mvns(Register rd, const Operand& operand) {
mvns(al, Best, rd, operand);
}
void mvns(Condition cond, Register rd, const Operand& operand) {
mvns(cond, Best, rd, operand);
}
void mvns(EncodingSize size, Register rd, const Operand& operand) {
mvns(al, size, rd, operand);
}
void nop(Condition cond, EncodingSize size);
void nop() { nop(al, Best); }
void nop(Condition cond) { nop(cond, Best); }
void nop(EncodingSize size) { nop(al, size); }
void orn(Condition cond, Register rd, Register rn, const Operand& operand);
void orn(Register rd, Register rn, const Operand& operand) {
orn(al, rd, rn, operand);
}
void orns(Condition cond, Register rd, Register rn, const Operand& operand);
void orns(Register rd, Register rn, const Operand& operand) {
orns(al, rd, rn, operand);
}
void orr(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void orr(Register rd, Register rn, const Operand& operand) {
orr(al, Best, rd, rn, operand);
}
void orr(Condition cond, Register rd, Register rn, const Operand& operand) {
orr(cond, Best, rd, rn, operand);
}
void orr(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
orr(al, size, rd, rn, operand);
}
void orrs(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void orrs(Register rd, Register rn, const Operand& operand) {
orrs(al, Best, rd, rn, operand);
}
void orrs(Condition cond, Register rd, Register rn, const Operand& operand) {
orrs(cond, Best, rd, rn, operand);
}
void orrs(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
orrs(al, size, rd, rn, operand);
}
void pkhbt(Condition cond, Register rd, Register rn, const Operand& operand);
void pkhbt(Register rd, Register rn, const Operand& operand) {
pkhbt(al, rd, rn, operand);
}
void pkhtb(Condition cond, Register rd, Register rn, const Operand& operand);
void pkhtb(Register rd, Register rn, const Operand& operand) {
pkhtb(al, rd, rn, operand);
}
void pld(Condition cond, Label* label);
void pld(Label* label) { pld(al, label); }
void pld(Condition cond, const MemOperand& operand);
void pld(const MemOperand& operand) { pld(al, operand); }
void pldw(Condition cond, const MemOperand& operand);
void pldw(const MemOperand& operand) { pldw(al, operand); }
void pli(Condition cond, const MemOperand& operand);
void pli(const MemOperand& operand) { pli(al, operand); }
void pli(Condition cond, Label* label);
void pli(Label* label) { pli(al, label); }
void pop(Condition cond, EncodingSize size, RegisterList registers);
void pop(RegisterList registers) { pop(al, Best, registers); }
void pop(Condition cond, RegisterList registers) {
pop(cond, Best, registers);
}
void pop(EncodingSize size, RegisterList registers) {
pop(al, size, registers);
}
void pop(Condition cond, EncodingSize size, Register rt);
void pop(Register rt) { pop(al, Best, rt); }
void pop(Condition cond, Register rt) { pop(cond, Best, rt); }
void pop(EncodingSize size, Register rt) { pop(al, size, rt); }
void push(Condition cond, EncodingSize size, RegisterList registers);
void push(RegisterList registers) { push(al, Best, registers); }
void push(Condition cond, RegisterList registers) {
push(cond, Best, registers);
}
void push(EncodingSize size, RegisterList registers) {
push(al, size, registers);
}
void push(Condition cond, EncodingSize size, Register rt);
void push(Register rt) { push(al, Best, rt); }
void push(Condition cond, Register rt) { push(cond, Best, rt); }
void push(EncodingSize size, Register rt) { push(al, size, rt); }
void qadd(Condition cond, Register rd, Register rm, Register rn);
void qadd(Register rd, Register rm, Register rn) { qadd(al, rd, rm, rn); }
void qadd16(Condition cond, Register rd, Register rn, Register rm);
void qadd16(Register rd, Register rn, Register rm) { qadd16(al, rd, rn, rm); }
void qadd8(Condition cond, Register rd, Register rn, Register rm);
void qadd8(Register rd, Register rn, Register rm) { qadd8(al, rd, rn, rm); }
void qasx(Condition cond, Register rd, Register rn, Register rm);
void qasx(Register rd, Register rn, Register rm) { qasx(al, rd, rn, rm); }
void qdadd(Condition cond, Register rd, Register rm, Register rn);
void qdadd(Register rd, Register rm, Register rn) { qdadd(al, rd, rm, rn); }
void qdsub(Condition cond, Register rd, Register rm, Register rn);
void qdsub(Register rd, Register rm, Register rn) { qdsub(al, rd, rm, rn); }
void qsax(Condition cond, Register rd, Register rn, Register rm);
void qsax(Register rd, Register rn, Register rm) { qsax(al, rd, rn, rm); }
void qsub(Condition cond, Register rd, Register rm, Register rn);
void qsub(Register rd, Register rm, Register rn) { qsub(al, rd, rm, rn); }
void qsub16(Condition cond, Register rd, Register rn, Register rm);
void qsub16(Register rd, Register rn, Register rm) { qsub16(al, rd, rn, rm); }
void qsub8(Condition cond, Register rd, Register rn, Register rm);
void qsub8(Register rd, Register rn, Register rm) { qsub8(al, rd, rn, rm); }
void rbit(Condition cond, Register rd, Register rm);
void rbit(Register rd, Register rm) { rbit(al, rd, rm); }
void rev(Condition cond, EncodingSize size, Register rd, Register rm);
void rev(Register rd, Register rm) { rev(al, Best, rd, rm); }
void rev(Condition cond, Register rd, Register rm) {
rev(cond, Best, rd, rm);
}
void rev(EncodingSize size, Register rd, Register rm) {
rev(al, size, rd, rm);
}
void rev16(Condition cond, EncodingSize size, Register rd, Register rm);
void rev16(Register rd, Register rm) { rev16(al, Best, rd, rm); }
void rev16(Condition cond, Register rd, Register rm) {
rev16(cond, Best, rd, rm);
}
void rev16(EncodingSize size, Register rd, Register rm) {
rev16(al, size, rd, rm);
}
void revsh(Condition cond, EncodingSize size, Register rd, Register rm);
void revsh(Register rd, Register rm) { revsh(al, Best, rd, rm); }
void revsh(Condition cond, Register rd, Register rm) {
revsh(cond, Best, rd, rm);
}
void revsh(EncodingSize size, Register rd, Register rm) {
revsh(al, size, rd, rm);
}
void ror(Condition cond,
EncodingSize size,
Register rd,
Register rm,
const Operand& operand);
void ror(Register rd, Register rm, const Operand& operand) {
ror(al, Best, rd, rm, operand);
}
void ror(Condition cond, Register rd, Register rm, const Operand& operand) {
ror(cond, Best, rd, rm, operand);
}
void ror(EncodingSize size,
Register rd,
Register rm,
const Operand& operand) {
ror(al, size, rd, rm, operand);
}
void rors(Condition cond,
EncodingSize size,
Register rd,
Register rm,
const Operand& operand);
void rors(Register rd, Register rm, const Operand& operand) {
rors(al, Best, rd, rm, operand);
}
void rors(Condition cond, Register rd, Register rm, const Operand& operand) {
rors(cond, Best, rd, rm, operand);
}
void rors(EncodingSize size,
Register rd,
Register rm,
const Operand& operand) {
rors(al, size, rd, rm, operand);
}
void rrx(Condition cond, Register rd, Register rm);
void rrx(Register rd, Register rm) { rrx(al, rd, rm); }
void rrxs(Condition cond, Register rd, Register rm);
void rrxs(Register rd, Register rm) { rrxs(al, rd, rm); }
void rsb(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void rsb(Register rd, Register rn, const Operand& operand) {
rsb(al, Best, rd, rn, operand);
}
void rsb(Condition cond, Register rd, Register rn, const Operand& operand) {
rsb(cond, Best, rd, rn, operand);
}
void rsb(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
rsb(al, size, rd, rn, operand);
}
void rsbs(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void rsbs(Register rd, Register rn, const Operand& operand) {
rsbs(al, Best, rd, rn, operand);
}
void rsbs(Condition cond, Register rd, Register rn, const Operand& operand) {
rsbs(cond, Best, rd, rn, operand);
}
void rsbs(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
rsbs(al, size, rd, rn, operand);
}
void rsc(Condition cond, Register rd, Register rn, const Operand& operand);
void rsc(Register rd, Register rn, const Operand& operand) {
rsc(al, rd, rn, operand);
}
void rscs(Condition cond, Register rd, Register rn, const Operand& operand);
void rscs(Register rd, Register rn, const Operand& operand) {
rscs(al, rd, rn, operand);
}
void sadd16(Condition cond, Register rd, Register rn, Register rm);
void sadd16(Register rd, Register rn, Register rm) { sadd16(al, rd, rn, rm); }
void sadd8(Condition cond, Register rd, Register rn, Register rm);
void sadd8(Register rd, Register rn, Register rm) { sadd8(al, rd, rn, rm); }
void sasx(Condition cond, Register rd, Register rn, Register rm);
void sasx(Register rd, Register rn, Register rm) { sasx(al, rd, rn, rm); }
void sbc(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void sbc(Register rd, Register rn, const Operand& operand) {
sbc(al, Best, rd, rn, operand);
}
void sbc(Condition cond, Register rd, Register rn, const Operand& operand) {
sbc(cond, Best, rd, rn, operand);
}
void sbc(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
sbc(al, size, rd, rn, operand);
}
void sbcs(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void sbcs(Register rd, Register rn, const Operand& operand) {
sbcs(al, Best, rd, rn, operand);
}
void sbcs(Condition cond, Register rd, Register rn, const Operand& operand) {
sbcs(cond, Best, rd, rn, operand);
}
void sbcs(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
sbcs(al, size, rd, rn, operand);
}
void sbfx(Condition cond,
Register rd,
Register rn,
uint32_t lsb,
const Operand& operand);
void sbfx(Register rd, Register rn, uint32_t lsb, const Operand& operand) {
sbfx(al, rd, rn, lsb, operand);
}
void sdiv(Condition cond, Register rd, Register rn, Register rm);
void sdiv(Register rd, Register rn, Register rm) { sdiv(al, rd, rn, rm); }
void sel(Condition cond, Register rd, Register rn, Register rm);
void sel(Register rd, Register rn, Register rm) { sel(al, rd, rn, rm); }
void shadd16(Condition cond, Register rd, Register rn, Register rm);
void shadd16(Register rd, Register rn, Register rm) {
shadd16(al, rd, rn, rm);
}
void shadd8(Condition cond, Register rd, Register rn, Register rm);
void shadd8(Register rd, Register rn, Register rm) { shadd8(al, rd, rn, rm); }
void shasx(Condition cond, Register rd, Register rn, Register rm);
void shasx(Register rd, Register rn, Register rm) { shasx(al, rd, rn, rm); }
void shsax(Condition cond, Register rd, Register rn, Register rm);
void shsax(Register rd, Register rn, Register rm) { shsax(al, rd, rn, rm); }
void shsub16(Condition cond, Register rd, Register rn, Register rm);
void shsub16(Register rd, Register rn, Register rm) {
shsub16(al, rd, rn, rm);
}
void shsub8(Condition cond, Register rd, Register rn, Register rm);
void shsub8(Register rd, Register rn, Register rm) { shsub8(al, rd, rn, rm); }
void smlabb(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smlabb(Register rd, Register rn, Register rm, Register ra) {
smlabb(al, rd, rn, rm, ra);
}
void smlabt(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smlabt(Register rd, Register rn, Register rm, Register ra) {
smlabt(al, rd, rn, rm, ra);
}
void smlad(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smlad(Register rd, Register rn, Register rm, Register ra) {
smlad(al, rd, rn, rm, ra);
}
void smladx(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smladx(Register rd, Register rn, Register rm, Register ra) {
smladx(al, rd, rn, rm, ra);
}
void smlal(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlal(Register rdlo, Register rdhi, Register rn, Register rm) {
smlal(al, rdlo, rdhi, rn, rm);
}
void smlalbb(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlalbb(Register rdlo, Register rdhi, Register rn, Register rm) {
smlalbb(al, rdlo, rdhi, rn, rm);
}
void smlalbt(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlalbt(Register rdlo, Register rdhi, Register rn, Register rm) {
smlalbt(al, rdlo, rdhi, rn, rm);
}
void smlald(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlald(Register rdlo, Register rdhi, Register rn, Register rm) {
smlald(al, rdlo, rdhi, rn, rm);
}
void smlaldx(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlaldx(Register rdlo, Register rdhi, Register rn, Register rm) {
smlaldx(al, rdlo, rdhi, rn, rm);
}
void smlals(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlals(Register rdlo, Register rdhi, Register rn, Register rm) {
smlals(al, rdlo, rdhi, rn, rm);
}
void smlaltb(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlaltb(Register rdlo, Register rdhi, Register rn, Register rm) {
smlaltb(al, rdlo, rdhi, rn, rm);
}
void smlaltt(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlaltt(Register rdlo, Register rdhi, Register rn, Register rm) {
smlaltt(al, rdlo, rdhi, rn, rm);
}
void smlatb(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smlatb(Register rd, Register rn, Register rm, Register ra) {
smlatb(al, rd, rn, rm, ra);
}
void smlatt(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smlatt(Register rd, Register rn, Register rm, Register ra) {
smlatt(al, rd, rn, rm, ra);
}
void smlawb(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smlawb(Register rd, Register rn, Register rm, Register ra) {
smlawb(al, rd, rn, rm, ra);
}
void smlawt(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smlawt(Register rd, Register rn, Register rm, Register ra) {
smlawt(al, rd, rn, rm, ra);
}
void smlsd(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smlsd(Register rd, Register rn, Register rm, Register ra) {
smlsd(al, rd, rn, rm, ra);
}
void smlsdx(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smlsdx(Register rd, Register rn, Register rm, Register ra) {
smlsdx(al, rd, rn, rm, ra);
}
void smlsld(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlsld(Register rdlo, Register rdhi, Register rn, Register rm) {
smlsld(al, rdlo, rdhi, rn, rm);
}
void smlsldx(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smlsldx(Register rdlo, Register rdhi, Register rn, Register rm) {
smlsldx(al, rdlo, rdhi, rn, rm);
}
void smmla(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smmla(Register rd, Register rn, Register rm, Register ra) {
smmla(al, rd, rn, rm, ra);
}
void smmlar(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smmlar(Register rd, Register rn, Register rm, Register ra) {
smmlar(al, rd, rn, rm, ra);
}
void smmls(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smmls(Register rd, Register rn, Register rm, Register ra) {
smmls(al, rd, rn, rm, ra);
}
void smmlsr(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void smmlsr(Register rd, Register rn, Register rm, Register ra) {
smmlsr(al, rd, rn, rm, ra);
}
void smmul(Condition cond, Register rd, Register rn, Register rm);
void smmul(Register rd, Register rn, Register rm) { smmul(al, rd, rn, rm); }
void smmulr(Condition cond, Register rd, Register rn, Register rm);
void smmulr(Register rd, Register rn, Register rm) { smmulr(al, rd, rn, rm); }
void smuad(Condition cond, Register rd, Register rn, Register rm);
void smuad(Register rd, Register rn, Register rm) { smuad(al, rd, rn, rm); }
void smuadx(Condition cond, Register rd, Register rn, Register rm);
void smuadx(Register rd, Register rn, Register rm) { smuadx(al, rd, rn, rm); }
void smulbb(Condition cond, Register rd, Register rn, Register rm);
void smulbb(Register rd, Register rn, Register rm) { smulbb(al, rd, rn, rm); }
void smulbt(Condition cond, Register rd, Register rn, Register rm);
void smulbt(Register rd, Register rn, Register rm) { smulbt(al, rd, rn, rm); }
void smull(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smull(Register rdlo, Register rdhi, Register rn, Register rm) {
smull(al, rdlo, rdhi, rn, rm);
}
void smulls(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void smulls(Register rdlo, Register rdhi, Register rn, Register rm) {
smulls(al, rdlo, rdhi, rn, rm);
}
void smultb(Condition cond, Register rd, Register rn, Register rm);
void smultb(Register rd, Register rn, Register rm) { smultb(al, rd, rn, rm); }
void smultt(Condition cond, Register rd, Register rn, Register rm);
void smultt(Register rd, Register rn, Register rm) { smultt(al, rd, rn, rm); }
void smulwb(Condition cond, Register rd, Register rn, Register rm);
void smulwb(Register rd, Register rn, Register rm) { smulwb(al, rd, rn, rm); }
void smulwt(Condition cond, Register rd, Register rn, Register rm);
void smulwt(Register rd, Register rn, Register rm) { smulwt(al, rd, rn, rm); }
void smusd(Condition cond, Register rd, Register rn, Register rm);
void smusd(Register rd, Register rn, Register rm) { smusd(al, rd, rn, rm); }
void smusdx(Condition cond, Register rd, Register rn, Register rm);
void smusdx(Register rd, Register rn, Register rm) { smusdx(al, rd, rn, rm); }
void ssat(Condition cond, Register rd, uint32_t imm, const Operand& operand);
void ssat(Register rd, uint32_t imm, const Operand& operand) {
ssat(al, rd, imm, operand);
}
void ssat16(Condition cond, Register rd, uint32_t imm, Register rn);
void ssat16(Register rd, uint32_t imm, Register rn) {
ssat16(al, rd, imm, rn);
}
void ssax(Condition cond, Register rd, Register rn, Register rm);
void ssax(Register rd, Register rn, Register rm) { ssax(al, rd, rn, rm); }
void ssub16(Condition cond, Register rd, Register rn, Register rm);
void ssub16(Register rd, Register rn, Register rm) { ssub16(al, rd, rn, rm); }
void ssub8(Condition cond, Register rd, Register rn, Register rm);
void ssub8(Register rd, Register rn, Register rm) { ssub8(al, rd, rn, rm); }
void stl(Condition cond, Register rt, const MemOperand& operand);
void stl(Register rt, const MemOperand& operand) { stl(al, rt, operand); }
void stlb(Condition cond, Register rt, const MemOperand& operand);
void stlb(Register rt, const MemOperand& operand) { stlb(al, rt, operand); }
void stlex(Condition cond,
Register rd,
Register rt,
const MemOperand& operand);
void stlex(Register rd, Register rt, const MemOperand& operand) {
stlex(al, rd, rt, operand);
}
void stlexb(Condition cond,
Register rd,
Register rt,
const MemOperand& operand);
void stlexb(Register rd, Register rt, const MemOperand& operand) {
stlexb(al, rd, rt, operand);
}
void stlexd(Condition cond,
Register rd,
Register rt,
Register rt2,
const MemOperand& operand);
void stlexd(Register rd,
Register rt,
Register rt2,
const MemOperand& operand) {
stlexd(al, rd, rt, rt2, operand);
}
void stlexh(Condition cond,
Register rd,
Register rt,
const MemOperand& operand);
void stlexh(Register rd, Register rt, const MemOperand& operand) {
stlexh(al, rd, rt, operand);
}
void stlh(Condition cond, Register rt, const MemOperand& operand);
void stlh(Register rt, const MemOperand& operand) { stlh(al, rt, operand); }
void stm(Condition cond,
EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers);
void stm(Register rn, WriteBack write_back, RegisterList registers) {
stm(al, Best, rn, write_back, registers);
}
void stm(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers) {
stm(cond, Best, rn, write_back, registers);
}
void stm(EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers) {
stm(al, size, rn, write_back, registers);
}
void stmda(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void stmda(Register rn, WriteBack write_back, RegisterList registers) {
stmda(al, rn, write_back, registers);
}
void stmdb(Condition cond,
EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers);
void stmdb(Register rn, WriteBack write_back, RegisterList registers) {
stmdb(al, Best, rn, write_back, registers);
}
void stmdb(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers) {
stmdb(cond, Best, rn, write_back, registers);
}
void stmdb(EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers) {
stmdb(al, size, rn, write_back, registers);
}
void stmea(Condition cond,
EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers);
void stmea(Register rn, WriteBack write_back, RegisterList registers) {
stmea(al, Best, rn, write_back, registers);
}
void stmea(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers) {
stmea(cond, Best, rn, write_back, registers);
}
void stmea(EncodingSize size,
Register rn,
WriteBack write_back,
RegisterList registers) {
stmea(al, size, rn, write_back, registers);
}
void stmed(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void stmed(Register rn, WriteBack write_back, RegisterList registers) {
stmed(al, rn, write_back, registers);
}
void stmfa(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void stmfa(Register rn, WriteBack write_back, RegisterList registers) {
stmfa(al, rn, write_back, registers);
}
void stmfd(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void stmfd(Register rn, WriteBack write_back, RegisterList registers) {
stmfd(al, rn, write_back, registers);
}
void stmib(Condition cond,
Register rn,
WriteBack write_back,
RegisterList registers);
void stmib(Register rn, WriteBack write_back, RegisterList registers) {
stmib(al, rn, write_back, registers);
}
void str(Condition cond,
EncodingSize size,
Register rt,
const MemOperand& operand);
void str(Register rt, const MemOperand& operand) {
str(al, Best, rt, operand);
}
void str(Condition cond, Register rt, const MemOperand& operand) {
str(cond, Best, rt, operand);
}
void str(EncodingSize size, Register rt, const MemOperand& operand) {
str(al, size, rt, operand);
}
void strb(Condition cond,
EncodingSize size,
Register rt,
const MemOperand& operand);
void strb(Register rt, const MemOperand& operand) {
strb(al, Best, rt, operand);
}
void strb(Condition cond, Register rt, const MemOperand& operand) {
strb(cond, Best, rt, operand);
}
void strb(EncodingSize size, Register rt, const MemOperand& operand) {
strb(al, size, rt, operand);
}
void strd(Condition cond,
Register rt,
Register rt2,
const MemOperand& operand);
void strd(Register rt, Register rt2, const MemOperand& operand) {
strd(al, rt, rt2, operand);
}
void strex(Condition cond,
Register rd,
Register rt,
const MemOperand& operand);
void strex(Register rd, Register rt, const MemOperand& operand) {
strex(al, rd, rt, operand);
}
void strexb(Condition cond,
Register rd,
Register rt,
const MemOperand& operand);
void strexb(Register rd, Register rt, const MemOperand& operand) {
strexb(al, rd, rt, operand);
}
void strexd(Condition cond,
Register rd,
Register rt,
Register rt2,
const MemOperand& operand);
void strexd(Register rd,
Register rt,
Register rt2,
const MemOperand& operand) {
strexd(al, rd, rt, rt2, operand);
}
void strexh(Condition cond,
Register rd,
Register rt,
const MemOperand& operand);
void strexh(Register rd, Register rt, const MemOperand& operand) {
strexh(al, rd, rt, operand);
}
void strh(Condition cond,
EncodingSize size,
Register rt,
const MemOperand& operand);
void strh(Register rt, const MemOperand& operand) {
strh(al, Best, rt, operand);
}
void strh(Condition cond, Register rt, const MemOperand& operand) {
strh(cond, Best, rt, operand);
}
void strh(EncodingSize size, Register rt, const MemOperand& operand) {
strh(al, size, rt, operand);
}
void sub(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void sub(Register rd, Register rn, const Operand& operand) {
sub(al, Best, rd, rn, operand);
}
void sub(Condition cond, Register rd, Register rn, const Operand& operand) {
sub(cond, Best, rd, rn, operand);
}
void sub(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
sub(al, size, rd, rn, operand);
}
void sub(Condition cond, Register rd, const Operand& operand);
void sub(Register rd, const Operand& operand) { sub(al, rd, operand); }
void subs(Condition cond,
EncodingSize size,
Register rd,
Register rn,
const Operand& operand);
void subs(Register rd, Register rn, const Operand& operand) {
subs(al, Best, rd, rn, operand);
}
void subs(Condition cond, Register rd, Register rn, const Operand& operand) {
subs(cond, Best, rd, rn, operand);
}
void subs(EncodingSize size,
Register rd,
Register rn,
const Operand& operand) {
subs(al, size, rd, rn, operand);
}
void subs(Register rd, const Operand& operand);
void subw(Condition cond, Register rd, Register rn, const Operand& operand);
void subw(Register rd, Register rn, const Operand& operand) {
subw(al, rd, rn, operand);
}
void svc(Condition cond, uint32_t imm);
void svc(uint32_t imm) { svc(al, imm); }
void sxtab(Condition cond, Register rd, Register rn, const Operand& operand);
void sxtab(Register rd, Register rn, const Operand& operand) {
sxtab(al, rd, rn, operand);
}
void sxtab16(Condition cond,
Register rd,
Register rn,
const Operand& operand);
void sxtab16(Register rd, Register rn, const Operand& operand) {
sxtab16(al, rd, rn, operand);
}
void sxtah(Condition cond, Register rd, Register rn, const Operand& operand);
void sxtah(Register rd, Register rn, const Operand& operand) {
sxtah(al, rd, rn, operand);
}
void sxtb(Condition cond,
EncodingSize size,
Register rd,
const Operand& operand);
void sxtb(Register rd, const Operand& operand) {
sxtb(al, Best, rd, operand);
}
void sxtb(Condition cond, Register rd, const Operand& operand) {
sxtb(cond, Best, rd, operand);
}
void sxtb(EncodingSize size, Register rd, const Operand& operand) {
sxtb(al, size, rd, operand);
}
void sxtb16(Condition cond, Register rd, const Operand& operand);
void sxtb16(Register rd, const Operand& operand) { sxtb16(al, rd, operand); }
void sxth(Condition cond,
EncodingSize size,
Register rd,
const Operand& operand);
void sxth(Register rd, const Operand& operand) {
sxth(al, Best, rd, operand);
}
void sxth(Condition cond, Register rd, const Operand& operand) {
sxth(cond, Best, rd, operand);
}
void sxth(EncodingSize size, Register rd, const Operand& operand) {
sxth(al, size, rd, operand);
}
void tbb(Condition cond, Register rn, Register rm);
void tbb(Register rn, Register rm) { tbb(al, rn, rm); }
void tbh(Condition cond, Register rn, Register rm);
void tbh(Register rn, Register rm) { tbh(al, rn, rm); }
void teq(Condition cond, Register rn, const Operand& operand);
void teq(Register rn, const Operand& operand) { teq(al, rn, operand); }
void tst(Condition cond,
EncodingSize size,
Register rn,
const Operand& operand);
void tst(Register rn, const Operand& operand) { tst(al, Best, rn, operand); }
void tst(Condition cond, Register rn, const Operand& operand) {
tst(cond, Best, rn, operand);
}
void tst(EncodingSize size, Register rn, const Operand& operand) {
tst(al, size, rn, operand);
}
void uadd16(Condition cond, Register rd, Register rn, Register rm);
void uadd16(Register rd, Register rn, Register rm) { uadd16(al, rd, rn, rm); }
void uadd8(Condition cond, Register rd, Register rn, Register rm);
void uadd8(Register rd, Register rn, Register rm) { uadd8(al, rd, rn, rm); }
void uasx(Condition cond, Register rd, Register rn, Register rm);
void uasx(Register rd, Register rn, Register rm) { uasx(al, rd, rn, rm); }
void ubfx(Condition cond,
Register rd,
Register rn,
uint32_t lsb,
const Operand& operand);
void ubfx(Register rd, Register rn, uint32_t lsb, const Operand& operand) {
ubfx(al, rd, rn, lsb, operand);
}
void udf(Condition cond, EncodingSize size, uint32_t imm);
void udf(uint32_t imm) { udf(al, Best, imm); }
void udf(Condition cond, uint32_t imm) { udf(cond, Best, imm); }
void udf(EncodingSize size, uint32_t imm) { udf(al, size, imm); }
void udiv(Condition cond, Register rd, Register rn, Register rm);
void udiv(Register rd, Register rn, Register rm) { udiv(al, rd, rn, rm); }
void uhadd16(Condition cond, Register rd, Register rn, Register rm);
void uhadd16(Register rd, Register rn, Register rm) {
uhadd16(al, rd, rn, rm);
}
void uhadd8(Condition cond, Register rd, Register rn, Register rm);
void uhadd8(Register rd, Register rn, Register rm) { uhadd8(al, rd, rn, rm); }
void uhasx(Condition cond, Register rd, Register rn, Register rm);
void uhasx(Register rd, Register rn, Register rm) { uhasx(al, rd, rn, rm); }
void uhsax(Condition cond, Register rd, Register rn, Register rm);
void uhsax(Register rd, Register rn, Register rm) { uhsax(al, rd, rn, rm); }
void uhsub16(Condition cond, Register rd, Register rn, Register rm);
void uhsub16(Register rd, Register rn, Register rm) {
uhsub16(al, rd, rn, rm);
}
void uhsub8(Condition cond, Register rd, Register rn, Register rm);
void uhsub8(Register rd, Register rn, Register rm) { uhsub8(al, rd, rn, rm); }
void umaal(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void umaal(Register rdlo, Register rdhi, Register rn, Register rm) {
umaal(al, rdlo, rdhi, rn, rm);
}
void umlal(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void umlal(Register rdlo, Register rdhi, Register rn, Register rm) {
umlal(al, rdlo, rdhi, rn, rm);
}
void umlals(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void umlals(Register rdlo, Register rdhi, Register rn, Register rm) {
umlals(al, rdlo, rdhi, rn, rm);
}
void umull(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void umull(Register rdlo, Register rdhi, Register rn, Register rm) {
umull(al, rdlo, rdhi, rn, rm);
}
void umulls(
Condition cond, Register rdlo, Register rdhi, Register rn, Register rm);
void umulls(Register rdlo, Register rdhi, Register rn, Register rm) {
umulls(al, rdlo, rdhi, rn, rm);
}
void uqadd16(Condition cond, Register rd, Register rn, Register rm);
void uqadd16(Register rd, Register rn, Register rm) {
uqadd16(al, rd, rn, rm);
}
void uqadd8(Condition cond, Register rd, Register rn, Register rm);
void uqadd8(Register rd, Register rn, Register rm) { uqadd8(al, rd, rn, rm); }
void uqasx(Condition cond, Register rd, Register rn, Register rm);
void uqasx(Register rd, Register rn, Register rm) { uqasx(al, rd, rn, rm); }
void uqsax(Condition cond, Register rd, Register rn, Register rm);
void uqsax(Register rd, Register rn, Register rm) { uqsax(al, rd, rn, rm); }
void uqsub16(Condition cond, Register rd, Register rn, Register rm);
void uqsub16(Register rd, Register rn, Register rm) {
uqsub16(al, rd, rn, rm);
}
void uqsub8(Condition cond, Register rd, Register rn, Register rm);
void uqsub8(Register rd, Register rn, Register rm) { uqsub8(al, rd, rn, rm); }
void usad8(Condition cond, Register rd, Register rn, Register rm);
void usad8(Register rd, Register rn, Register rm) { usad8(al, rd, rn, rm); }
void usada8(
Condition cond, Register rd, Register rn, Register rm, Register ra);
void usada8(Register rd, Register rn, Register rm, Register ra) {
usada8(al, rd, rn, rm, ra);
}
void usat(Condition cond, Register rd, uint32_t imm, const Operand& operand);
void usat(Register rd, uint32_t imm, const Operand& operand) {
usat(al, rd, imm, operand);
}
void usat16(Condition cond, Register rd, uint32_t imm, Register rn);
void usat16(Register rd, uint32_t imm, Register rn) {
usat16(al, rd, imm, rn);
}
void usax(Condition cond, Register rd, Register rn, Register rm);
void usax(Register rd, Register rn, Register rm) { usax(al, rd, rn, rm); }
void usub16(Condition cond, Register rd, Register rn, Register rm);
void usub16(Register rd, Register rn, Register rm) { usub16(al, rd, rn, rm); }
void usub8(Condition cond, Register rd, Register rn, Register rm);
void usub8(Register rd, Register rn, Register rm) { usub8(al, rd, rn, rm); }
void uxtab(Condition cond, Register rd, Register rn, const Operand& operand);
void uxtab(Register rd, Register rn, const Operand& operand) {
uxtab(al, rd, rn, operand);
}
void uxtab16(Condition cond,
Register rd,
Register rn,
const Operand& operand);
void uxtab16(Register rd, Register rn, const Operand& operand) {
uxtab16(al, rd, rn, operand);
}
void uxtah(Condition cond, Register rd, Register rn, const Operand& operand);
void uxtah(Register rd, Register rn, const Operand& operand) {
uxtah(al, rd, rn, operand);
}
void uxtb(Condition cond,
EncodingSize size,
Register rd,
const Operand& operand);
void uxtb(Register rd, const Operand& operand) {
uxtb(al, Best, rd, operand);
}
void uxtb(Condition cond, Register rd, const Operand& operand) {
uxtb(cond, Best, rd, operand);
}
void uxtb(EncodingSize size, Register rd, const Operand& operand) {
uxtb(al, size, rd, operand);
}
void uxtb16(Condition cond, Register rd, const Operand& operand);
void uxtb16(Register rd, const Operand& operand) { uxtb16(al, rd, operand); }
void uxth(Condition cond,
EncodingSize size,
Register rd,
const Operand& operand);
void uxth(Register rd, const Operand& operand) {
uxth(al, Best, rd, operand);
}
void uxth(Condition cond, Register rd, const Operand& operand) {
uxth(cond, Best, rd, operand);
}
void uxth(EncodingSize size, Register rd, const Operand& operand) {
uxth(al, size, rd, operand);
}
void vaba(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vaba(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vaba(al, dt, rd, rn, rm);
}
void vaba(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vaba(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vaba(al, dt, rd, rn, rm);
}
void vabal(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vabal(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vabal(al, dt, rd, rn, rm);
}
void vabd(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vabd(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vabd(al, dt, rd, rn, rm);
}
void vabd(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vabd(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vabd(al, dt, rd, rn, rm);
}
void vabdl(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vabdl(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vabdl(al, dt, rd, rn, rm);
}
void vabs(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vabs(DataType dt, DRegister rd, DRegister rm) { vabs(al, dt, rd, rm); }
void vabs(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vabs(DataType dt, QRegister rd, QRegister rm) { vabs(al, dt, rd, rm); }
void vabs(Condition cond, DataType dt, SRegister rd, SRegister rm);
void vabs(DataType dt, SRegister rd, SRegister rm) { vabs(al, dt, rd, rm); }
void vacge(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vacge(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vacge(al, dt, rd, rn, rm);
}
void vacge(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vacge(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vacge(al, dt, rd, rn, rm);
}
void vacgt(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vacgt(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vacgt(al, dt, rd, rn, rm);
}
void vacgt(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vacgt(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vacgt(al, dt, rd, rn, rm);
}
void vacle(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vacle(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vacle(al, dt, rd, rn, rm);
}
void vacle(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vacle(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vacle(al, dt, rd, rn, rm);
}
void vaclt(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vaclt(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vaclt(al, dt, rd, rn, rm);
}
void vaclt(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vaclt(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vaclt(al, dt, rd, rn, rm);
}
void vadd(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vadd(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vadd(al, dt, rd, rn, rm);
}
void vadd(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vadd(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vadd(al, dt, rd, rn, rm);
}
void vadd(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vadd(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vadd(al, dt, rd, rn, rm);
}
void vaddhn(
Condition cond, DataType dt, DRegister rd, QRegister rn, QRegister rm);
void vaddhn(DataType dt, DRegister rd, QRegister rn, QRegister rm) {
vaddhn(al, dt, rd, rn, rm);
}
void vaddl(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vaddl(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vaddl(al, dt, rd, rn, rm);
}
void vaddw(
Condition cond, DataType dt, QRegister rd, QRegister rn, DRegister rm);
void vaddw(DataType dt, QRegister rd, QRegister rn, DRegister rm) {
vaddw(al, dt, rd, rn, rm);
}
void vand(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
const DOperand& operand);
void vand(DataType dt, DRegister rd, DRegister rn, const DOperand& operand) {
vand(al, dt, rd, rn, operand);
}
void vand(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
const QOperand& operand);
void vand(DataType dt, QRegister rd, QRegister rn, const QOperand& operand) {
vand(al, dt, rd, rn, operand);
}
void vbic(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
const DOperand& operand);
void vbic(DataType dt, DRegister rd, DRegister rn, const DOperand& operand) {
vbic(al, dt, rd, rn, operand);
}
void vbic(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
const QOperand& operand);
void vbic(DataType dt, QRegister rd, QRegister rn, const QOperand& operand) {
vbic(al, dt, rd, rn, operand);
}
void vbif(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vbif(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vbif(al, dt, rd, rn, rm);
}
void vbif(DRegister rd, DRegister rn, DRegister rm) {
vbif(al, kDataTypeValueNone, rd, rn, rm);
}
void vbif(Condition cond, DRegister rd, DRegister rn, DRegister rm) {
vbif(cond, kDataTypeValueNone, rd, rn, rm);
}
void vbif(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vbif(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vbif(al, dt, rd, rn, rm);
}
void vbif(QRegister rd, QRegister rn, QRegister rm) {
vbif(al, kDataTypeValueNone, rd, rn, rm);
}
void vbif(Condition cond, QRegister rd, QRegister rn, QRegister rm) {
vbif(cond, kDataTypeValueNone, rd, rn, rm);
}
void vbit(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vbit(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vbit(al, dt, rd, rn, rm);
}
void vbit(DRegister rd, DRegister rn, DRegister rm) {
vbit(al, kDataTypeValueNone, rd, rn, rm);
}
void vbit(Condition cond, DRegister rd, DRegister rn, DRegister rm) {
vbit(cond, kDataTypeValueNone, rd, rn, rm);
}
void vbit(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vbit(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vbit(al, dt, rd, rn, rm);
}
void vbit(QRegister rd, QRegister rn, QRegister rm) {
vbit(al, kDataTypeValueNone, rd, rn, rm);
}
void vbit(Condition cond, QRegister rd, QRegister rn, QRegister rm) {
vbit(cond, kDataTypeValueNone, rd, rn, rm);
}
void vbsl(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vbsl(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vbsl(al, dt, rd, rn, rm);
}
void vbsl(DRegister rd, DRegister rn, DRegister rm) {
vbsl(al, kDataTypeValueNone, rd, rn, rm);
}
void vbsl(Condition cond, DRegister rd, DRegister rn, DRegister rm) {
vbsl(cond, kDataTypeValueNone, rd, rn, rm);
}
void vbsl(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vbsl(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vbsl(al, dt, rd, rn, rm);
}
void vbsl(QRegister rd, QRegister rn, QRegister rm) {
vbsl(al, kDataTypeValueNone, rd, rn, rm);
}
void vbsl(Condition cond, QRegister rd, QRegister rn, QRegister rm) {
vbsl(cond, kDataTypeValueNone, rd, rn, rm);
}
void vceq(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vceq(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vceq(al, dt, rd, rm, operand);
}
void vceq(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vceq(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vceq(al, dt, rd, rm, operand);
}
void vceq(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vceq(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vceq(al, dt, rd, rn, rm);
}
void vceq(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vceq(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vceq(al, dt, rd, rn, rm);
}
void vcge(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vcge(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vcge(al, dt, rd, rm, operand);
}
void vcge(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vcge(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vcge(al, dt, rd, rm, operand);
}
void vcge(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vcge(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vcge(al, dt, rd, rn, rm);
}
void vcge(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vcge(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vcge(al, dt, rd, rn, rm);
}
void vcgt(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vcgt(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vcgt(al, dt, rd, rm, operand);
}
void vcgt(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vcgt(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vcgt(al, dt, rd, rm, operand);
}
void vcgt(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vcgt(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vcgt(al, dt, rd, rn, rm);
}
void vcgt(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vcgt(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vcgt(al, dt, rd, rn, rm);
}
void vcle(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vcle(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vcle(al, dt, rd, rm, operand);
}
void vcle(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vcle(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vcle(al, dt, rd, rm, operand);
}
void vcle(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vcle(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vcle(al, dt, rd, rn, rm);
}
void vcle(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vcle(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vcle(al, dt, rd, rn, rm);
}
void vcls(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vcls(DataType dt, DRegister rd, DRegister rm) { vcls(al, dt, rd, rm); }
void vcls(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vcls(DataType dt, QRegister rd, QRegister rm) { vcls(al, dt, rd, rm); }
void vclt(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vclt(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vclt(al, dt, rd, rm, operand);
}
void vclt(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vclt(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vclt(al, dt, rd, rm, operand);
}
void vclt(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vclt(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vclt(al, dt, rd, rn, rm);
}
void vclt(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vclt(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vclt(al, dt, rd, rn, rm);
}
void vclz(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vclz(DataType dt, DRegister rd, DRegister rm) { vclz(al, dt, rd, rm); }
void vclz(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vclz(DataType dt, QRegister rd, QRegister rm) { vclz(al, dt, rd, rm); }
void vcmp(Condition cond, DataType dt, SRegister rd, SRegister rm);
void vcmp(DataType dt, SRegister rd, SRegister rm) { vcmp(al, dt, rd, rm); }
void vcmp(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vcmp(DataType dt, DRegister rd, DRegister rm) { vcmp(al, dt, rd, rm); }
void vcmp(Condition cond, DataType dt, SRegister rd, double imm);
void vcmp(DataType dt, SRegister rd, double imm) { vcmp(al, dt, rd, imm); }
void vcmp(Condition cond, DataType dt, DRegister rd, double imm);
void vcmp(DataType dt, DRegister rd, double imm) { vcmp(al, dt, rd, imm); }
void vcmpe(Condition cond, DataType dt, SRegister rd, SRegister rm);
void vcmpe(DataType dt, SRegister rd, SRegister rm) { vcmpe(al, dt, rd, rm); }
void vcmpe(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vcmpe(DataType dt, DRegister rd, DRegister rm) { vcmpe(al, dt, rd, rm); }
void vcmpe(Condition cond, DataType dt, SRegister rd, double imm);
void vcmpe(DataType dt, SRegister rd, double imm) { vcmpe(al, dt, rd, imm); }
void vcmpe(Condition cond, DataType dt, DRegister rd, double imm);
void vcmpe(DataType dt, DRegister rd, double imm) { vcmpe(al, dt, rd, imm); }
void vcnt(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vcnt(DataType dt, DRegister rd, DRegister rm) { vcnt(al, dt, rd, rm); }
void vcnt(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vcnt(DataType dt, QRegister rd, QRegister rm) { vcnt(al, dt, rd, rm); }
void vcvt(
Condition cond, DataType dt1, DataType dt2, DRegister rd, SRegister rm);
void vcvt(DataType dt1, DataType dt2, DRegister rd, SRegister rm) {
vcvt(al, dt1, dt2, rd, rm);
}
void vcvt(
Condition cond, DataType dt1, DataType dt2, SRegister rd, DRegister rm);
void vcvt(DataType dt1, DataType dt2, SRegister rd, DRegister rm) {
vcvt(al, dt1, dt2, rd, rm);
}
void vcvt(Condition cond,
DataType dt1,
DataType dt2,
DRegister rd,
DRegister rm,
int32_t fbits);
void vcvt(
DataType dt1, DataType dt2, DRegister rd, DRegister rm, int32_t fbits) {
vcvt(al, dt1, dt2, rd, rm, fbits);
}
void vcvt(Condition cond,
DataType dt1,
DataType dt2,
QRegister rd,
QRegister rm,
int32_t fbits);
void vcvt(
DataType dt1, DataType dt2, QRegister rd, QRegister rm, int32_t fbits) {
vcvt(al, dt1, dt2, rd, rm, fbits);
}
void vcvt(Condition cond,
DataType dt1,
DataType dt2,
SRegister rd,
SRegister rm,
int32_t fbits);
void vcvt(
DataType dt1, DataType dt2, SRegister rd, SRegister rm, int32_t fbits) {
vcvt(al, dt1, dt2, rd, rm, fbits);
}
void vcvt(
Condition cond, DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vcvt(DataType dt1, DataType dt2, DRegister rd, DRegister rm) {
vcvt(al, dt1, dt2, rd, rm);
}
void vcvt(
Condition cond, DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vcvt(DataType dt1, DataType dt2, QRegister rd, QRegister rm) {
vcvt(al, dt1, dt2, rd, rm);
}
void vcvt(
Condition cond, DataType dt1, DataType dt2, DRegister rd, QRegister rm);
void vcvt(DataType dt1, DataType dt2, DRegister rd, QRegister rm) {
vcvt(al, dt1, dt2, rd, rm);
}
void vcvt(
Condition cond, DataType dt1, DataType dt2, QRegister rd, DRegister rm);
void vcvt(DataType dt1, DataType dt2, QRegister rd, DRegister rm) {
vcvt(al, dt1, dt2, rd, rm);
}
void vcvt(
Condition cond, DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vcvt(DataType dt1, DataType dt2, SRegister rd, SRegister rm) {
vcvt(al, dt1, dt2, rd, rm);
}
void vcvta(DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vcvta(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vcvta(DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vcvta(DataType dt1, DataType dt2, SRegister rd, DRegister rm);
void vcvtb(
Condition cond, DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vcvtb(DataType dt1, DataType dt2, SRegister rd, SRegister rm) {
vcvtb(al, dt1, dt2, rd, rm);
}
void vcvtb(
Condition cond, DataType dt1, DataType dt2, DRegister rd, SRegister rm);
void vcvtb(DataType dt1, DataType dt2, DRegister rd, SRegister rm) {
vcvtb(al, dt1, dt2, rd, rm);
}
void vcvtb(
Condition cond, DataType dt1, DataType dt2, SRegister rd, DRegister rm);
void vcvtb(DataType dt1, DataType dt2, SRegister rd, DRegister rm) {
vcvtb(al, dt1, dt2, rd, rm);
}
void vcvtm(DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vcvtm(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vcvtm(DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vcvtm(DataType dt1, DataType dt2, SRegister rd, DRegister rm);
void vcvtn(DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vcvtn(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vcvtn(DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vcvtn(DataType dt1, DataType dt2, SRegister rd, DRegister rm);
void vcvtp(DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vcvtp(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vcvtp(DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vcvtp(DataType dt1, DataType dt2, SRegister rd, DRegister rm);
void vcvtr(
Condition cond, DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vcvtr(DataType dt1, DataType dt2, SRegister rd, SRegister rm) {
vcvtr(al, dt1, dt2, rd, rm);
}
void vcvtr(
Condition cond, DataType dt1, DataType dt2, SRegister rd, DRegister rm);
void vcvtr(DataType dt1, DataType dt2, SRegister rd, DRegister rm) {
vcvtr(al, dt1, dt2, rd, rm);
}
void vcvtt(
Condition cond, DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vcvtt(DataType dt1, DataType dt2, SRegister rd, SRegister rm) {
vcvtt(al, dt1, dt2, rd, rm);
}
void vcvtt(
Condition cond, DataType dt1, DataType dt2, DRegister rd, SRegister rm);
void vcvtt(DataType dt1, DataType dt2, DRegister rd, SRegister rm) {
vcvtt(al, dt1, dt2, rd, rm);
}
void vcvtt(
Condition cond, DataType dt1, DataType dt2, SRegister rd, DRegister rm);
void vcvtt(DataType dt1, DataType dt2, SRegister rd, DRegister rm) {
vcvtt(al, dt1, dt2, rd, rm);
}
void vdiv(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vdiv(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vdiv(al, dt, rd, rn, rm);
}
void vdiv(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vdiv(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vdiv(al, dt, rd, rn, rm);
}
void vdup(Condition cond, DataType dt, QRegister rd, Register rt);
void vdup(DataType dt, QRegister rd, Register rt) { vdup(al, dt, rd, rt); }
void vdup(Condition cond, DataType dt, DRegister rd, Register rt);
void vdup(DataType dt, DRegister rd, Register rt) { vdup(al, dt, rd, rt); }
void vdup(Condition cond, DataType dt, DRegister rd, DRegisterLane rm);
void vdup(DataType dt, DRegister rd, DRegisterLane rm) {
vdup(al, dt, rd, rm);
}
void vdup(Condition cond, DataType dt, QRegister rd, DRegisterLane rm);
void vdup(DataType dt, QRegister rd, DRegisterLane rm) {
vdup(al, dt, rd, rm);
}
void veor(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void veor(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
veor(al, dt, rd, rn, rm);
}
void veor(DRegister rd, DRegister rn, DRegister rm) {
veor(al, kDataTypeValueNone, rd, rn, rm);
}
void veor(Condition cond, DRegister rd, DRegister rn, DRegister rm) {
veor(cond, kDataTypeValueNone, rd, rn, rm);
}
void veor(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void veor(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
veor(al, dt, rd, rn, rm);
}
void veor(QRegister rd, QRegister rn, QRegister rm) {
veor(al, kDataTypeValueNone, rd, rn, rm);
}
void veor(Condition cond, QRegister rd, QRegister rn, QRegister rm) {
veor(cond, kDataTypeValueNone, rd, rn, rm);
}
void vext(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
DRegister rm,
const DOperand& operand);
void vext(DataType dt,
DRegister rd,
DRegister rn,
DRegister rm,
const DOperand& operand) {
vext(al, dt, rd, rn, rm, operand);
}
void vext(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
QRegister rm,
const QOperand& operand);
void vext(DataType dt,
QRegister rd,
QRegister rn,
QRegister rm,
const QOperand& operand) {
vext(al, dt, rd, rn, rm, operand);
}
void vfma(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vfma(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vfma(al, dt, rd, rn, rm);
}
void vfma(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vfma(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vfma(al, dt, rd, rn, rm);
}
void vfma(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vfma(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vfma(al, dt, rd, rn, rm);
}
void vfms(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vfms(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vfms(al, dt, rd, rn, rm);
}
void vfms(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vfms(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vfms(al, dt, rd, rn, rm);
}
void vfms(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vfms(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vfms(al, dt, rd, rn, rm);
}
void vfnma(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vfnma(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vfnma(al, dt, rd, rn, rm);
}
void vfnma(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vfnma(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vfnma(al, dt, rd, rn, rm);
}
void vfnms(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vfnms(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vfnms(al, dt, rd, rn, rm);
}
void vfnms(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vfnms(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vfnms(al, dt, rd, rn, rm);
}
void vhadd(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vhadd(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vhadd(al, dt, rd, rn, rm);
}
void vhadd(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vhadd(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vhadd(al, dt, rd, rn, rm);
}
void vhsub(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vhsub(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vhsub(al, dt, rd, rn, rm);
}
void vhsub(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vhsub(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vhsub(al, dt, rd, rn, rm);
}
void vld1(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand);
void vld1(DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand) {
vld1(al, dt, nreglist, operand);
}
void vld2(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand);
void vld2(DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand) {
vld2(al, dt, nreglist, operand);
}
void vld3(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand);
void vld3(DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand) {
vld3(al, dt, nreglist, operand);
}
void vld3(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const MemOperand& operand);
void vld3(DataType dt,
const NeonRegisterList& nreglist,
const MemOperand& operand) {
vld3(al, dt, nreglist, operand);
}
void vld4(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand);
void vld4(DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand) {
vld4(al, dt, nreglist, operand);
}
void vldm(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void vldm(DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vldm(al, dt, rn, write_back, dreglist);
}
void vldm(Register rn, WriteBack write_back, DRegisterList dreglist) {
vldm(al, kDataTypeValueNone, rn, write_back, dreglist);
}
void vldm(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vldm(cond, kDataTypeValueNone, rn, write_back, dreglist);
}
void vldm(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist);
void vldm(DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vldm(al, dt, rn, write_back, sreglist);
}
void vldm(Register rn, WriteBack write_back, SRegisterList sreglist) {
vldm(al, kDataTypeValueNone, rn, write_back, sreglist);
}
void vldm(Condition cond,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vldm(cond, kDataTypeValueNone, rn, write_back, sreglist);
}
void vldmdb(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void vldmdb(DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vldmdb(al, dt, rn, write_back, dreglist);
}
void vldmdb(Register rn, WriteBack write_back, DRegisterList dreglist) {
vldmdb(al, kDataTypeValueNone, rn, write_back, dreglist);
}
void vldmdb(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vldmdb(cond, kDataTypeValueNone, rn, write_back, dreglist);
}
void vldmdb(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist);
void vldmdb(DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vldmdb(al, dt, rn, write_back, sreglist);
}
void vldmdb(Register rn, WriteBack write_back, SRegisterList sreglist) {
vldmdb(al, kDataTypeValueNone, rn, write_back, sreglist);
}
void vldmdb(Condition cond,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vldmdb(cond, kDataTypeValueNone, rn, write_back, sreglist);
}
void vldmia(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void vldmia(DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vldmia(al, dt, rn, write_back, dreglist);
}
void vldmia(Register rn, WriteBack write_back, DRegisterList dreglist) {
vldmia(al, kDataTypeValueNone, rn, write_back, dreglist);
}
void vldmia(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vldmia(cond, kDataTypeValueNone, rn, write_back, dreglist);
}
void vldmia(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist);
void vldmia(DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vldmia(al, dt, rn, write_back, sreglist);
}
void vldmia(Register rn, WriteBack write_back, SRegisterList sreglist) {
vldmia(al, kDataTypeValueNone, rn, write_back, sreglist);
}
void vldmia(Condition cond,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vldmia(cond, kDataTypeValueNone, rn, write_back, sreglist);
}
void vldr(Condition cond, DataType dt, DRegister rd, Label* label);
void vldr(DataType dt, DRegister rd, Label* label) {
vldr(al, dt, rd, label);
}
void vldr(DRegister rd, Label* label) { vldr(al, Untyped64, rd, label); }
void vldr(Condition cond, DRegister rd, Label* label) {
vldr(cond, Untyped64, rd, label);
}
void vldr(Condition cond,
DataType dt,
DRegister rd,
const MemOperand& operand);
void vldr(DataType dt, DRegister rd, const MemOperand& operand) {
vldr(al, dt, rd, operand);
}
void vldr(DRegister rd, const MemOperand& operand) {
vldr(al, Untyped64, rd, operand);
}
void vldr(Condition cond, DRegister rd, const MemOperand& operand) {
vldr(cond, Untyped64, rd, operand);
}
void vldr(Condition cond, DataType dt, SRegister rd, Label* label);
void vldr(DataType dt, SRegister rd, Label* label) {
vldr(al, dt, rd, label);
}
void vldr(SRegister rd, Label* label) { vldr(al, Untyped32, rd, label); }
void vldr(Condition cond, SRegister rd, Label* label) {
vldr(cond, Untyped32, rd, label);
}
void vldr(Condition cond,
DataType dt,
SRegister rd,
const MemOperand& operand);
void vldr(DataType dt, SRegister rd, const MemOperand& operand) {
vldr(al, dt, rd, operand);
}
void vldr(SRegister rd, const MemOperand& operand) {
vldr(al, Untyped32, rd, operand);
}
void vldr(Condition cond, SRegister rd, const MemOperand& operand) {
vldr(cond, Untyped32, rd, operand);
}
void vmax(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vmax(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vmax(al, dt, rd, rn, rm);
}
void vmax(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vmax(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vmax(al, dt, rd, rn, rm);
}
void vmaxnm(DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vmaxnm(DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vmaxnm(DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vmin(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vmin(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vmin(al, dt, rd, rn, rm);
}
void vmin(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vmin(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vmin(al, dt, rd, rn, rm);
}
void vminnm(DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vminnm(DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vminnm(DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vmla(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
DRegisterLane rm);
void vmla(DataType dt, DRegister rd, DRegister rn, DRegisterLane rm) {
vmla(al, dt, rd, rn, rm);
}
void vmla(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
DRegisterLane rm);
void vmla(DataType dt, QRegister rd, QRegister rn, DRegisterLane rm) {
vmla(al, dt, rd, rn, rm);
}
void vmla(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vmla(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vmla(al, dt, rd, rn, rm);
}
void vmla(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vmla(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vmla(al, dt, rd, rn, rm);
}
void vmla(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vmla(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vmla(al, dt, rd, rn, rm);
}
void vmlal(Condition cond,
DataType dt,
QRegister rd,
DRegister rn,
DRegisterLane rm);
void vmlal(DataType dt, QRegister rd, DRegister rn, DRegisterLane rm) {
vmlal(al, dt, rd, rn, rm);
}
void vmlal(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vmlal(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vmlal(al, dt, rd, rn, rm);
}
void vmls(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
DRegisterLane rm);
void vmls(DataType dt, DRegister rd, DRegister rn, DRegisterLane rm) {
vmls(al, dt, rd, rn, rm);
}
void vmls(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
DRegisterLane rm);
void vmls(DataType dt, QRegister rd, QRegister rn, DRegisterLane rm) {
vmls(al, dt, rd, rn, rm);
}
void vmls(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vmls(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vmls(al, dt, rd, rn, rm);
}
void vmls(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vmls(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vmls(al, dt, rd, rn, rm);
}
void vmls(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vmls(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vmls(al, dt, rd, rn, rm);
}
void vmlsl(Condition cond,
DataType dt,
QRegister rd,
DRegister rn,
DRegisterLane rm);
void vmlsl(DataType dt, QRegister rd, DRegister rn, DRegisterLane rm) {
vmlsl(al, dt, rd, rn, rm);
}
void vmlsl(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vmlsl(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vmlsl(al, dt, rd, rn, rm);
}
void vmov(Condition cond, Register rt, SRegister rn);
void vmov(Register rt, SRegister rn) { vmov(al, rt, rn); }
void vmov(Condition cond, SRegister rn, Register rt);
void vmov(SRegister rn, Register rt) { vmov(al, rn, rt); }
void vmov(Condition cond, Register rt, Register rt2, DRegister rm);
void vmov(Register rt, Register rt2, DRegister rm) { vmov(al, rt, rt2, rm); }
void vmov(Condition cond, DRegister rm, Register rt, Register rt2);
void vmov(DRegister rm, Register rt, Register rt2) { vmov(al, rm, rt, rt2); }
void vmov(
Condition cond, Register rt, Register rt2, SRegister rm, SRegister rm1);
void vmov(Register rt, Register rt2, SRegister rm, SRegister rm1) {
vmov(al, rt, rt2, rm, rm1);
}
void vmov(
Condition cond, SRegister rm, SRegister rm1, Register rt, Register rt2);
void vmov(SRegister rm, SRegister rm1, Register rt, Register rt2) {
vmov(al, rm, rm1, rt, rt2);
}
void vmov(Condition cond, DataType dt, DRegisterLane rd, Register rt);
void vmov(DataType dt, DRegisterLane rd, Register rt) {
vmov(al, dt, rd, rt);
}
void vmov(DRegisterLane rd, Register rt) {
vmov(al, kDataTypeValueNone, rd, rt);
}
void vmov(Condition cond, DRegisterLane rd, Register rt) {
vmov(cond, kDataTypeValueNone, rd, rt);
}
void vmov(Condition cond, DataType dt, DRegister rd, const DOperand& operand);
void vmov(DataType dt, DRegister rd, const DOperand& operand) {
vmov(al, dt, rd, operand);
}
void vmov(Condition cond, DataType dt, QRegister rd, const QOperand& operand);
void vmov(DataType dt, QRegister rd, const QOperand& operand) {
vmov(al, dt, rd, operand);
}
void vmov(Condition cond, DataType dt, SRegister rd, const SOperand& operand);
void vmov(DataType dt, SRegister rd, const SOperand& operand) {
vmov(al, dt, rd, operand);
}
void vmov(Condition cond, DataType dt, Register rt, DRegisterLane rn);
void vmov(DataType dt, Register rt, DRegisterLane rn) {
vmov(al, dt, rt, rn);
}
void vmov(Register rt, DRegisterLane rn) {
vmov(al, kDataTypeValueNone, rt, rn);
}
void vmov(Condition cond, Register rt, DRegisterLane rn) {
vmov(cond, kDataTypeValueNone, rt, rn);
}
void vmovl(Condition cond, DataType dt, QRegister rd, DRegister rm);
void vmovl(DataType dt, QRegister rd, DRegister rm) { vmovl(al, dt, rd, rm); }
void vmovn(Condition cond, DataType dt, DRegister rd, QRegister rm);
void vmovn(DataType dt, DRegister rd, QRegister rm) { vmovn(al, dt, rd, rm); }
void vmrs(Condition cond, RegisterOrAPSR_nzcv rt, SpecialFPRegister spec_reg);
void vmrs(RegisterOrAPSR_nzcv rt, SpecialFPRegister spec_reg) {
vmrs(al, rt, spec_reg);
}
void vmsr(Condition cond, SpecialFPRegister spec_reg, Register rt);
void vmsr(SpecialFPRegister spec_reg, Register rt) { vmsr(al, spec_reg, rt); }
void vmul(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
DRegister dm,
unsigned index);
void vmul(
DataType dt, DRegister rd, DRegister rn, DRegister dm, unsigned index) {
vmul(al, dt, rd, rn, dm, index);
}
void vmul(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
DRegister dm,
unsigned index);
void vmul(
DataType dt, QRegister rd, QRegister rn, DRegister dm, unsigned index) {
vmul(al, dt, rd, rn, dm, index);
}
void vmul(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vmul(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vmul(al, dt, rd, rn, rm);
}
void vmul(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vmul(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vmul(al, dt, rd, rn, rm);
}
void vmul(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vmul(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vmul(al, dt, rd, rn, rm);
}
void vmull(Condition cond,
DataType dt,
QRegister rd,
DRegister rn,
DRegister dm,
unsigned index);
void vmull(
DataType dt, QRegister rd, DRegister rn, DRegister dm, unsigned index) {
vmull(al, dt, rd, rn, dm, index);
}
void vmull(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vmull(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vmull(al, dt, rd, rn, rm);
}
void vmvn(Condition cond, DataType dt, DRegister rd, const DOperand& operand);
void vmvn(DataType dt, DRegister rd, const DOperand& operand) {
vmvn(al, dt, rd, operand);
}
void vmvn(Condition cond, DataType dt, QRegister rd, const QOperand& operand);
void vmvn(DataType dt, QRegister rd, const QOperand& operand) {
vmvn(al, dt, rd, operand);
}
void vneg(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vneg(DataType dt, DRegister rd, DRegister rm) { vneg(al, dt, rd, rm); }
void vneg(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vneg(DataType dt, QRegister rd, QRegister rm) { vneg(al, dt, rd, rm); }
void vneg(Condition cond, DataType dt, SRegister rd, SRegister rm);
void vneg(DataType dt, SRegister rd, SRegister rm) { vneg(al, dt, rd, rm); }
void vnmla(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vnmla(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vnmla(al, dt, rd, rn, rm);
}
void vnmla(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vnmla(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vnmla(al, dt, rd, rn, rm);
}
void vnmls(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vnmls(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vnmls(al, dt, rd, rn, rm);
}
void vnmls(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vnmls(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vnmls(al, dt, rd, rn, rm);
}
void vnmul(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vnmul(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vnmul(al, dt, rd, rn, rm);
}
void vnmul(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vnmul(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vnmul(al, dt, rd, rn, rm);
}
void vorn(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
const DOperand& operand);
void vorn(DataType dt, DRegister rd, DRegister rn, const DOperand& operand) {
vorn(al, dt, rd, rn, operand);
}
void vorn(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
const QOperand& operand);
void vorn(DataType dt, QRegister rd, QRegister rn, const QOperand& operand) {
vorn(al, dt, rd, rn, operand);
}
void vorr(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
const DOperand& operand);
void vorr(DataType dt, DRegister rd, DRegister rn, const DOperand& operand) {
vorr(al, dt, rd, rn, operand);
}
void vorr(DRegister rd, DRegister rn, const DOperand& operand) {
vorr(al, kDataTypeValueNone, rd, rn, operand);
}
void vorr(Condition cond,
DRegister rd,
DRegister rn,
const DOperand& operand) {
vorr(cond, kDataTypeValueNone, rd, rn, operand);
}
void vorr(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
const QOperand& operand);
void vorr(DataType dt, QRegister rd, QRegister rn, const QOperand& operand) {
vorr(al, dt, rd, rn, operand);
}
void vorr(QRegister rd, QRegister rn, const QOperand& operand) {
vorr(al, kDataTypeValueNone, rd, rn, operand);
}
void vorr(Condition cond,
QRegister rd,
QRegister rn,
const QOperand& operand) {
vorr(cond, kDataTypeValueNone, rd, rn, operand);
}
void vpadal(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vpadal(DataType dt, DRegister rd, DRegister rm) {
vpadal(al, dt, rd, rm);
}
void vpadal(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vpadal(DataType dt, QRegister rd, QRegister rm) {
vpadal(al, dt, rd, rm);
}
void vpadd(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vpadd(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vpadd(al, dt, rd, rn, rm);
}
void vpaddl(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vpaddl(DataType dt, DRegister rd, DRegister rm) {
vpaddl(al, dt, rd, rm);
}
void vpaddl(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vpaddl(DataType dt, QRegister rd, QRegister rm) {
vpaddl(al, dt, rd, rm);
}
void vpmax(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vpmax(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vpmax(al, dt, rd, rn, rm);
}
void vpmin(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vpmin(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vpmin(al, dt, rd, rn, rm);
}
void vpop(Condition cond, DataType dt, DRegisterList dreglist);
void vpop(DataType dt, DRegisterList dreglist) { vpop(al, dt, dreglist); }
void vpop(DRegisterList dreglist) { vpop(al, kDataTypeValueNone, dreglist); }
void vpop(Condition cond, DRegisterList dreglist) {
vpop(cond, kDataTypeValueNone, dreglist);
}
void vpop(Condition cond, DataType dt, SRegisterList sreglist);
void vpop(DataType dt, SRegisterList sreglist) { vpop(al, dt, sreglist); }
void vpop(SRegisterList sreglist) { vpop(al, kDataTypeValueNone, sreglist); }
void vpop(Condition cond, SRegisterList sreglist) {
vpop(cond, kDataTypeValueNone, sreglist);
}
void vpush(Condition cond, DataType dt, DRegisterList dreglist);
void vpush(DataType dt, DRegisterList dreglist) { vpush(al, dt, dreglist); }
void vpush(DRegisterList dreglist) {
vpush(al, kDataTypeValueNone, dreglist);
}
void vpush(Condition cond, DRegisterList dreglist) {
vpush(cond, kDataTypeValueNone, dreglist);
}
void vpush(Condition cond, DataType dt, SRegisterList sreglist);
void vpush(DataType dt, SRegisterList sreglist) { vpush(al, dt, sreglist); }
void vpush(SRegisterList sreglist) {
vpush(al, kDataTypeValueNone, sreglist);
}
void vpush(Condition cond, SRegisterList sreglist) {
vpush(cond, kDataTypeValueNone, sreglist);
}
void vqabs(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vqabs(DataType dt, DRegister rd, DRegister rm) { vqabs(al, dt, rd, rm); }
void vqabs(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vqabs(DataType dt, QRegister rd, QRegister rm) { vqabs(al, dt, rd, rm); }
void vqadd(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vqadd(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vqadd(al, dt, rd, rn, rm);
}
void vqadd(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vqadd(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vqadd(al, dt, rd, rn, rm);
}
void vqdmlal(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vqdmlal(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vqdmlal(al, dt, rd, rn, rm);
}
void vqdmlal(Condition cond,
DataType dt,
QRegister rd,
DRegister rn,
DRegister dm,
unsigned index);
void vqdmlal(
DataType dt, QRegister rd, DRegister rn, DRegister dm, unsigned index) {
vqdmlal(al, dt, rd, rn, dm, index);
}
void vqdmlsl(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vqdmlsl(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vqdmlsl(al, dt, rd, rn, rm);
}
void vqdmlsl(Condition cond,
DataType dt,
QRegister rd,
DRegister rn,
DRegister dm,
unsigned index);
void vqdmlsl(
DataType dt, QRegister rd, DRegister rn, DRegister dm, unsigned index) {
vqdmlsl(al, dt, rd, rn, dm, index);
}
void vqdmulh(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vqdmulh(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vqdmulh(al, dt, rd, rn, rm);
}
void vqdmulh(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vqdmulh(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vqdmulh(al, dt, rd, rn, rm);
}
void vqdmulh(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
DRegisterLane rm);
void vqdmulh(DataType dt, DRegister rd, DRegister rn, DRegisterLane rm) {
vqdmulh(al, dt, rd, rn, rm);
}
void vqdmulh(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
DRegisterLane rm);
void vqdmulh(DataType dt, QRegister rd, QRegister rn, DRegisterLane rm) {
vqdmulh(al, dt, rd, rn, rm);
}
void vqdmull(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vqdmull(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vqdmull(al, dt, rd, rn, rm);
}
void vqdmull(Condition cond,
DataType dt,
QRegister rd,
DRegister rn,
DRegisterLane rm);
void vqdmull(DataType dt, QRegister rd, DRegister rn, DRegisterLane rm) {
vqdmull(al, dt, rd, rn, rm);
}
void vqmovn(Condition cond, DataType dt, DRegister rd, QRegister rm);
void vqmovn(DataType dt, DRegister rd, QRegister rm) {
vqmovn(al, dt, rd, rm);
}
void vqmovun(Condition cond, DataType dt, DRegister rd, QRegister rm);
void vqmovun(DataType dt, DRegister rd, QRegister rm) {
vqmovun(al, dt, rd, rm);
}
void vqneg(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vqneg(DataType dt, DRegister rd, DRegister rm) { vqneg(al, dt, rd, rm); }
void vqneg(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vqneg(DataType dt, QRegister rd, QRegister rm) { vqneg(al, dt, rd, rm); }
void vqrdmulh(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vqrdmulh(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vqrdmulh(al, dt, rd, rn, rm);
}
void vqrdmulh(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vqrdmulh(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vqrdmulh(al, dt, rd, rn, rm);
}
void vqrdmulh(Condition cond,
DataType dt,
DRegister rd,
DRegister rn,
DRegisterLane rm);
void vqrdmulh(DataType dt, DRegister rd, DRegister rn, DRegisterLane rm) {
vqrdmulh(al, dt, rd, rn, rm);
}
void vqrdmulh(Condition cond,
DataType dt,
QRegister rd,
QRegister rn,
DRegisterLane rm);
void vqrdmulh(DataType dt, QRegister rd, QRegister rn, DRegisterLane rm) {
vqrdmulh(al, dt, rd, rn, rm);
}
void vqrshl(
Condition cond, DataType dt, DRegister rd, DRegister rm, DRegister rn);
void vqrshl(DataType dt, DRegister rd, DRegister rm, DRegister rn) {
vqrshl(al, dt, rd, rm, rn);
}
void vqrshl(
Condition cond, DataType dt, QRegister rd, QRegister rm, QRegister rn);
void vqrshl(DataType dt, QRegister rd, QRegister rm, QRegister rn) {
vqrshl(al, dt, rd, rm, rn);
}
void vqrshrn(Condition cond,
DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand);
void vqrshrn(DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand) {
vqrshrn(al, dt, rd, rm, operand);
}
void vqrshrun(Condition cond,
DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand);
void vqrshrun(DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand) {
vqrshrun(al, dt, rd, rm, operand);
}
void vqshl(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vqshl(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vqshl(al, dt, rd, rm, operand);
}
void vqshl(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vqshl(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vqshl(al, dt, rd, rm, operand);
}
void vqshlu(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vqshlu(DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand) {
vqshlu(al, dt, rd, rm, operand);
}
void vqshlu(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vqshlu(DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand) {
vqshlu(al, dt, rd, rm, operand);
}
void vqshrn(Condition cond,
DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand);
void vqshrn(DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand) {
vqshrn(al, dt, rd, rm, operand);
}
void vqshrun(Condition cond,
DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand);
void vqshrun(DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand) {
vqshrun(al, dt, rd, rm, operand);
}
void vqsub(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vqsub(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vqsub(al, dt, rd, rn, rm);
}
void vqsub(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vqsub(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vqsub(al, dt, rd, rn, rm);
}
void vraddhn(
Condition cond, DataType dt, DRegister rd, QRegister rn, QRegister rm);
void vraddhn(DataType dt, DRegister rd, QRegister rn, QRegister rm) {
vraddhn(al, dt, rd, rn, rm);
}
void vrecpe(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vrecpe(DataType dt, DRegister rd, DRegister rm) {
vrecpe(al, dt, rd, rm);
}
void vrecpe(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vrecpe(DataType dt, QRegister rd, QRegister rm) {
vrecpe(al, dt, rd, rm);
}
void vrecps(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vrecps(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vrecps(al, dt, rd, rn, rm);
}
void vrecps(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vrecps(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vrecps(al, dt, rd, rn, rm);
}
void vrev16(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vrev16(DataType dt, DRegister rd, DRegister rm) {
vrev16(al, dt, rd, rm);
}
void vrev16(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vrev16(DataType dt, QRegister rd, QRegister rm) {
vrev16(al, dt, rd, rm);
}
void vrev32(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vrev32(DataType dt, DRegister rd, DRegister rm) {
vrev32(al, dt, rd, rm);
}
void vrev32(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vrev32(DataType dt, QRegister rd, QRegister rm) {
vrev32(al, dt, rd, rm);
}
void vrev64(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vrev64(DataType dt, DRegister rd, DRegister rm) {
vrev64(al, dt, rd, rm);
}
void vrev64(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vrev64(DataType dt, QRegister rd, QRegister rm) {
vrev64(al, dt, rd, rm);
}
void vrhadd(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vrhadd(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vrhadd(al, dt, rd, rn, rm);
}
void vrhadd(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vrhadd(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vrhadd(al, dt, rd, rn, rm);
}
void vrinta(DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vrinta(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vrinta(DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vrintm(DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vrintm(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vrintm(DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vrintn(DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vrintn(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vrintn(DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vrintp(DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vrintp(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vrintp(DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vrintr(
Condition cond, DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vrintr(DataType dt1, DataType dt2, SRegister rd, SRegister rm) {
vrintr(al, dt1, dt2, rd, rm);
}
void vrintr(
Condition cond, DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vrintr(DataType dt1, DataType dt2, DRegister rd, DRegister rm) {
vrintr(al, dt1, dt2, rd, rm);
}
void vrintx(
Condition cond, DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vrintx(DataType dt1, DataType dt2, DRegister rd, DRegister rm) {
vrintx(al, dt1, dt2, rd, rm);
}
void vrintx(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vrintx(
Condition cond, DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vrintx(DataType dt1, DataType dt2, SRegister rd, SRegister rm) {
vrintx(al, dt1, dt2, rd, rm);
}
void vrintz(
Condition cond, DataType dt1, DataType dt2, DRegister rd, DRegister rm);
void vrintz(DataType dt1, DataType dt2, DRegister rd, DRegister rm) {
vrintz(al, dt1, dt2, rd, rm);
}
void vrintz(DataType dt1, DataType dt2, QRegister rd, QRegister rm);
void vrintz(
Condition cond, DataType dt1, DataType dt2, SRegister rd, SRegister rm);
void vrintz(DataType dt1, DataType dt2, SRegister rd, SRegister rm) {
vrintz(al, dt1, dt2, rd, rm);
}
void vrshl(
Condition cond, DataType dt, DRegister rd, DRegister rm, DRegister rn);
void vrshl(DataType dt, DRegister rd, DRegister rm, DRegister rn) {
vrshl(al, dt, rd, rm, rn);
}
void vrshl(
Condition cond, DataType dt, QRegister rd, QRegister rm, QRegister rn);
void vrshl(DataType dt, QRegister rd, QRegister rm, QRegister rn) {
vrshl(al, dt, rd, rm, rn);
}
void vrshr(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vrshr(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vrshr(al, dt, rd, rm, operand);
}
void vrshr(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vrshr(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vrshr(al, dt, rd, rm, operand);
}
void vrshrn(Condition cond,
DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand);
void vrshrn(DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand) {
vrshrn(al, dt, rd, rm, operand);
}
void vrsqrte(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vrsqrte(DataType dt, DRegister rd, DRegister rm) {
vrsqrte(al, dt, rd, rm);
}
void vrsqrte(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vrsqrte(DataType dt, QRegister rd, QRegister rm) {
vrsqrte(al, dt, rd, rm);
}
void vrsqrts(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vrsqrts(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vrsqrts(al, dt, rd, rn, rm);
}
void vrsqrts(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vrsqrts(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vrsqrts(al, dt, rd, rn, rm);
}
void vrsra(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vrsra(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vrsra(al, dt, rd, rm, operand);
}
void vrsra(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vrsra(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vrsra(al, dt, rd, rm, operand);
}
void vrsubhn(
Condition cond, DataType dt, DRegister rd, QRegister rn, QRegister rm);
void vrsubhn(DataType dt, DRegister rd, QRegister rn, QRegister rm) {
vrsubhn(al, dt, rd, rn, rm);
}
void vseleq(DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vseleq(DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vselge(DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vselge(DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vselgt(DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vselgt(DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vselvs(DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vselvs(DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vshl(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vshl(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vshl(al, dt, rd, rm, operand);
}
void vshl(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vshl(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vshl(al, dt, rd, rm, operand);
}
void vshll(Condition cond,
DataType dt,
QRegister rd,
DRegister rm,
const DOperand& operand);
void vshll(DataType dt, QRegister rd, DRegister rm, const DOperand& operand) {
vshll(al, dt, rd, rm, operand);
}
void vshr(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vshr(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vshr(al, dt, rd, rm, operand);
}
void vshr(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vshr(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vshr(al, dt, rd, rm, operand);
}
void vshrn(Condition cond,
DataType dt,
DRegister rd,
QRegister rm,
const QOperand& operand);
void vshrn(DataType dt, DRegister rd, QRegister rm, const QOperand& operand) {
vshrn(al, dt, rd, rm, operand);
}
void vsli(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vsli(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vsli(al, dt, rd, rm, operand);
}
void vsli(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vsli(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vsli(al, dt, rd, rm, operand);
}
void vsqrt(Condition cond, DataType dt, SRegister rd, SRegister rm);
void vsqrt(DataType dt, SRegister rd, SRegister rm) { vsqrt(al, dt, rd, rm); }
void vsqrt(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vsqrt(DataType dt, DRegister rd, DRegister rm) { vsqrt(al, dt, rd, rm); }
void vsra(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vsra(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vsra(al, dt, rd, rm, operand);
}
void vsra(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vsra(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vsra(al, dt, rd, rm, operand);
}
void vsri(Condition cond,
DataType dt,
DRegister rd,
DRegister rm,
const DOperand& operand);
void vsri(DataType dt, DRegister rd, DRegister rm, const DOperand& operand) {
vsri(al, dt, rd, rm, operand);
}
void vsri(Condition cond,
DataType dt,
QRegister rd,
QRegister rm,
const QOperand& operand);
void vsri(DataType dt, QRegister rd, QRegister rm, const QOperand& operand) {
vsri(al, dt, rd, rm, operand);
}
void vst1(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand);
void vst1(DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand) {
vst1(al, dt, nreglist, operand);
}
void vst2(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand);
void vst2(DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand) {
vst2(al, dt, nreglist, operand);
}
void vst3(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand);
void vst3(DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand) {
vst3(al, dt, nreglist, operand);
}
void vst3(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const MemOperand& operand);
void vst3(DataType dt,
const NeonRegisterList& nreglist,
const MemOperand& operand) {
vst3(al, dt, nreglist, operand);
}
void vst4(Condition cond,
DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand);
void vst4(DataType dt,
const NeonRegisterList& nreglist,
const AlignedMemOperand& operand) {
vst4(al, dt, nreglist, operand);
}
void vstm(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void vstm(DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vstm(al, dt, rn, write_back, dreglist);
}
void vstm(Register rn, WriteBack write_back, DRegisterList dreglist) {
vstm(al, kDataTypeValueNone, rn, write_back, dreglist);
}
void vstm(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vstm(cond, kDataTypeValueNone, rn, write_back, dreglist);
}
void vstm(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist);
void vstm(DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vstm(al, dt, rn, write_back, sreglist);
}
void vstm(Register rn, WriteBack write_back, SRegisterList sreglist) {
vstm(al, kDataTypeValueNone, rn, write_back, sreglist);
}
void vstm(Condition cond,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vstm(cond, kDataTypeValueNone, rn, write_back, sreglist);
}
void vstmdb(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void vstmdb(DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vstmdb(al, dt, rn, write_back, dreglist);
}
void vstmdb(Register rn, WriteBack write_back, DRegisterList dreglist) {
vstmdb(al, kDataTypeValueNone, rn, write_back, dreglist);
}
void vstmdb(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vstmdb(cond, kDataTypeValueNone, rn, write_back, dreglist);
}
void vstmdb(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist);
void vstmdb(DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vstmdb(al, dt, rn, write_back, sreglist);
}
void vstmdb(Register rn, WriteBack write_back, SRegisterList sreglist) {
vstmdb(al, kDataTypeValueNone, rn, write_back, sreglist);
}
void vstmdb(Condition cond,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vstmdb(cond, kDataTypeValueNone, rn, write_back, sreglist);
}
void vstmia(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist);
void vstmia(DataType dt,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vstmia(al, dt, rn, write_back, dreglist);
}
void vstmia(Register rn, WriteBack write_back, DRegisterList dreglist) {
vstmia(al, kDataTypeValueNone, rn, write_back, dreglist);
}
void vstmia(Condition cond,
Register rn,
WriteBack write_back,
DRegisterList dreglist) {
vstmia(cond, kDataTypeValueNone, rn, write_back, dreglist);
}
void vstmia(Condition cond,
DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist);
void vstmia(DataType dt,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vstmia(al, dt, rn, write_back, sreglist);
}
void vstmia(Register rn, WriteBack write_back, SRegisterList sreglist) {
vstmia(al, kDataTypeValueNone, rn, write_back, sreglist);
}
void vstmia(Condition cond,
Register rn,
WriteBack write_back,
SRegisterList sreglist) {
vstmia(cond, kDataTypeValueNone, rn, write_back, sreglist);
}
void vstr(Condition cond,
DataType dt,
DRegister rd,
const MemOperand& operand);
void vstr(DataType dt, DRegister rd, const MemOperand& operand) {
vstr(al, dt, rd, operand);
}
void vstr(DRegister rd, const MemOperand& operand) {
vstr(al, Untyped64, rd, operand);
}
void vstr(Condition cond, DRegister rd, const MemOperand& operand) {
vstr(cond, Untyped64, rd, operand);
}
void vstr(Condition cond,
DataType dt,
SRegister rd,
const MemOperand& operand);
void vstr(DataType dt, SRegister rd, const MemOperand& operand) {
vstr(al, dt, rd, operand);
}
void vstr(SRegister rd, const MemOperand& operand) {
vstr(al, Untyped32, rd, operand);
}
void vstr(Condition cond, SRegister rd, const MemOperand& operand) {
vstr(cond, Untyped32, rd, operand);
}
void vsub(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vsub(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vsub(al, dt, rd, rn, rm);
}
void vsub(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vsub(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vsub(al, dt, rd, rn, rm);
}
void vsub(
Condition cond, DataType dt, SRegister rd, SRegister rn, SRegister rm);
void vsub(DataType dt, SRegister rd, SRegister rn, SRegister rm) {
vsub(al, dt, rd, rn, rm);
}
void vsubhn(
Condition cond, DataType dt, DRegister rd, QRegister rn, QRegister rm);
void vsubhn(DataType dt, DRegister rd, QRegister rn, QRegister rm) {
vsubhn(al, dt, rd, rn, rm);
}
void vsubl(
Condition cond, DataType dt, QRegister rd, DRegister rn, DRegister rm);
void vsubl(DataType dt, QRegister rd, DRegister rn, DRegister rm) {
vsubl(al, dt, rd, rn, rm);
}
void vsubw(
Condition cond, DataType dt, QRegister rd, QRegister rn, DRegister rm);
void vsubw(DataType dt, QRegister rd, QRegister rn, DRegister rm) {
vsubw(al, dt, rd, rn, rm);
}
void vswp(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vswp(DataType dt, DRegister rd, DRegister rm) { vswp(al, dt, rd, rm); }
void vswp(DRegister rd, DRegister rm) {
vswp(al, kDataTypeValueNone, rd, rm);
}
void vswp(Condition cond, DRegister rd, DRegister rm) {
vswp(cond, kDataTypeValueNone, rd, rm);
}
void vswp(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vswp(DataType dt, QRegister rd, QRegister rm) { vswp(al, dt, rd, rm); }
void vswp(QRegister rd, QRegister rm) {
vswp(al, kDataTypeValueNone, rd, rm);
}
void vswp(Condition cond, QRegister rd, QRegister rm) {
vswp(cond, kDataTypeValueNone, rd, rm);
}
void vtbl(Condition cond,
DataType dt,
DRegister rd,
const NeonRegisterList& nreglist,
DRegister rm);
void vtbl(DataType dt,
DRegister rd,
const NeonRegisterList& nreglist,
DRegister rm) {
vtbl(al, dt, rd, nreglist, rm);
}
void vtbx(Condition cond,
DataType dt,
DRegister rd,
const NeonRegisterList& nreglist,
DRegister rm);
void vtbx(DataType dt,
DRegister rd,
const NeonRegisterList& nreglist,
DRegister rm) {
vtbx(al, dt, rd, nreglist, rm);
}
void vtrn(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vtrn(DataType dt, DRegister rd, DRegister rm) { vtrn(al, dt, rd, rm); }
void vtrn(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vtrn(DataType dt, QRegister rd, QRegister rm) { vtrn(al, dt, rd, rm); }
void vtst(
Condition cond, DataType dt, DRegister rd, DRegister rn, DRegister rm);
void vtst(DataType dt, DRegister rd, DRegister rn, DRegister rm) {
vtst(al, dt, rd, rn, rm);
}
void vtst(
Condition cond, DataType dt, QRegister rd, QRegister rn, QRegister rm);
void vtst(DataType dt, QRegister rd, QRegister rn, QRegister rm) {
vtst(al, dt, rd, rn, rm);
}
void vuzp(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vuzp(DataType dt, DRegister rd, DRegister rm) { vuzp(al, dt, rd, rm); }
void vuzp(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vuzp(DataType dt, QRegister rd, QRegister rm) { vuzp(al, dt, rd, rm); }
void vzip(Condition cond, DataType dt, DRegister rd, DRegister rm);
void vzip(DataType dt, DRegister rd, DRegister rm) { vzip(al, dt, rd, rm); }
void vzip(Condition cond, DataType dt, QRegister rd, QRegister rm);
void vzip(DataType dt, QRegister rd, QRegister rm) { vzip(al, dt, rd, rm); }
void yield(Condition cond, EncodingSize size);
void yield() { yield(al, Best); }
void yield(Condition cond) { yield(cond, Best); }
void yield(EncodingSize size) { yield(al, size); }
// End of generated code.
virtual void UnimplementedDelegate(InstructionType type) {
std::string error_message(std::string("Ill-formed '") +
std::string(ToCString(type)) +
std::string("' instruction.\n"));
VIXL_ABORT_WITH_MSG(error_message.c_str());
}
virtual bool AllowUnpredictable() { return allow_unpredictable_; }
virtual bool AllowStronglyDiscouraged() {
return allow_strongly_discouraged_;
}
};
} // namespace aarch32
} // namespace vixl
#endif // VIXL_AARCH32_ASSEMBLER_AARCH32_H_