tcg/i386: Allow immediate as input to deposit_*
We can use MOVB and MOVW with an immediate just as easily as with a register input. Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
		
							parent
							
								
									8f7a840d7d
								
							
						
					
					
						commit
						73f97f0aa3
					
				| @ -33,7 +33,7 @@ C_O1_I1(r, q) | ||||
| C_O1_I1(r, r) | ||||
| C_O1_I1(x, r) | ||||
| C_O1_I1(x, x) | ||||
| C_O1_I2(q, 0, q) | ||||
| C_O1_I2(q, 0, qi) | ||||
| C_O1_I2(q, r, re) | ||||
| C_O1_I2(r, 0, ci) | ||||
| C_O1_I2(r, 0, r) | ||||
|  | ||||
| @ -276,6 +276,7 @@ static bool tcg_target_const_match(int64_t val, TCGType type, int ct) | ||||
| #define OPC_MOVL_GvEv	(0x8b)		/* loads, more or less */
 | ||||
| #define OPC_MOVB_EvIz   (0xc6)
 | ||||
| #define OPC_MOVL_EvIz	(0xc7)
 | ||||
| #define OPC_MOVB_Ib     (0xb0)
 | ||||
| #define OPC_MOVL_Iv     (0xb8)
 | ||||
| #define OPC_MOVBE_GyMy  (0xf0 | P_EXT38)
 | ||||
| #define OPC_MOVBE_MyGy  (0xf1 | P_EXT38)
 | ||||
| @ -2750,13 +2751,30 @@ static inline void tcg_out_op(TCGContext *s, TCGOpcode opc, | ||||
|     OP_32_64(deposit): | ||||
|         if (args[3] == 0 && args[4] == 8) { | ||||
|             /* load bits 0..7 */ | ||||
|             if (const_a2) { | ||||
|                 tcg_out_opc(s, OPC_MOVB_Ib | P_REXB_RM | LOWREGMASK(a0), | ||||
|                             0, a0, 0); | ||||
|                 tcg_out8(s, a2); | ||||
|             } else { | ||||
|                 tcg_out_modrm(s, OPC_MOVB_EvGv | P_REXB_R | P_REXB_RM, a2, a0); | ||||
|             } | ||||
|         } else if (TCG_TARGET_REG_BITS == 32 && args[3] == 8 && args[4] == 8) { | ||||
|             /* load bits 8..15 */ | ||||
|             if (const_a2) { | ||||
|                 tcg_out8(s, OPC_MOVB_Ib + a0 + 4); | ||||
|                 tcg_out8(s, a2); | ||||
|             } else { | ||||
|                 tcg_out_modrm(s, OPC_MOVB_EvGv, a2, a0 + 4); | ||||
|             } | ||||
|         } else if (args[3] == 0 && args[4] == 16) { | ||||
|             /* load bits 0..15 */ | ||||
|             if (const_a2) { | ||||
|                 tcg_out_opc(s, OPC_MOVL_Iv | P_DATA16 | LOWREGMASK(a0), | ||||
|                             0, a0, 0); | ||||
|                 tcg_out16(s, a2); | ||||
|             } else { | ||||
|                 tcg_out_modrm(s, OPC_MOVL_EvGv | P_DATA16, a2, a0); | ||||
|             } | ||||
|         } else { | ||||
|             g_assert_not_reached(); | ||||
|         } | ||||
| @ -3311,7 +3329,7 @@ static TCGConstraintSetIndex tcg_target_op_def(TCGOpcode op) | ||||
| 
 | ||||
|     case INDEX_op_deposit_i32: | ||||
|     case INDEX_op_deposit_i64: | ||||
|         return C_O1_I2(q, 0, q); | ||||
|         return C_O1_I2(q, 0, qi); | ||||
| 
 | ||||
|     case INDEX_op_setcond_i32: | ||||
|     case INDEX_op_setcond_i64: | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Richard Henderson
						Richard Henderson