| //===- HexagonIntrinsicsV4.td - V4 Instruction intrinsics --*- tablegen -*-===// |
| // |
| // The LLVM Compiler Infrastructure |
| // |
| // This file is distributed under the University of Illinois Open Source |
| // License. See LICENSE.TXT for details. |
| // |
| //===----------------------------------------------------------------------===// |
| // This is populated based on the following specs: |
| // Hexagon V4 Architecture Extensions |
| // Application-Level Specification |
| // 80-V9418-12 Rev. A |
| // June 15, 2010 |
| |
| |
| // |
| // ALU 32 types. |
| // |
| |
| class si_ALU32_sisi_not<string opc, Intrinsic IntID> |
| : ALU32_rr<(outs IntRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2), |
| !strconcat("$dst = ", !strconcat(opc , "($src1, ~$src2)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2))]>; |
| |
| class di_ALU32_s8si<string opc, Intrinsic IntID> |
| : ALU32_rr<(outs DoubleRegs:$dst), (ins s8Imm:$src1, IntRegs:$src2), |
| !strconcat("$dst = ", !strconcat(opc , "(#$src1, $src2)")), |
| [(set DoubleRegs:$dst, (IntID imm:$src1, IntRegs:$src2))]>; |
| |
| class di_ALU32_sis8<string opc, Intrinsic IntID> |
| : ALU32_rr<(outs DoubleRegs:$dst), (ins IntRegs:$src1, s8Imm:$src2), |
| !strconcat("$dst = ", !strconcat(opc , "($src1, #$src2)")), |
| [(set DoubleRegs:$dst, (IntID IntRegs:$src1, imm:$src2))]>; |
| |
| class qi_neg_ALU32_sisi<string opc, Intrinsic IntID> |
| : ALU32_rr<(outs PredRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2), |
| !strconcat("$dst = !", !strconcat(opc , "($src1, $src2)")), |
| [(set PredRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2))]>; |
| |
| class qi_neg_ALU32_sis10<string opc, Intrinsic IntID> |
| : ALU32_rr<(outs PredRegs:$dst), (ins IntRegs:$src1, s10Imm:$src2), |
| !strconcat("$dst = !", !strconcat(opc , "($src1, #$src2)")), |
| [(set PredRegs:$dst, (IntID IntRegs:$src1, imm:$src2))]>; |
| |
| class qi_neg_ALU32_siu9<string opc, Intrinsic IntID> |
| : ALU32_rr<(outs PredRegs:$dst), (ins IntRegs:$src1, u9Imm:$src2), |
| !strconcat("$dst = !", !strconcat(opc , "($src1, #$src2)")), |
| [(set PredRegs:$dst, (IntID IntRegs:$src1, imm:$src2))]>; |
| |
| class si_neg_ALU32_sisi<string opc, Intrinsic IntID> |
| : ALU32_rr<(outs IntRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2), |
| !strconcat("$dst = !", !strconcat(opc , "($src1, $src2)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2))]>; |
| |
| class si_neg_ALU32_sis8<string opc, Intrinsic IntID> |
| : ALU32_rr<(outs IntRegs:$dst), (ins IntRegs:$src1, s8Imm:$src2), |
| !strconcat("$dst = !", !strconcat(opc , "($src1, #$src2)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$src1, imm:$src2))]>; |
| |
| class si_ALU32_sis8<string opc, Intrinsic IntID> |
| : ALU32_rr<(outs IntRegs:$dst), (ins IntRegs:$src1, s8Imm:$src2), |
| !strconcat("$dst = ", !strconcat(opc , "($src1, #$src2)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$src1, imm:$src2))]>; |
| |
| |
| // |
| // SInst Classes. |
| // |
| class qi_neg_SInst_qiqi<string opc, Intrinsic IntID> |
| : SInst<(outs PredRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2), |
| !strconcat("$dst = !", !strconcat(opc , "($src1, $src2)")), |
| [(set PredRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2))]>; |
| |
| class qi_SInst_qi_andqiqi_neg<string opc, Intrinsic IntID> |
| : SInst<(outs PredRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst = ", !strconcat(opc , |
| "($src1, and($src2, !$src3)")), |
| [(set PredRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class qi_SInst_qi_andqiqi<string opc, Intrinsic IntID> |
| : SInst<(outs PredRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst = ", !strconcat(opc , |
| "($src1, and($src2, $src3)")), |
| [(set PredRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class qi_SInst_qi_orqiqi_neg<string opc, Intrinsic IntID> |
| : SInst<(outs PredRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst = ", !strconcat(opc , |
| "($src1, or($src2, !$src3)")), |
| [(set PredRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class qi_SInst_qi_orqiqi<string opc, Intrinsic IntID> |
| : SInst<(outs PredRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst = ", !strconcat(opc , |
| "($src1, or($src2, $src3)")), |
| [(set PredRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class si_SInst_si_addsis6<string opc, Intrinsic IntID> |
| : SInst<(outs IntRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2, s6Imm:$src3), |
| !strconcat("$dst = ", !strconcat(opc , |
| "($src1, add($src2, #$src3)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2, |
| imm:$src3))]>; |
| |
| class si_SInst_si_subs6si<string opc, Intrinsic IntID> |
| : SInst<(outs IntRegs:$dst), (ins IntRegs:$src1, s6Imm:$src2, IntRegs:$src3), |
| !strconcat("$dst = ", !strconcat(opc , |
| "($src1, sub(#$src2, $src3)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$src1, imm:$src2, |
| IntRegs:$src3))]>; |
| |
| class di_ALU64_didi_neg<string opc, Intrinsic IntID> |
| : ALU64_rr<(outs DoubleRegs:$dst), (ins DoubleRegs:$src1, DoubleRegs:$src2), |
| !strconcat("$dst = ", !strconcat(opc , "($src1, ~$src2)")), |
| [(set DoubleRegs:$dst, (IntID DoubleRegs:$src1, DoubleRegs:$src2))]>; |
| |
| class di_MInst_dididi_xacc<string opc, Intrinsic IntID> |
| : MInst_acc<(outs DoubleRegs:$dst), (ins DoubleRegs:$dst2, DoubleRegs:$src1, |
| DoubleRegs:$src2), |
| !strconcat("$dst ^= ", !strconcat(opc , "($src1, $src2)")), |
| [(set DoubleRegs:$dst, (IntID DoubleRegs:$dst2, DoubleRegs:$src1, |
| DoubleRegs:$src2))], |
| "$dst2 = $dst">; |
| |
| class si_MInst_sisisi_and<string opc, Intrinsic IntID> |
| : MInst<(outs IntRegs:$dst), (ins IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst &= ", !strconcat(opc , "($src2, $src3)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class si_MInst_sisisi_andn<string opc, Intrinsic IntID> |
| : MInst<(outs IntRegs:$dst), (ins IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst &= ", !strconcat(opc , "($src2, ~$src3)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class si_SInst_sisis10_andi<string opc, Intrinsic IntID> |
| : SInst<(outs IntRegs:$dst), (ins IntRegs:$src1, IntRegs:$src2, s10Imm:$src3), |
| !strconcat("$dst = ", !strconcat(opc , |
| "($src1, and($src2, #$src3))")), |
| [(set IntRegs:$dst, (IntID IntRegs:$src1, IntRegs:$src2, |
| imm:$src3))]>; |
| |
| class si_MInst_sisisi_xor<string opc, Intrinsic IntID> |
| : MInst<(outs IntRegs:$dst), (ins IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst ^= ", !strconcat(opc , "($src2, $src3)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class si_MInst_sisisi_xorn<string opc, Intrinsic IntID> |
| : MInst<(outs IntRegs:$dst), (ins IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst ^= ", !strconcat(opc , "($src2, ~$src3)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class si_SInst_sisis10_or<string opc, Intrinsic IntID> |
| : SInst<(outs IntRegs:$dst), (ins IntRegs:$dst1, IntRegs:$src2, s10Imm:$src3), |
| !strconcat("$dst |= ", !strconcat(opc , "($src2, #$src3)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$dst1, IntRegs:$src2, |
| imm:$src3))]>; |
| |
| class si_MInst_sisisi_or<string opc, Intrinsic IntID> |
| : MInst<(outs IntRegs:$dst), (ins IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst |= ", !strconcat(opc , "($src2, $src3)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class si_MInst_sisisi_orn<string opc, Intrinsic IntID> |
| : MInst<(outs IntRegs:$dst), (ins IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3), |
| !strconcat("$dst |= ", !strconcat(opc , "($src2, ~$src3)")), |
| [(set IntRegs:$dst, (IntID IntRegs:$dst1, IntRegs:$src2, |
| IntRegs:$src3))]>; |
| |
| class si_SInst_siu5_sat<string opc, Intrinsic IntID> |
| : SInst<(outs IntRegs:$dst), (ins IntRegs:$src1, u5Imm:$src2), |
| !strconcat("$dst = ", !strconcat(opc , "($src1, #$src2):sat")), |
| [(set IntRegs:$dst, (IntID IntRegs:$src1, imm:$src2))]>; |
| |
| |
| /******************************************************************** |
| * ALU32/ALU * |
| *********************************************************************/ |
| |
| // ALU32 / ALU / Logical Operations. |
| def Hexagon_A4_orn : si_ALU32_sisi_not <"or", int_hexagon_A4_orn>; |
| def Hexagon_A4_andn : si_ALU32_sisi_not <"and", int_hexagon_A4_andn>; |
| |
| |
| /******************************************************************** |
| * ALU32/PERM * |
| *********************************************************************/ |
| |
| // ALU32 / PERM / Combine Words Into Doublewords. |
| def Hexagon_A4_combineir : di_ALU32_s8si <"combine", int_hexagon_A4_combineir>; |
| def Hexagon_A4_combineri : di_ALU32_sis8 <"combine", int_hexagon_A4_combineri>; |
| |
| |
| /******************************************************************** |
| * ALU32/PRED * |
| *********************************************************************/ |
| |
| // ALU32 / PRED / Conditional Shift Halfword. |
| // ALU32 / PRED / Conditional Sign Extend. |
| // ALU32 / PRED / Conditional Zero Extend. |
| // ALU32 / PRED / Compare. |
| def Hexagon_C4_cmpneq : qi_neg_ALU32_sisi <"cmp.eq", int_hexagon_C4_cmpneq>; |
| def Hexagon_C4_cmpneqi : qi_neg_ALU32_sis10 <"cmp.eq", int_hexagon_C4_cmpneqi>; |
| def Hexagon_C4_cmplte : qi_neg_ALU32_sisi <"cmp.gt", int_hexagon_C4_cmplte>; |
| def Hexagon_C4_cmpltei : qi_neg_ALU32_sis10 <"cmp.gt", int_hexagon_C4_cmpltei>; |
| def Hexagon_C4_cmplteu : qi_neg_ALU32_sisi <"cmp.gtu",int_hexagon_C4_cmplteu>; |
| def Hexagon_C4_cmplteui: qi_neg_ALU32_siu9 <"cmp.gtu",int_hexagon_C4_cmplteui>; |
| |
| // ALU32 / PRED / cmpare To General Register. |
| def Hexagon_A4_rcmpneq : si_neg_ALU32_sisi <"cmp.eq", int_hexagon_A4_rcmpneq>; |
| def Hexagon_A4_rcmpneqi: si_neg_ALU32_sis8 <"cmp.eq", int_hexagon_A4_rcmpneqi>; |
| def Hexagon_A4_rcmpeq : si_ALU32_sisi <"cmp.eq", int_hexagon_A4_rcmpeq>; |
| def Hexagon_A4_rcmpeqi : si_ALU32_sis8 <"cmp.eq", int_hexagon_A4_rcmpeqi>; |
| |
| |
| /******************************************************************** |
| * CR * |
| *********************************************************************/ |
| |
| // CR / Corner Detection Acceleration. |
| def Hexagon_C4_fastcorner9: |
| qi_SInst_qiqi<"fastcorner9", int_hexagon_C4_fastcorner9>; |
| def Hexagon_C4_fastcorner9_not: |
| qi_neg_SInst_qiqi<"fastcorner9",int_hexagon_C4_fastcorner9_not>; |
| |
| // CR / Logical Operations On Predicates. |
| def Hexagon_C4_and_andn: |
| qi_SInst_qi_andqiqi_neg <"and", int_hexagon_C4_and_andn>; |
| def Hexagon_C4_and_and: |
| qi_SInst_qi_andqiqi <"and", int_hexagon_C4_and_and>; |
| def Hexagon_C4_and_orn: |
| qi_SInst_qi_orqiqi_neg <"and", int_hexagon_C4_and_orn>; |
| def Hexagon_C4_and_or: |
| qi_SInst_qi_orqiqi <"and", int_hexagon_C4_and_or>; |
| def Hexagon_C4_or_andn: |
| qi_SInst_qi_andqiqi_neg <"or", int_hexagon_C4_or_andn>; |
| def Hexagon_C4_or_and: |
| qi_SInst_qi_andqiqi <"or", int_hexagon_C4_or_and>; |
| def Hexagon_C4_or_orn: |
| qi_SInst_qi_orqiqi_neg <"or", int_hexagon_C4_or_orn>; |
| def Hexagon_C4_or_or: |
| qi_SInst_qi_orqiqi <"or", int_hexagon_C4_or_or>; |
| |
| |
| /******************************************************************** |
| * XTYPE/ALU * |
| *********************************************************************/ |
| |
| // XTYPE / ALU / Add And Accumulate. |
| def Hexagon_S4_addaddi: |
| si_SInst_si_addsis6 <"add", int_hexagon_S4_addaddi>; |
| def Hexagon_S4_subaddi: |
| si_SInst_si_subs6si <"add", int_hexagon_S4_subaddi>; |
| |
| // XTYPE / ALU / Logical Doublewords. |
| def Hexagon_S4_andnp: |
| di_ALU64_didi_neg <"and", int_hexagon_A4_andnp>; |
| def Hexagon_S4_ornp: |
| di_ALU64_didi_neg <"or", int_hexagon_A4_ornp>; |
| |
| // XTYPE / ALU / Logical-logical Doublewords. |
| def Hexagon_M4_xor_xacc: |
| di_MInst_dididi_xacc <"xor", int_hexagon_M4_xor_xacc>; |
| |
| // XTYPE / ALU / Logical-logical Words. |
| def HEXAGON_M4_and_and: |
| si_MInst_sisisi_and <"and", int_hexagon_M4_and_and>; |
| def HEXAGON_M4_and_or: |
| si_MInst_sisisi_and <"or", int_hexagon_M4_and_or>; |
| def HEXAGON_M4_and_xor: |
| si_MInst_sisisi_and <"xor", int_hexagon_M4_and_xor>; |
| def HEXAGON_M4_and_andn: |
| si_MInst_sisisi_andn <"and", int_hexagon_M4_and_andn>; |
| def HEXAGON_M4_xor_and: |
| si_MInst_sisisi_xor <"and", int_hexagon_M4_xor_and>; |
| def HEXAGON_M4_xor_or: |
| si_MInst_sisisi_xor <"or", int_hexagon_M4_xor_or>; |
| def HEXAGON_M4_xor_andn: |
| si_MInst_sisisi_xorn <"and", int_hexagon_M4_xor_andn>; |
| def HEXAGON_M4_or_and: |
| si_MInst_sisisi_or <"and", int_hexagon_M4_or_and>; |
| def HEXAGON_M4_or_or: |
| si_MInst_sisisi_or <"or", int_hexagon_M4_or_or>; |
| def HEXAGON_M4_or_xor: |
| si_MInst_sisisi_or <"xor", int_hexagon_M4_or_xor>; |
| def HEXAGON_M4_or_andn: |
| si_MInst_sisisi_orn <"and", int_hexagon_M4_or_andn>; |
| def HEXAGON_S4_or_andix: |
| si_SInst_sisis10_andi <"or", int_hexagon_S4_or_andix>; |
| def HEXAGON_S4_or_andi: |
| si_SInst_sisis10_or <"and", int_hexagon_S4_or_andi>; |
| def HEXAGON_S4_or_ori: |
| si_SInst_sisis10_or <"or", int_hexagon_S4_or_ori>; |
| |
| // XTYPE / ALU / Modulo wrap. |
| def HEXAGON_A4_modwrapu: |
| si_ALU64_sisi <"modwrap", int_hexagon_A4_modwrapu>; |
| |
| // XTYPE / ALU / Round. |
| def HEXAGON_A4_cround_ri: |
| si_SInst_siu5 <"cround", int_hexagon_A4_cround_ri>; |
| def HEXAGON_A4_cround_rr: |
| si_SInst_sisi <"cround", int_hexagon_A4_cround_rr>; |
| def HEXAGON_A4_round_ri: |
| si_SInst_siu5 <"round", int_hexagon_A4_round_ri>; |
| def HEXAGON_A4_round_rr: |
| si_SInst_sisi <"round", int_hexagon_A4_round_rr>; |
| def HEXAGON_A4_round_ri_sat: |
| si_SInst_siu5_sat <"round", int_hexagon_A4_round_ri_sat>; |
| def HEXAGON_A4_round_rr_sat: |
| si_SInst_sisi_sat <"round", int_hexagon_A4_round_rr_sat>; |
| |
| // XTYPE / ALU / Vector reduce add unsigned halfwords. |
| // XTYPE / ALU / Vector add bytes. |
| // XTYPE / ALU / Vector conditional negate. |
| // XTYPE / ALU / Vector maximum bytes. |
| // XTYPE / ALU / Vector reduce maximum halfwords. |
| // XTYPE / ALU / Vector reduce maximum words. |
| // XTYPE / ALU / Vector minimum bytes. |
| // XTYPE / ALU / Vector reduce minimum halfwords. |
| // XTYPE / ALU / Vector reduce minimum words. |
| // XTYPE / ALU / Vector subtract bytes. |
| |
| |
| /******************************************************************** |
| * XTYPE/BIT * |
| *********************************************************************/ |
| |
| // XTYPE / BIT / Count leading. |
| // XTYPE / BIT / Count trailing. |
| // XTYPE / BIT / Extract bitfield. |
| // XTYPE / BIT / Masked parity. |
| // XTYPE / BIT / Bit reverse. |
| // XTYPE / BIT / Split bitfield. |
| |
| |
| /******************************************************************** |
| * XTYPE/COMPLEX * |
| *********************************************************************/ |
| |
| // XTYPE / COMPLEX / Complex add/sub halfwords. |
| // XTYPE / COMPLEX / Complex add/sub words. |
| // XTYPE / COMPLEX / Complex multiply 32x16. |
| // XTYPE / COMPLEX / Vector reduce complex rotate. |
| |
| |
| /******************************************************************** |
| * XTYPE/MPY * |
| *********************************************************************/ |
| |
| // XTYPE / COMPLEX / Complex add/sub halfwords. |