diff options
Diffstat (limited to 'arch/mips/mm/uasm.c')
| -rw-r--r-- | arch/mips/mm/uasm.c | 59 | 
1 files changed, 53 insertions, 6 deletions
diff --git a/arch/mips/mm/uasm.c b/arch/mips/mm/uasm.c index b9d14b6c7f5..a01b0d6cedd 100644 --- a/arch/mips/mm/uasm.c +++ b/arch/mips/mm/uasm.c @@ -47,14 +47,16 @@ enum opcode {  	insn_addiu, insn_addu, insn_and, insn_andi, insn_bbit0, insn_bbit1,  	insn_beq, insn_beql, insn_bgez, insn_bgezl, insn_bltz, insn_bltzl,  	insn_bne, insn_cache, insn_daddiu, insn_daddu, insn_dins, insn_dinsm, -	insn_dmfc0, insn_dmtc0, insn_drotr, insn_drotr32, insn_dsll, +	insn_divu, insn_dmfc0, insn_dmtc0, insn_drotr, insn_drotr32, insn_dsll,  	insn_dsll32, insn_dsra, insn_dsrl, insn_dsrl32, insn_dsubu, insn_eret, -	insn_ext, insn_ins, insn_j, insn_jal, insn_jr, insn_ld, insn_ldx, -	insn_ll, insn_lld, insn_lui, insn_lw, insn_lwx, insn_mfc0, insn_mtc0, +	insn_ext, insn_ins, insn_j, insn_jal, insn_jalr, insn_jr, insn_lb, +	insn_ld, insn_ldx, insn_lh, insn_ll, insn_lld, insn_lui, insn_lw, +	insn_lwx, insn_mfc0, insn_mfhi, insn_mflo, insn_mtc0, insn_mul,  	insn_or, insn_ori, insn_pref, insn_rfe, insn_rotr, insn_sc, insn_scd, -	insn_sd, insn_sll, insn_sra, insn_srl, insn_subu, insn_sw, -	insn_syscall, insn_tlbp, insn_tlbr, insn_tlbwi, insn_tlbwr, insn_xor, -	insn_xori, +	insn_sd, insn_sll, insn_sllv, insn_slt, insn_sltiu, insn_sltu, insn_sra, +	insn_srl, insn_srlv, insn_subu, insn_sw, insn_sync, insn_syscall, +	insn_tlbp, insn_tlbr, insn_tlbwi, insn_tlbwr, insn_wait, insn_wsbh, +	insn_xor, insn_xori, insn_yield,  };  struct insn { @@ -137,6 +139,13 @@ Ip_u1u2u3(op)						\  }							\  UASM_EXPORT_SYMBOL(uasm_i##op); +#define I_s3s1s2(op)					\ +Ip_s3s1s2(op)						\ +{							\ +	build_insn(buf, insn##op, b, c, a);		\ +}							\ +UASM_EXPORT_SYMBOL(uasm_i##op); +  #define I_u2u1u3(op)					\  Ip_u2u1u3(op)						\  {							\ @@ -144,6 +153,13 @@ Ip_u2u1u3(op)						\  }							\  UASM_EXPORT_SYMBOL(uasm_i##op); +#define I_u3u2u1(op)					\ +Ip_u3u2u1(op)						\ +{							\ +	build_insn(buf, insn##op, c, b, a);		\ +}							\ +UASM_EXPORT_SYMBOL(uasm_i##op); +  #define I_u3u1u2(op)					\  Ip_u3u1u2(op)						\  {							\ @@ -200,6 +216,13 @@ Ip_u1u2(op)						\  }							\  UASM_EXPORT_SYMBOL(uasm_i##op); +#define I_u2u1(op)					\ +Ip_u1u2(op)						\ +{							\ +	build_insn(buf, insn##op, b, a);		\ +}							\ +UASM_EXPORT_SYMBOL(uasm_i##op); +  #define I_u1s2(op)					\  Ip_u1s2(op)						\  {							\ @@ -237,6 +260,7 @@ I_u1u2u3(_dmfc0)  I_u1u2u3(_dmtc0)  I_u2u1s3(_daddiu)  I_u3u1u2(_daddu) +I_u1u2(_divu)  I_u2u1u3(_dsll)  I_u2u1u3(_dsll32)  I_u2u1u3(_dsra) @@ -250,14 +274,20 @@ I_u2u1msbdu3(_ext)  I_u2u1msbu3(_ins)  I_u1(_j)  I_u1(_jal) +I_u2u1(_jalr)  I_u1(_jr) +I_u2s3u1(_lb)  I_u2s3u1(_ld) +I_u2s3u1(_lh)  I_u2s3u1(_ll)  I_u2s3u1(_lld)  I_u1s2(_lui)  I_u2s3u1(_lw)  I_u1u2u3(_mfc0) +I_u1(_mfhi) +I_u1(_mflo)  I_u1u2u3(_mtc0) +I_u3u1u2(_mul)  I_u2u1u3(_ori)  I_u3u1u2(_or)  I_0(_rfe) @@ -265,17 +295,26 @@ I_u2s3u1(_sc)  I_u2s3u1(_scd)  I_u2s3u1(_sd)  I_u2u1u3(_sll) +I_u3u2u1(_sllv) +I_s3s1s2(_slt) +I_u2u1s3(_sltiu) +I_u3u1u2(_sltu)  I_u2u1u3(_sra)  I_u2u1u3(_srl) +I_u3u2u1(_srlv)  I_u2u1u3(_rotr)  I_u3u1u2(_subu)  I_u2s3u1(_sw) +I_u1(_sync)  I_0(_tlbp)  I_0(_tlbr)  I_0(_tlbwi)  I_0(_tlbwr) +I_u1(_wait); +I_u2u1(_wsbh)  I_u3u1u2(_xor)  I_u2u1u3(_xori) +I_u2u1(_yield)  I_u2u1msbu3(_dins);  I_u2u1msb32u3(_dinsm);  I_u1(_syscall); @@ -469,6 +508,14 @@ void ISAFUNC(uasm_il_b)(u32 **p, struct uasm_reloc **r, int lid)  }  UASM_EXPORT_SYMBOL(ISAFUNC(uasm_il_b)); +void ISAFUNC(uasm_il_beq)(u32 **p, struct uasm_reloc **r, unsigned int r1, +			  unsigned int r2, int lid) +{ +	uasm_r_mips_pc16(r, *p, lid); +	ISAFUNC(uasm_i_beq)(p, r1, r2, 0); +} +UASM_EXPORT_SYMBOL(ISAFUNC(uasm_il_beq)); +  void ISAFUNC(uasm_il_beqz)(u32 **p, struct uasm_reloc **r, unsigned int reg,  			   int lid)  {  | 
