⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ia64.md

📁 linux下编程用 编译软件
💻 MD
📖 第 1 页 / 共 5 页
字号:
(define_insn_and_split "andbi3"  [(set (match_operand:BI 0 "register_operand" "=c,c,r")	(and:BI (match_operand:BI 1 "register_operand" "%0,0,r")		(match_operand:BI 2 "register_operand" "c,r,r")))]  ""  "@   #   tbit.nz.and.orcm %0, %I0 = %2, 0   and %0 = %2, %1"  "reload_completed   && GET_CODE (operands[0]) == REG && PR_REGNO_P (REGNO (operands[0]))   && GET_CODE (operands[2]) == REG && PR_REGNO_P (REGNO (operands[2]))"  [(cond_exec (eq (match_dup 2) (const_int 0))     (set (match_dup 0) (and:BI (ne:BI (const_int 0) (const_int 0))				(match_dup 0))))]  ""  [(set_attr "itanium_class" "unknown,tbit,ilog")])(define_insn_and_split "*andcmbi3"  [(set (match_operand:BI 0 "register_operand" "=c,c,r")	(and:BI (not:BI (match_operand:BI 1 "register_operand" "c,r,r"))		(match_operand:BI 2 "register_operand" "0,0,r")))]  ""  "@   #   tbit.z.and.orcm %0, %I0 = %1, 0   andcm %0 = %2, %1"  "reload_completed   && GET_CODE (operands[0]) == REG && PR_REGNO_P (REGNO (operands[0]))   && GET_CODE (operands[1]) == REG && PR_REGNO_P (REGNO (operands[1]))"  [(cond_exec (ne (match_dup 1) (const_int 0))     (set (match_dup 0) (and:BI (ne:BI (const_int 0) (const_int 0))				(match_dup 0))))]  ""  [(set_attr "itanium_class" "unknown,tbit,ilog")])(define_insn_and_split "iorbi3"  [(set (match_operand:BI 0 "register_operand" "=c,c,r")	(ior:BI (match_operand:BI 1 "register_operand" "%0,0,r")		(match_operand:BI 2 "register_operand" "c,r,r")))]  ""  "@   #   tbit.nz.or.andcm %0, %I0 = %2, 0   or %0 = %2, %1"  "reload_completed   && GET_CODE (operands[0]) == REG && PR_REGNO_P (REGNO (operands[0]))   && GET_CODE (operands[2]) == REG && PR_REGNO_P (REGNO (operands[2]))"  [(cond_exec (ne (match_dup 2) (const_int 0))     (set (match_dup 0) (ior:BI (eq:BI (const_int 0) (const_int 0))				(match_dup 0))))]  ""  [(set_attr "itanium_class" "unknown,tbit,ilog")])(define_insn_and_split "*iorcmbi3"  [(set (match_operand:BI 0 "register_operand" "=c,c")	(ior:BI (not:BI (match_operand:BI 1 "register_operand" "c,r"))		(match_operand:BI 2 "register_operand" "0,0")))]  ""  "@   #   tbit.z.or.andcm %0, %I0 = %1, 0"  "reload_completed   && GET_CODE (operands[0]) == REG && PR_REGNO_P (REGNO (operands[0]))   && GET_CODE (operands[1]) == REG && PR_REGNO_P (REGNO (operands[1]))"  [(cond_exec (eq (match_dup 1) (const_int 0))     (set (match_dup 0) (ior:BI (eq:BI (const_int 0) (const_int 0))				(match_dup 0))))]  ""  [(set_attr "itanium_class" "unknown,tbit")])(define_insn "one_cmplbi2"  [(set (match_operand:BI 0 "register_operand" "=c,r,c,&c")	(not:BI (match_operand:BI 1 "register_operand" "r,r,0,c")))   (clobber (match_scratch:BI 2 "=X,X,c,X"))]  ""  "@   tbit.z %0, %I0 = %1, 0   xor %0 = 1, %1   #   #"  [(set_attr "itanium_class" "tbit,ilog,unknown,unknown")])(define_split  [(set (match_operand:BI 0 "register_operand" "")	(not:BI (match_operand:BI 1 "register_operand" "")))   (clobber (match_scratch:BI 2 ""))]  "reload_completed   && GET_CODE (operands[0]) == REG && PR_REGNO_P (REGNO (operands[0]))   && rtx_equal_p (operands[0], operands[1])"  [(set (match_dup 4) (match_dup 3))   (set (match_dup 0) (const_int 1))   (cond_exec (ne (match_dup 2) (const_int 0))     (set (match_dup 0) (const_int 0)))   (set (match_dup 0) (unspec:BI [(match_dup 0)] UNSPEC_PRED_REL_MUTEX))]  "operands[3] = gen_rtx_REG (CCImode, REGNO (operands[1]));   operands[4] = gen_rtx_REG (CCImode, REGNO (operands[2]));")(define_split  [(set (match_operand:BI 0 "register_operand" "")	(not:BI (match_operand:BI 1 "register_operand" "")))   (clobber (match_scratch:BI 2 ""))]  "reload_completed   && GET_CODE (operands[0]) == REG && PR_REGNO_P (REGNO (operands[0]))   && GET_CODE (operands[1]) == REG && PR_REGNO_P (REGNO (operands[1]))   && ! rtx_equal_p (operands[0], operands[1])"  [(cond_exec (ne (match_dup 1) (const_int 0))     (set (match_dup 0) (const_int 0)))   (cond_exec (eq (match_dup 1) (const_int 0))     (set (match_dup 0) (const_int 1)))   (set (match_dup 0) (unspec:BI [(match_dup 0)] UNSPEC_PRED_REL_MUTEX))]  "")(define_insn "*cmpsi_and_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (match_operator:BI 4 "predicate_operator"		  [(match_operand:SI 2 "gr_reg_or_0_operand" "rO")		   (match_operand:SI 3 "gr_reg_or_8bit_operand" "rK")])		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp4.%C4.and.orcm %0, %I0 = %3, %r2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpsi_and_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (match_operator:BI 3 "signed_inequality_operator"		  [(match_operand:SI 2 "gr_register_operand" "r")		   (const_int 0)])		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp4.%C3.and.orcm %0, %I0 = r0, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpsi_andnot_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (not:BI (match_operator:BI 4 "predicate_operator"			 [(match_operand:SI 2 "gr_reg_or_0_operand" "rO")			  (match_operand:SI 3 "gr_reg_or_8bit_operand" "rK")]))		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp4.%C4.or.andcm %I0, %0 = %3, %r2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpsi_andnot_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (not:BI (match_operator:BI 3 "signed_inequality_operator"			  [(match_operand:SI 2 "gr_register_operand" "r")			   (const_int 0)]))		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp4.%C3.or.andcm %I0, %0 = r0, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpdi_and_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (match_operator:BI 4 "predicate_operator"		  [(match_operand:DI 2 "gr_register_operand" "r")		   (match_operand:DI 3 "gr_reg_or_8bit_operand" "rK")])		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp.%C4.and.orcm %0, %I0 = %3, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpdi_and_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (match_operator:BI 3 "signed_inequality_operator"		  [(match_operand:DI 2 "gr_register_operand" "r")		   (const_int 0)])		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp.%C3.and.orcm %0, %I0 = r0, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpdi_andnot_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (not:BI (match_operator:BI 4 "predicate_operator"			 [(match_operand:DI 2 "gr_register_operand" "r")			  (match_operand:DI 3 "gr_reg_or_8bit_operand" "rK")]))		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp.%C4.or.andcm %I0, %0 = %3, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpdi_andnot_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (not:BI (match_operator:BI 3 "signed_inequality_operator"			  [(match_operand:DI 2 "gr_register_operand" "r")			   (const_int 0)]))		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp.%C3.or.andcm %I0, %0 = r0, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*tbit_and_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (ne:BI (and:DI (match_operand:DI 1 "gr_register_operand" "r")			       (const_int 1))		       (const_int 0))		(match_operand:BI 2 "register_operand" "0")))]  ""  "tbit.nz.and.orcm %0, %I0 = %1, 0"  [(set_attr "itanium_class" "tbit")])(define_insn "*tbit_and_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (eq:BI (and:DI (match_operand:DI 1 "gr_register_operand" "r")			       (const_int 1))		       (const_int 0))		(match_operand:BI 2 "register_operand" "0")))]  ""  "tbit.z.and.orcm %0, %I0 = %1, 0"  [(set_attr "itanium_class" "tbit")])(define_insn "*tbit_and_2"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (ne:BI (zero_extract:DI			 (match_operand:DI 1 "gr_register_operand" "r")			 (const_int 1)			 (match_operand:DI 2 "const_int_operand" "n"))		       (const_int 0))		(match_operand:BI 3 "register_operand" "0")))]  ""  "tbit.nz.and.orcm %0, %I0 = %1, %2"  [(set_attr "itanium_class" "tbit")])(define_insn "*tbit_and_3"  [(set (match_operand:BI 0 "register_operand" "=c")	(and:BI (eq:BI (zero_extract:DI			 (match_operand:DI 1 "gr_register_operand" "r")			 (const_int 1)			 (match_operand:DI 2 "const_int_operand" "n"))		       (const_int 0))		(match_operand:BI 3 "register_operand" "0")))]  ""  "tbit.z.and.orcm %0, %I0 = %1, %2"  [(set_attr "itanium_class" "tbit")])(define_insn "*cmpsi_or_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (match_operator:BI 4 "predicate_operator"		  [(match_operand:SI 2 "gr_reg_or_0_operand" "rO")		   (match_operand:SI 3 "gr_reg_or_8bit_operand" "rK")])		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp4.%C4.or.andcm %0, %I0 = %3, %r2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpsi_or_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (match_operator:BI 3 "signed_inequality_operator"		  [(match_operand:SI 2 "gr_register_operand" "r")		   (const_int 0)])		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp4.%C3.or.andcm %0, %I0 = r0, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpsi_orcm_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (not:BI (match_operator:BI 4 "predicate_operator"			 [(match_operand:SI 2 "gr_reg_or_0_operand" "rO")			  (match_operand:SI 3 "gr_reg_or_8bit_operand" "rK")]))		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp4.%C4.and.orcm %I0, %0 = %3, %r2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpsi_orcm_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (not:BI (match_operator:BI 3 "signed_inequality_operator"			  [(match_operand:SI 2 "gr_register_operand" "r")			   (const_int 0)]))		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp4.%C3.and.orcm %I0, %0 = r0, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpdi_or_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (match_operator:BI 4 "predicate_operator"		  [(match_operand:DI 2 "gr_register_operand" "r")		   (match_operand:DI 3 "gr_reg_or_8bit_operand" "rK")])		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp.%C4.or.andcm %0, %I0 = %3, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpdi_or_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (match_operator:BI 3 "signed_inequality_operator"		  [(match_operand:DI 2 "gr_register_operand" "r")		   (const_int 0)])		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp.%C3.or.andcm %0, %I0 = r0, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpdi_orcm_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (not:BI (match_operator:BI 4 "predicate_operator"			 [(match_operand:DI 2 "gr_register_operand" "r")			  (match_operand:DI 3 "gr_reg_or_8bit_operand" "rK")]))		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp.%C4.and.orcm %I0, %0 = %3, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*cmpdi_orcm_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (not:BI (match_operator:BI 3 "signed_inequality_operator"			  [(match_operand:DI 2 "gr_register_operand" "r")			   (const_int 0)]))		(match_operand:BI 1 "register_operand" "0")))]  ""  "cmp.%C3.and.orcm %I0, %0 = r0, %2"  [(set_attr "itanium_class" "icmp")])(define_insn "*tbit_or_0"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (ne:BI (and:DI (match_operand:DI 1 "gr_register_operand" "r")			       (const_int 1))		       (const_int 0))		(match_operand:BI 2 "register_operand" "0")))]  ""  "tbit.nz.or.andcm %0, %I0 = %1, 0"  [(set_attr "itanium_class" "tbit")])(define_insn "*tbit_or_1"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (eq:BI (and:DI (match_operand:DI 1 "gr_register_operand" "r")			       (const_int 1))		       (const_int 0))		(match_operand:BI 2 "register_operand" "0")))]  ""  "tbit.z.or.andcm %0, %I0 = %1, 0"  [(set_attr "itanium_class" "tbit")])(define_insn "*tbit_or_2"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (ne:BI (zero_extract:DI			 (match_operand:DI 1 "gr_register_operand" "r")			 (const_int 1)			 (match_operand:DI 2 "const_int_operand" "n"))		       (const_int 0))		(match_operand:BI 3 "register_operand" "0")))]  ""  "tbit.nz.or.andcm %0, %I0 = %1, %2"  [(set_attr "itanium_class" "tbit")])(define_insn "*tbit_or_3"  [(set (match_operand:BI 0 "register_operand" "=c")	(ior:BI (eq:BI (zero_extract:DI			 (match_operand:DI 1 "gr_register_operand" "r")			 (const_int 1)			 (match_operand:DI 2 "const_int_operand" "n"))		       (const_int 0))		(match_operand:BI 3 "register_operand" "0")))]  ""  "tbit.z.or.andcm %0, %I0 = %1, %2"  [(set_attr "itanium_class" "tbit")]);; Transform test of and/or of setcc into parallel comparisons.(define_split  [(set (match_operand:BI 0 "register_operand" "")	(ne:BI (and:DI (ne:DI (match_operand:BI 2 "register_operand" "")			      (const_int 0))		       (match_operand:DI 3 "register_operand" ""))	       (const_int 0)))]  ""  [(set (match_dup 0)	(and:BI (ne:BI (and:DI (match_dup 3) (const_int 1)) (const_int 0))		(match_dup 2)))]  "")(define_split  [(set (match_operand:BI 0 "register_operand" "")	(eq:BI (and:DI (ne:DI (match_operand:BI 2 "register_operand" "")			      (const_int 0))		       (match_operand:DI 3 "register_operand" ""))	       (const_int 0)))]  ""  [(set (match_dup 0)	(and:BI (ne:BI (and:DI (match_dup 3) (const_int 1)) (const_int 0))		(match_dup 2)))   (parallel [(set (match_dup 0) (not:BI (match_dup 0)))	      (clobber (scratch))])]  "")(define_split  [(set (match_operand:BI 0 "register_operand" "")	(ne:BI (ior:DI (ne:DI (match_operand:BI 2 "register_operand" "")			      (const_int 0))		       (match_operand:DI 3 "register_operand" ""))	       (const_int 0)))]  ""  [(set (match_dup 0) 	(ior:BI (ne:BI (match_dup 3) (const_int 0))		(match_dup 2)))]  "")(define_split  [(set (match_operand:BI 0 "register_operand" "")

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -