mirror of
				https://github.com/yuzu-emu/unicorn.git
				synced 2025-10-25 13:47:10 +00:00 
			
		
		
		
	target/arm: Implement SVE copy to vector (predicated)
Backports commit 792a557847697235037fea30eaaacb9b45b4c9e5 from qemu
This commit is contained in:
		
							parent
							
								
									0bb2fdd752
								
							
						
					
					
						commit
						53d151de58
					
				|  | @ -450,6 +450,12 @@ LASTB_v         00000101 .. 10001 1 100 ... ..... .....         @rd_pg_rn | |||
| LASTA_r         00000101 .. 10000 0 101 ... ..... .....         @rd_pg_rn | ||||
| LASTB_r         00000101 .. 10000 1 101 ... ..... .....         @rd_pg_rn | ||||
| 
 | ||||
| # SVE copy element from SIMD&FP scalar register | ||||
| CPY_m_v         00000101 .. 100000 100 ... ..... .....          @rd_pg_rn | ||||
| 
 | ||||
| # SVE copy element from general register to vector (predicated) | ||||
| CPY_m_r         00000101 .. 101000 101 ... ..... .....          @rd_pg_rn | ||||
| 
 | ||||
| ### SVE Predicate Logical Operations Group | ||||
| 
 | ||||
| # SVE predicate logical operations | ||||
|  |  | |||
|  | @ -2724,6 +2724,26 @@ static bool trans_LASTB_r(DisasContext *s, arg_rpr_esz *a, uint32_t insn) | |||
|     return do_last_general(s, a, true); | ||||
| } | ||||
| 
 | ||||
| static bool trans_CPY_m_r(DisasContext *s, arg_rpr_esz *a, uint32_t insn) | ||||
| { | ||||
|     if (sve_access_check(s)) { | ||||
|         do_cpy_m(s, a->esz, a->rd, a->rd, a->pg, cpu_reg_sp(s, a->rn)); | ||||
|     } | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| static bool trans_CPY_m_v(DisasContext *s, arg_rpr_esz *a, uint32_t insn) | ||||
| { | ||||
|     if (sve_access_check(s)) { | ||||
|         TCGContext *tcg_ctx = s->uc->tcg_ctx; | ||||
|         int ofs = vec_reg_offset(s, a->rn, 0, a->esz); | ||||
|         TCGv_i64 t = load_esz(s, tcg_ctx->cpu_env, ofs, a->esz); | ||||
|         do_cpy_m(s, a->esz, a->rd, a->rd, a->pg, t); | ||||
|         tcg_temp_free_i64(tcg_ctx, t); | ||||
|     } | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  *** SVE Memory - 32-bit Gather and Unsized Contiguous Group | ||||
|  */ | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue