qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH v11 13/14] target-mips: Add ASE DSP testcases


From: Aurelien Jarno
Subject: Re: [Qemu-devel] [PATCH v11 13/14] target-mips: Add ASE DSP testcases
Date: Wed, 17 Oct 2012 01:23:54 +0200
User-agent: Mutt/1.5.21 (2010-09-15)

On Tue, Oct 16, 2012 at 12:39:17AM +0800, Jia Liu wrote:
> Add MIPS ASE DSP testcases.
> 
> Signed-off-by: Jia Liu <address@hidden>
> ---
>  tests/tcg/mips/mips32-dsp/Makefile             |  135 +++++++++++
>  tests/tcg/mips/mips32-dsp/absq_s_ph.c          |   31 +++
>  tests/tcg/mips/mips32-dsp/absq_s_w.c           |   37 +++
>  tests/tcg/mips/mips32-dsp/addq_ph.c            |   30 +++
>  tests/tcg/mips/mips32-dsp/addq_s_ph.c          |   30 +++
>  tests/tcg/mips/mips32-dsp/addsc.c              |   30 +++
>  tests/tcg/mips/mips32-dsp/addu_qb.c            |   30 +++
>  tests/tcg/mips/mips32-dsp/addu_s_qb.c          |   30 +++
>  tests/tcg/mips/mips32-dsp/addwc.c              |   30 +++
>  tests/tcg/mips/mips32-dsp/bitrev.c             |   20 ++
>  tests/tcg/mips/mips32-dsp/bposge32.c           |   44 ++++
>  tests/tcg/mips/mips32-dsp/cmp_eq_ph.c          |   35 +++
>  tests/tcg/mips/mips32-dsp/cmp_le_ph.c          |   35 +++
>  tests/tcg/mips/mips32-dsp/cmp_lt_ph.c          |   35 +++
>  tests/tcg/mips/mips32-dsp/cmpgu_eq_qb.c        |   31 +++
>  tests/tcg/mips/mips32-dsp/cmpgu_le_qb.c        |   31 +++
>  tests/tcg/mips/mips32-dsp/cmpgu_lt_qb.c        |   31 +++
>  tests/tcg/mips/mips32-dsp/cmpu_eq_qb.c         |   35 +++
>  tests/tcg/mips/mips32-dsp/cmpu_le_qb.c         |   35 +++
>  tests/tcg/mips/mips32-dsp/cmpu_lt_qb.c         |   35 +++
>  tests/tcg/mips/mips32-dsp/dpaq_s_w_ph.c        |   31 +++
>  tests/tcg/mips/mips32-dsp/dpaq_sa_l_w.c        |   31 +++
>  tests/tcg/mips/mips32-dsp/dpau_h_qbl.c         |   27 +++
>  tests/tcg/mips/mips32-dsp/dpau_h_qbr.c         |   27 +++
>  tests/tcg/mips/mips32-dsp/dpsq_s_w_ph.c        |   27 +++
>  tests/tcg/mips/mips32-dsp/dpsq_sa_l_w.c        |   31 +++
>  tests/tcg/mips/mips32-dsp/dpsu_h_qbl.c         |   27 +++
>  tests/tcg/mips/mips32-dsp/dpsu_h_qbr.c         |   27 +++
>  tests/tcg/mips/mips32-dsp/extp.c               |   44 ++++
>  tests/tcg/mips/mips32-dsp/extpdp.c             |   46 ++++
>  tests/tcg/mips/mips32-dsp/extpdpv.c            |   47 ++++
>  tests/tcg/mips/mips32-dsp/extpv.c              |   45 ++++
>  tests/tcg/mips/mips32-dsp/extr_r_w.c           |   25 ++
>  tests/tcg/mips/mips32-dsp/extr_rs_w.c          |   25 ++
>  tests/tcg/mips/mips32-dsp/extr_s_h.c           |   25 ++
>  tests/tcg/mips/mips32-dsp/extr_w.c             |   25 ++
>  tests/tcg/mips/mips32-dsp/extrv_r_w.c          |   29 +++
>  tests/tcg/mips/mips32-dsp/extrv_rs_w.c         |   29 +++
>  tests/tcg/mips/mips32-dsp/extrv_s_h.c          |   29 +++
>  tests/tcg/mips/mips32-dsp/extrv_w.c            |   29 +++
>  tests/tcg/mips/mips32-dsp/insv.c               |   23 ++
>  tests/tcg/mips/mips32-dsp/lbux.c               |   25 ++
>  tests/tcg/mips/mips32-dsp/lhx.c                |   25 ++
>  tests/tcg/mips/mips32-dsp/lwx.c                |   25 ++
>  tests/tcg/mips/mips32-dsp/madd.c               |   31 +++
>  tests/tcg/mips/mips32-dsp/maddu.c              |   31 +++
>  tests/tcg/mips/mips32-dsp/main.c               |    6 +
>  tests/tcg/mips/mips32-dsp/maq_s_w_phl.c        |   31 +++
>  tests/tcg/mips/mips32-dsp/maq_s_w_phr.c        |   31 +++
>  tests/tcg/mips/mips32-dsp/maq_sa_w_phl.c       |   31 +++
>  tests/tcg/mips/mips32-dsp/maq_sa_w_phr.c       |   31 +++
>  tests/tcg/mips/mips32-dsp/mfhi.c               |   21 ++
>  tests/tcg/mips/mips32-dsp/mflo.c               |   21 ++
>  tests/tcg/mips/mips32-dsp/modsub.c             |   30 +++
>  tests/tcg/mips/mips32-dsp/msub.c               |   30 +++
>  tests/tcg/mips/mips32-dsp/msubu.c              |   30 +++
>  tests/tcg/mips/mips32-dsp/mthi.c               |   21 ++
>  tests/tcg/mips/mips32-dsp/mthlip.c             |   34 +++
>  tests/tcg/mips/mips32-dsp/mtlo.c               |   21 ++
>  tests/tcg/mips/mips32-dsp/muleq_s_w_phl.c      |   41 ++++
>  tests/tcg/mips/mips32-dsp/muleq_s_w_phr.c      |   40 ++++
>  tests/tcg/mips/mips32-dsp/muleu_s_ph_qbl.c     |   25 ++
>  tests/tcg/mips/mips32-dsp/muleu_s_ph_qbr.c     |   25 ++
>  tests/tcg/mips/mips32-dsp/mulq_rs_ph.c         |   25 ++
>  tests/tcg/mips/mips32-dsp/mult.c               |   24 ++
>  tests/tcg/mips/mips32-dsp/multu.c              |   24 ++
>  tests/tcg/mips/mips32-dsp/packrl_ph.c          |   21 ++
>  tests/tcg/mips/mips32-dsp/pick_ph.c            |   23 ++
>  tests/tcg/mips/mips32-dsp/pick_qb.c            |   23 ++
>  tests/tcg/mips/mips32-dsp/preceq_w_phl.c       |   20 ++
>  tests/tcg/mips/mips32-dsp/preceq_w_phr.c       |   20 ++
>  tests/tcg/mips/mips32-dsp/precequ_ph_qbl.c     |   20 ++
>  tests/tcg/mips/mips32-dsp/precequ_ph_qbla.c    |   20 ++
>  tests/tcg/mips/mips32-dsp/precequ_ph_qbr.c     |   20 ++
>  tests/tcg/mips/mips32-dsp/precequ_ph_qbra.c    |   20 ++
>  tests/tcg/mips/mips32-dsp/preceu_ph_qbl.c      |   20 ++
>  tests/tcg/mips/mips32-dsp/preceu_ph_qbla.c     |   20 ++
>  tests/tcg/mips/mips32-dsp/preceu_ph_qbr.c      |   20 ++
>  tests/tcg/mips/mips32-dsp/preceu_ph_qbra.c     |   20 ++
>  tests/tcg/mips/mips32-dsp/precrq_ph_w.c        |   21 ++
>  tests/tcg/mips/mips32-dsp/precrq_qb_ph.c       |   21 ++
>  tests/tcg/mips/mips32-dsp/precrq_rs_ph_w.c     |   21 ++
>  tests/tcg/mips/mips32-dsp/precrqu_s_qb_ph.c    |   21 ++
>  tests/tcg/mips/mips32-dsp/raddu_w_qb.c         |   20 ++
>  tests/tcg/mips/mips32-dsp/rddsp.c              |   54 +++++
>  tests/tcg/mips/mips32-dsp/repl_ph.c            |   23 ++
>  tests/tcg/mips/mips32-dsp/repl_qb.c            |   16 ++
>  tests/tcg/mips/mips32-dsp/replv_ph.c           |   19 ++
>  tests/tcg/mips/mips32-dsp/replv_qb.c           |   19 ++
>  tests/tcg/mips/mips32-dsp/shilo.c              |   27 +++
>  tests/tcg/mips/mips32-dsp/shilov.c             |   29 +++
>  tests/tcg/mips/mips32-dsp/shll_ph.c            |   24 ++
>  tests/tcg/mips/mips32-dsp/shll_qb.c            |   23 ++
>  tests/tcg/mips/mips32-dsp/shll_s_ph.c          |   24 ++
>  tests/tcg/mips/mips32-dsp/shll_s_w.c           |   24 ++
>  tests/tcg/mips/mips32-dsp/shllv_ph.c           |   25 ++
>  tests/tcg/mips/mips32-dsp/shllv_qb.c           |   24 ++
>  tests/tcg/mips/mips32-dsp/shllv_s_ph.c         |   25 ++
>  tests/tcg/mips/mips32-dsp/shllv_s_w.c          |   25 ++
>  tests/tcg/mips/mips32-dsp/shra_ph.c            |   20 ++
>  tests/tcg/mips/mips32-dsp/shra_r_ph.c          |   20 ++
>  tests/tcg/mips/mips32-dsp/shra_r_w.c           |   20 ++
>  tests/tcg/mips/mips32-dsp/shrav_ph.c           |   21 ++
>  tests/tcg/mips/mips32-dsp/shrav_r_ph.c         |   21 ++
>  tests/tcg/mips/mips32-dsp/shrav_r_w.c          |   21 ++
>  tests/tcg/mips/mips32-dsp/shrl_qb.c            |   20 ++
>  tests/tcg/mips/mips32-dsp/shrlv_qb.c           |   21 ++
>  tests/tcg/mips/mips32-dsp/subq_ph.c            |   25 ++
>  tests/tcg/mips/mips32-dsp/subq_s_ph.c          |   25 ++
>  tests/tcg/mips/mips32-dsp/subq_s_w.c           |   25 ++
>  tests/tcg/mips/mips32-dsp/subu_qb.c            |   25 ++
>  tests/tcg/mips/mips32-dsp/subu_s_qb.c          |   25 ++
>  tests/tcg/mips/mips32-dsp/wrdsp.c              |   54 +++++
>  tests/tcg/mips/mips32-dspr2/Makefile           |   72 ++++++
>  tests/tcg/mips/mips32-dspr2/absq_s_qb.c        |   35 +++
>  tests/tcg/mips/mips32-dspr2/addqh_ph.c         |   30 +++
>  tests/tcg/mips/mips32-dspr2/addqh_r_ph.c       |   30 +++
>  tests/tcg/mips/mips32-dspr2/addqh_r_w.c        |   34 +++
>  tests/tcg/mips/mips32-dspr2/addqh_w.c          |   34 +++
>  tests/tcg/mips/mips32-dspr2/addu_ph.c          |   30 +++
>  tests/tcg/mips/mips32-dspr2/addu_s_ph.c        |   30 +++
>  tests/tcg/mips/mips32-dspr2/adduh_qb.c         |   30 +++
>  tests/tcg/mips/mips32-dspr2/adduh_r_qb.c       |   30 +++
>  tests/tcg/mips/mips32-dspr2/append.c           |   30 +++
>  tests/tcg/mips/mips32-dspr2/balign.c           |   30 +++
>  tests/tcg/mips/mips32-dspr2/cmpgdu_eq_qb.c     |   37 +++
>  tests/tcg/mips/mips32-dspr2/cmpgdu_le_qb.c     |   37 +++
>  tests/tcg/mips/mips32-dspr2/cmpgdu_lt_qb.c     |   37 +++
>  tests/tcg/mips/mips32-dspr2/dpa_w_ph.c         |   27 +++
>  tests/tcg/mips/mips32-dspr2/dpaqx_s_w_ph.c     |   57 +++++
>  tests/tcg/mips/mips32-dspr2/dpaqx_sa_w_ph.c    |   31 +++
>  tests/tcg/mips/mips32-dspr2/dpax_w_ph.c        |   27 +++
>  tests/tcg/mips/mips32-dspr2/dps_w_ph.c         |   27 +++
>  tests/tcg/mips/mips32-dspr2/dpsqx_s_w_ph.c     |   31 +++
>  tests/tcg/mips/mips32-dspr2/dpsqx_sa_w_ph.c    |   31 +++
>  tests/tcg/mips/mips32-dspr2/dpsx_w_ph.c        |   27 +++
>  tests/tcg/mips/mips32-dspr2/mul_ph.c           |   25 ++
>  tests/tcg/mips/mips32-dspr2/mul_s_ph.c         |   25 ++
>  tests/tcg/mips/mips32-dspr2/muleq_s_w_phl.c    |   40 ++++
>  tests/tcg/mips/mips32-dspr2/mulq_rs_w.c        |   36 +++
>  tests/tcg/mips/mips32-dspr2/mulq_s_ph.c        |   25 ++
>  tests/tcg/mips/mips32-dspr2/mulq_s_w.c         |   36 +++
>  tests/tcg/mips/mips32-dspr2/mulsa_w_ph.c       |   29 +++
>  tests/tcg/mips/mips32-dspr2/mulsaq_s_w_ph.c    |   29 +++
>  tests/tcg/mips/mips32-dspr2/precr_qb_ph.c      |   21 ++
>  tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c   |   32 +++
>  tests/tcg/mips/mips32-dspr2/precr_sra_r_ph_w.c |   32 +++
>  tests/tcg/mips/mips32-dspr2/prepend.c          |   30 +++
>  tests/tcg/mips/mips32-dspr2/shra_qb.c          |   30 +++
>  tests/tcg/mips/mips32-dspr2/shra_r_qb.c        |   30 +++
>  tests/tcg/mips/mips32-dspr2/shrav_qb.c         |   32 +++
>  tests/tcg/mips/mips32-dspr2/shrav_r_qb.c       |   32 +++
>  tests/tcg/mips/mips32-dspr2/shrl_ph.c          |   20 ++
>  tests/tcg/mips/mips32-dspr2/shrlv_ph.c         |   21 ++
>  tests/tcg/mips/mips32-dspr2/subqh_ph.c         |   21 ++
>  tests/tcg/mips/mips32-dspr2/subqh_r_ph.c       |   21 ++
>  tests/tcg/mips/mips32-dspr2/subqh_r_w.c        |   21 ++
>  tests/tcg/mips/mips32-dspr2/subqh_w.c          |   21 ++
>  tests/tcg/mips/mips32-dspr2/subu_ph.c          |   25 ++
>  tests/tcg/mips/mips32-dspr2/subu_s_ph.c        |   25 ++
>  tests/tcg/mips/mips32-dspr2/subuh_qb.c         |   21 ++
>  tests/tcg/mips/mips32-dspr2/subuh_r_qb.c       |   21 ++
>  tests/tcg/mips/mips64-dsp/Makefile             |  305 
> ++++++++++++++++++++++++
>  tests/tcg/mips/mips64-dsp/absq_s_ob.c          |   63 +++++
>  tests/tcg/mips/mips64-dsp/absq_s_ph.c          |   37 +++
>  tests/tcg/mips/mips64-dsp/absq_s_pw.c          |   66 +++++
>  tests/tcg/mips/mips64-dsp/absq_s_qh.c          |   40 ++++
>  tests/tcg/mips/mips64-dsp/absq_s_w.c           |   48 ++++
>  tests/tcg/mips/mips64-dsp/addq_ph.c            |   37 +++
>  tests/tcg/mips/mips64-dsp/addq_pw.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/addq_qh.c            |   28 +++
>  tests/tcg/mips/mips64-dsp/addq_s_ph.c          |   37 +++
>  tests/tcg/mips/mips64-dsp/addq_s_pw.c          |   45 ++++
>  tests/tcg/mips/mips64-dsp/addq_s_qh.c          |   26 ++
>  tests/tcg/mips/mips64-dsp/addsc.c              |   37 +++
>  tests/tcg/mips/mips64-dsp/addu_ob.c            |   27 +++
>  tests/tcg/mips/mips64-dsp/addu_qb.c            |   37 +++
>  tests/tcg/mips/mips64-dsp/addu_s_ob.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/addu_s_qb.c          |   38 +++
>  tests/tcg/mips/mips64-dsp/addwc.c              |   37 +++
>  tests/tcg/mips/mips64-dsp/bitrev.c             |   23 ++
>  tests/tcg/mips/mips64-dsp/bposge32.c           |   50 ++++
>  tests/tcg/mips/mips64-dsp/bposge64.c           |   50 ++++
>  tests/tcg/mips/mips64-dsp/cmp_eq_ph.c          |   42 ++++
>  tests/tcg/mips/mips64-dsp/cmp_eq_pw.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/cmp_eq_qh.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/cmp_le_ph.c          |   40 ++++
>  tests/tcg/mips/mips64-dsp/cmp_le_pw.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/cmp_le_qh.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/cmp_lt_ph.c          |   41 ++++
>  tests/tcg/mips/mips64-dsp/cmp_lt_pw.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/cmp_lt_qh.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/cmpgu_eq_ob.c        |   24 ++
>  tests/tcg/mips/mips64-dsp/cmpgu_eq_qb.c        |   38 +++
>  tests/tcg/mips/mips64-dsp/cmpgu_le_ob.c        |   24 ++
>  tests/tcg/mips/mips64-dsp/cmpgu_le_qb.c        |   37 +++
>  tests/tcg/mips/mips64-dsp/cmpgu_lt_ob.c        |   24 ++
>  tests/tcg/mips/mips64-dsp/cmpgu_lt_qb.c        |   38 +++
>  tests/tcg/mips/mips64-dsp/cmpu_eq_ob.c         |   27 +++
>  tests/tcg/mips/mips64-dsp/cmpu_eq_qb.c         |   42 ++++
>  tests/tcg/mips/mips64-dsp/cmpu_le_ob.c         |   26 ++
>  tests/tcg/mips/mips64-dsp/cmpu_le_qb.c         |   41 ++++
>  tests/tcg/mips/mips64-dsp/cmpu_lt_ob.c         |   26 ++
>  tests/tcg/mips/mips64-dsp/cmpu_lt_qb.c         |   42 ++++
>  tests/tcg/mips/mips64-dsp/dappend.c            |   37 +++
>  tests/tcg/mips/mips64-dsp/dextp.c              |   33 +++
>  tests/tcg/mips/mips64-dsp/dextpdp.c            |   37 +++
>  tests/tcg/mips/mips64-dsp/dextpdpv.c           |   38 +++
>  tests/tcg/mips/mips64-dsp/dextpv.c             |   34 +++
>  tests/tcg/mips/mips64-dsp/dextr_l.c            |   27 +++
>  tests/tcg/mips/mips64-dsp/dextr_r_l.c          |   32 +++
>  tests/tcg/mips/mips64-dsp/dextr_r_w.c          |   32 +++
>  tests/tcg/mips/mips64-dsp/dextr_rs_l.c         |   31 +++
>  tests/tcg/mips/mips64-dsp/dextr_rs_w.c         |   31 +++
>  tests/tcg/mips/mips64-dsp/dextr_s_h.c          |   31 +++
>  tests/tcg/mips/mips64-dsp/dextr_w.c            |   27 +++
>  tests/tcg/mips/mips64-dsp/dextrv_l.c           |   28 +++
>  tests/tcg/mips/mips64-dsp/dextrv_r_l.c         |   33 +++
>  tests/tcg/mips/mips64-dsp/dextrv_r_w.c         |   33 +++
>  tests/tcg/mips/mips64-dsp/dextrv_rs_l.c        |   32 +++
>  tests/tcg/mips/mips64-dsp/dextrv_rs_w.c        |   32 +++
>  tests/tcg/mips/mips64-dsp/dextrv_s_h.c         |   32 +++
>  tests/tcg/mips/mips64-dsp/dextrv_w.c           |   28 +++
>  tests/tcg/mips/mips64-dsp/dinsv.c              |   25 ++
>  tests/tcg/mips/mips64-dsp/dmadd.c              |   57 +++++
>  tests/tcg/mips/mips64-dsp/dmaddu.c             |   56 +++++
>  tests/tcg/mips/mips64-dsp/dmsub.c              |   59 +++++
>  tests/tcg/mips/mips64-dsp/dmsubu.c             |   59 +++++
>  tests/tcg/mips/mips64-dsp/dmthlip.c            |   32 +++
>  tests/tcg/mips/mips64-dsp/dpaq_s_w_ph.c        |   32 +++
>  tests/tcg/mips/mips64-dsp/dpaq_s_w_qh.c        |   57 +++++
>  tests/tcg/mips/mips64-dsp/dpaq_sa_l_pw.c       |   62 +++++
>  tests/tcg/mips/mips64-dsp/dpaq_sa_l_w.c        |   32 +++
>  tests/tcg/mips/mips64-dsp/dpau_h_obl.c         |   59 +++++
>  tests/tcg/mips/mips64-dsp/dpau_h_obr.c         |   59 +++++
>  tests/tcg/mips/mips64-dsp/dpau_h_qbl.c         |   29 +++
>  tests/tcg/mips/mips64-dsp/dpau_h_qbr.c         |   29 +++
>  tests/tcg/mips/mips64-dsp/dpsq_s_w_ph.c        |   29 +++
>  tests/tcg/mips/mips64-dsp/dpsq_s_w_qh.c        |   33 +++
>  tests/tcg/mips/mips64-dsp/dpsq_sa_l_pw.c       |   39 +++
>  tests/tcg/mips/mips64-dsp/dpsq_sa_l_w.c        |   32 +++
>  tests/tcg/mips/mips64-dsp/dpsu_h_obl.c         |   32 +++
>  tests/tcg/mips/mips64-dsp/dpsu_h_obr.c         |   32 +++
>  tests/tcg/mips/mips64-dsp/dpsu_h_qbl.c         |   29 +++
>  tests/tcg/mips/mips64-dsp/dpsu_h_qbr.c         |   29 +++
>  tests/tcg/mips/mips64-dsp/dshilo.c             |   31 +++
>  tests/tcg/mips/mips64-dsp/dshilov.c            |   32 +++
>  tests/tcg/mips/mips64-dsp/extp.c               |   50 ++++
>  tests/tcg/mips/mips64-dsp/extpdp.c             |   51 ++++
>  tests/tcg/mips/mips64-dsp/extpdpv.c            |   52 ++++
>  tests/tcg/mips/mips64-dsp/extpv.c              |   51 ++++
>  tests/tcg/mips/mips64-dsp/extr_r_w.c           |   27 +++
>  tests/tcg/mips/mips64-dsp/extr_rs_w.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/extr_s_h.c           |   27 +++
>  tests/tcg/mips/mips64-dsp/extr_w.c             |   27 +++
>  tests/tcg/mips/mips64-dsp/extrv_r_w.c          |   31 +++
>  tests/tcg/mips/mips64-dsp/extrv_rs_w.c         |   31 +++
>  tests/tcg/mips/mips64-dsp/extrv_s_h.c          |   31 +++
>  tests/tcg/mips/mips64-dsp/extrv_w.c            |   31 +++
>  tests/tcg/mips/mips64-dsp/head.S               |   16 ++
>  tests/tcg/mips/mips64-dsp/insv.c               |   26 ++
>  tests/tcg/mips/mips64-dsp/io.h                 |   22 ++
>  tests/tcg/mips/mips64-dsp/lbux.c               |   27 +++
>  tests/tcg/mips/mips64-dsp/ldx.c                |   27 +++
>  tests/tcg/mips/mips64-dsp/lhx.c                |   27 +++
>  tests/tcg/mips/mips64-dsp/lwx.c                |   27 +++
>  tests/tcg/mips/mips64-dsp/madd.c               |   33 +++
>  tests/tcg/mips/mips64-dsp/maddu.c              |   33 +++
>  tests/tcg/mips/mips64-dsp/maq_s_l_pwl.c        |   56 +++++
>  tests/tcg/mips/mips64-dsp/maq_s_l_pwr.c        |   56 +++++
>  tests/tcg/mips/mips64-dsp/maq_s_w_phl.c        |   33 +++
>  tests/tcg/mips/mips64-dsp/maq_s_w_phr.c        |   33 +++
>  tests/tcg/mips/mips64-dsp/maq_s_w_qhll.c       |   62 +++++
>  tests/tcg/mips/mips64-dsp/maq_s_w_qhlr.c       |   62 +++++
>  tests/tcg/mips/mips64-dsp/maq_s_w_qhrl.c       |   63 +++++
>  tests/tcg/mips/mips64-dsp/maq_s_w_qhrr.c       |   63 +++++
>  tests/tcg/mips/mips64-dsp/maq_sa_w_phl.c       |   33 +++
>  tests/tcg/mips/mips64-dsp/maq_sa_w_phr.c       |   33 +++
>  tests/tcg/mips/mips64-dsp/maq_sa_w_qhll.c      |   62 +++++
>  tests/tcg/mips/mips64-dsp/maq_sa_w_qhlr.c      |   64 +++++
>  tests/tcg/mips/mips64-dsp/maq_sa_w_qhrl.c      |   64 +++++
>  tests/tcg/mips/mips64-dsp/maq_sa_w_qhrr.c      |   64 +++++
>  tests/tcg/mips/mips64-dsp/mfhi.c               |   24 ++
>  tests/tcg/mips/mips64-dsp/mflo.c               |   24 ++
>  tests/tcg/mips/mips64-dsp/mips_boot.lds        |   31 +++
>  tests/tcg/mips/mips64-dsp/modsub.c             |   37 +++
>  tests/tcg/mips/mips64-dsp/msub.c               |   32 +++
>  tests/tcg/mips/mips64-dsp/msubu.c              |   32 +++
>  tests/tcg/mips/mips64-dsp/mthi.c               |   24 ++
>  tests/tcg/mips/mips64-dsp/mthlip.c             |   35 +++
>  tests/tcg/mips/mips64-dsp/mtlo.c               |   22 ++
>  tests/tcg/mips/mips64-dsp/muleq_s_pw_qhl.c     |   55 +++++
>  tests/tcg/mips/mips64-dsp/muleq_s_pw_qhr.c     |   24 ++
>  tests/tcg/mips/mips64-dsp/muleq_s_w_phl.c      |   46 ++++
>  tests/tcg/mips/mips64-dsp/muleq_s_w_phr.c      |   45 ++++
>  tests/tcg/mips/mips64-dsp/muleu_s_ph_qbl.c     |   27 +++
>  tests/tcg/mips/mips64-dsp/muleu_s_ph_qbr.c     |   27 +++
>  tests/tcg/mips/mips64-dsp/muleu_s_qh_obl.c     |   25 ++
>  tests/tcg/mips/mips64-dsp/muleu_s_qh_obr.c     |   25 ++
>  tests/tcg/mips/mips64-dsp/mulq_rs_ph.c         |   27 +++
>  tests/tcg/mips/mips64-dsp/mulq_rs_qh.c         |   33 +++
>  tests/tcg/mips/mips64-dsp/mulsaq_s_l_pw.c      |   59 +++++
>  tests/tcg/mips/mips64-dsp/mulsaq_s_w_qh.c      |   57 +++++
>  tests/tcg/mips/mips64-dsp/mult.c               |   26 ++
>  tests/tcg/mips/mips64-dsp/multu.c              |   26 ++
>  tests/tcg/mips/mips64-dsp/packrl_ph.c          |   24 ++
>  tests/tcg/mips/mips64-dsp/packrl_pw.c          |   24 ++
>  tests/tcg/mips/mips64-dsp/pick_ob.c            |   27 +++
>  tests/tcg/mips/mips64-dsp/pick_ph.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/pick_pw.c            |   28 +++
>  tests/tcg/mips/mips64-dsp/pick_qb.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/pick_qh.c            |   28 +++
>  tests/tcg/mips/mips64-dsp/preceq_l_pwl.c       |   24 ++
>  tests/tcg/mips/mips64-dsp/preceq_l_pwr.c       |   24 ++
>  tests/tcg/mips/mips64-dsp/preceq_pw_qhl.c      |   21 ++
>  tests/tcg/mips/mips64-dsp/preceq_pw_qhla.c     |   23 ++
>  tests/tcg/mips/mips64-dsp/preceq_pw_qhr.c      |   21 ++
>  tests/tcg/mips/mips64-dsp/preceq_pw_qhra.c     |   23 ++
>  tests/tcg/mips/mips64-dsp/preceq_w_phl.c       |   23 ++
>  tests/tcg/mips/mips64-dsp/preceq_w_phr.c       |   23 ++
>  tests/tcg/mips/mips64-dsp/precequ_ph_qbl.c     |   23 ++
>  tests/tcg/mips/mips64-dsp/precequ_ph_qbla.c    |   23 ++
>  tests/tcg/mips/mips64-dsp/precequ_ph_qbr.c     |   23 ++
>  tests/tcg/mips/mips64-dsp/precequ_ph_qbra.c    |   23 ++
>  tests/tcg/mips/mips64-dsp/precequ_qh_obl.c     |   22 ++
>  tests/tcg/mips/mips64-dsp/precequ_qh_obla.c    |   22 ++
>  tests/tcg/mips/mips64-dsp/precequ_qh_obr.c     |   24 ++
>  tests/tcg/mips/mips64-dsp/precequ_qh_obra.c    |   24 ++
>  tests/tcg/mips/mips64-dsp/preceu_ph_qbl.c      |   23 ++
>  tests/tcg/mips/mips64-dsp/preceu_ph_qbla.c     |   23 ++
>  tests/tcg/mips/mips64-dsp/preceu_ph_qbr.c      |   23 ++
>  tests/tcg/mips/mips64-dsp/preceu_ph_qbra.c     |   23 ++
>  tests/tcg/mips/mips64-dsp/preceu_qh_obl.c      |   22 ++
>  tests/tcg/mips/mips64-dsp/preceu_qh_obla.c     |   22 ++
>  tests/tcg/mips/mips64-dsp/preceu_qh_obr.c      |   23 ++
>  tests/tcg/mips/mips64-dsp/preceu_qh_obra.c     |   23 ++
>  tests/tcg/mips/mips64-dsp/precr_ob_qh.c        |   25 ++
>  tests/tcg/mips/mips64-dsp/precr_sra_qh_pw.c    |   40 ++++
>  tests/tcg/mips/mips64-dsp/precr_sra_r_qh_pw.c  |   40 ++++
>  tests/tcg/mips/mips64-dsp/precrq_ob_qh.c       |   25 ++
>  tests/tcg/mips/mips64-dsp/precrq_ph_w.c        |   24 ++
>  tests/tcg/mips/mips64-dsp/precrq_pw_l.c        |   25 ++
>  tests/tcg/mips/mips64-dsp/precrq_qb_ph.c       |   24 ++
>  tests/tcg/mips/mips64-dsp/precrq_qh_pw.c       |   25 ++
>  tests/tcg/mips/mips64-dsp/precrq_rs_ph_w.c     |   24 ++
>  tests/tcg/mips/mips64-dsp/precrq_rs_qh_pw.c    |   25 ++
>  tests/tcg/mips/mips64-dsp/precrqu_s_ob_qh.c    |   27 +++
>  tests/tcg/mips/mips64-dsp/precrqu_s_qb_ph.c    |   24 ++
>  tests/tcg/mips/mips64-dsp/prependd.c           |   37 +++
>  tests/tcg/mips/mips64-dsp/prependw.c           |   37 +++
>  tests/tcg/mips/mips64-dsp/printf.c             |  266 +++++++++++++++++++++
>  tests/tcg/mips/mips64-dsp/raddu_l_ob.c         |   22 ++
>  tests/tcg/mips/mips64-dsp/raddu_w_qb.c         |   23 ++
>  tests/tcg/mips/mips64-dsp/rddsp.c              |   53 ++++
>  tests/tcg/mips/mips64-dsp/repl_ob.c            |   21 ++
>  tests/tcg/mips/mips64-dsp/repl_ph.c            |   30 +++
>  tests/tcg/mips/mips64-dsp/repl_pw.c            |   34 +++
>  tests/tcg/mips/mips64-dsp/repl_qb.c            |   19 ++
>  tests/tcg/mips/mips64-dsp/repl_qh.c            |   34 +++
>  tests/tcg/mips/mips64-dsp/replv_ob.c           |   23 ++
>  tests/tcg/mips/mips64-dsp/replv_ph.c           |   22 ++
>  tests/tcg/mips/mips64-dsp/replv_pw.c           |   23 ++
>  tests/tcg/mips/mips64-dsp/replv_qb.c           |   22 ++
>  tests/tcg/mips/mips64-dsp/shilo.c              |   29 +++
>  tests/tcg/mips/mips64-dsp/shilov.c             |   31 +++
>  tests/tcg/mips/mips64-dsp/shll_ob.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/shll_ph.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/shll_pw.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/shll_qb.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/shll_qh.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/shll_s_ph.c          |   26 ++
>  tests/tcg/mips/mips64-dsp/shll_s_pw.c          |   26 ++
>  tests/tcg/mips/mips64-dsp/shll_s_qh.c          |   26 ++
>  tests/tcg/mips/mips64-dsp/shll_s_w.c           |   26 ++
>  tests/tcg/mips/mips64-dsp/shllv_ob.c           |   27 +++
>  tests/tcg/mips/mips64-dsp/shllv_ph.c           |   27 +++
>  tests/tcg/mips/mips64-dsp/shllv_pw.c           |   27 +++
>  tests/tcg/mips/mips64-dsp/shllv_qb.c           |   27 +++
>  tests/tcg/mips/mips64-dsp/shllv_qh.c           |   27 +++
>  tests/tcg/mips/mips64-dsp/shllv_s_ph.c         |   27 +++
>  tests/tcg/mips/mips64-dsp/shllv_s_pw.c         |   27 +++
>  tests/tcg/mips/mips64-dsp/shllv_s_qh.c         |   27 +++
>  tests/tcg/mips/mips64-dsp/shllv_s_w.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/shra_ob.c            |   22 ++
>  tests/tcg/mips/mips64-dsp/shra_ph.c            |   23 ++
>  tests/tcg/mips/mips64-dsp/shra_pw.c            |   22 ++
>  tests/tcg/mips/mips64-dsp/shra_qh.c            |   24 ++
>  tests/tcg/mips/mips64-dsp/shra_r_ob.c          |   22 ++
>  tests/tcg/mips/mips64-dsp/shra_r_ph.c          |   23 ++
>  tests/tcg/mips/mips64-dsp/shra_r_pw.c          |   22 ++
>  tests/tcg/mips/mips64-dsp/shra_r_qh.c          |   23 ++
>  tests/tcg/mips/mips64-dsp/shra_r_w.c           |   23 ++
>  tests/tcg/mips/mips64-dsp/shrav_ph.c           |   24 ++
>  tests/tcg/mips/mips64-dsp/shrav_pw.c           |   23 ++
>  tests/tcg/mips/mips64-dsp/shrav_qh.c           |   24 ++
>  tests/tcg/mips/mips64-dsp/shrav_r_ph.c         |   24 ++
>  tests/tcg/mips/mips64-dsp/shrav_r_pw.c         |   23 ++
>  tests/tcg/mips/mips64-dsp/shrav_r_qh.c         |   24 ++
>  tests/tcg/mips/mips64-dsp/shrav_r_w.c          |   24 ++
>  tests/tcg/mips/mips64-dsp/shrl_ob.c            |   23 ++
>  tests/tcg/mips/mips64-dsp/shrl_qb.c            |   23 ++
>  tests/tcg/mips/mips64-dsp/shrl_qh.c            |   22 ++
>  tests/tcg/mips/mips64-dsp/shrlv_ob.c           |   24 ++
>  tests/tcg/mips/mips64-dsp/shrlv_qb.c           |   24 ++
>  tests/tcg/mips/mips64-dsp/shrlv_qh.c           |   23 ++
>  tests/tcg/mips/mips64-dsp/subq_ph.c            |   27 +++
>  tests/tcg/mips/mips64-dsp/subq_pw.c            |   44 ++++
>  tests/tcg/mips/mips64-dsp/subq_qh.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/subq_s_ph.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/subq_s_pw.c          |   45 ++++
>  tests/tcg/mips/mips64-dsp/subq_s_qh.c          |   44 ++++
>  tests/tcg/mips/mips64-dsp/subq_s_w.c           |   27 +++
>  tests/tcg/mips/mips64-dsp/subu_ob.c            |   26 ++
>  tests/tcg/mips/mips64-dsp/subu_qb.c            |   27 +++
>  tests/tcg/mips/mips64-dsp/subu_s_ob.c          |   26 ++
>  tests/tcg/mips/mips64-dsp/subu_s_qb.c          |   27 +++
>  tests/tcg/mips/mips64-dsp/wrdsp.c              |   48 ++++
>  tests/tcg/mips/mips64-dspr2/.directory         |    2 +
>  tests/tcg/mips/mips64-dspr2/Makefile           |  117 +++++++++
>  tests/tcg/mips/mips64-dspr2/absq_s_qb.c        |   42 ++++
>  tests/tcg/mips/mips64-dspr2/addqh_ph.c         |   35 +++
>  tests/tcg/mips/mips64-dspr2/addqh_r_ph.c       |   35 +++
>  tests/tcg/mips/mips64-dspr2/addqh_r_w.c        |   38 +++
>  tests/tcg/mips/mips64-dspr2/addqh_w.c          |   39 +++
>  tests/tcg/mips/mips64-dspr2/addu_ph.c          |   35 +++
>  tests/tcg/mips/mips64-dspr2/addu_qh.c          |   41 ++++
>  tests/tcg/mips/mips64-dspr2/addu_s_ph.c        |   35 +++
>  tests/tcg/mips/mips64-dspr2/addu_s_qh.c        |   41 ++++
>  tests/tcg/mips/mips64-dspr2/adduh_ob.c         |   21 ++
>  tests/tcg/mips/mips64-dspr2/adduh_qb.c         |   35 +++
>  tests/tcg/mips/mips64-dspr2/adduh_r_ob.c       |   21 ++
>  tests/tcg/mips/mips64-dspr2/adduh_r_qb.c       |   35 +++
>  tests/tcg/mips/mips64-dspr2/append.c           |   35 +++
>  tests/tcg/mips/mips64-dspr2/balign.c           |   35 +++
>  tests/tcg/mips/mips64-dspr2/cmpgdu_eq_ob.c     |   26 ++
>  tests/tcg/mips/mips64-dspr2/cmpgdu_eq_qb.c     |   41 ++++
>  tests/tcg/mips/mips64-dspr2/cmpgdu_le_ob.c     |   26 ++
>  tests/tcg/mips/mips64-dspr2/cmpgdu_le_qb.c     |   48 ++++
>  tests/tcg/mips/mips64-dspr2/cmpgdu_lt_ob.c     |   26 ++
>  tests/tcg/mips/mips64-dspr2/cmpgdu_lt_qb.c     |   48 ++++
>  tests/tcg/mips/mips64-dspr2/dbalign.c          |   23 ++
>  tests/tcg/mips/mips64-dspr2/dpa_w_ph.c         |   32 +++
>  tests/tcg/mips/mips64-dspr2/dpa_w_qh.c         |   56 +++++
>  tests/tcg/mips/mips64-dspr2/dpaqx_s_w_ph.c     |   74 ++++++
>  tests/tcg/mips/mips64-dspr2/dpaqx_sa_w_ph.c    |   42 ++++
>  tests/tcg/mips/mips64-dspr2/dpax_w_ph.c        |   32 +++
>  tests/tcg/mips/mips64-dspr2/dps_w_ph.c         |   28 +++
>  tests/tcg/mips/mips64-dspr2/dps_w_qh.c         |   55 +++++
>  tests/tcg/mips/mips64-dspr2/dpsqx_s_w_ph.c     |   31 +++
>  tests/tcg/mips/mips64-dspr2/dpsqx_sa_w_ph.c    |   30 +++
>  tests/tcg/mips/mips64-dspr2/dpsx_w_ph.c        |   28 +++
>  tests/tcg/mips/mips64-dspr2/head.S             |   16 ++
>  tests/tcg/mips/mips64-dspr2/io.h               |   22 ++
>  tests/tcg/mips/mips64-dspr2/mips_boot.lds      |   31 +++
>  tests/tcg/mips/mips64-dspr2/mul_ph.c           |   26 ++
>  tests/tcg/mips/mips64-dspr2/mul_s_ph.c         |   26 ++
>  tests/tcg/mips/mips64-dspr2/muleq_s_w_phl.c    |   42 ++++
>  tests/tcg/mips/mips64-dspr2/mulq_rs_w.c        |   40 ++++
>  tests/tcg/mips/mips64-dspr2/mulq_s_ph.c        |   26 ++
>  tests/tcg/mips/mips64-dspr2/mulq_s_w.c         |   40 ++++
>  tests/tcg/mips/mips64-dspr2/mulsa_w_ph.c       |   30 +++
>  tests/tcg/mips/mips64-dspr2/mulsaq_s_w_ph.c    |   30 +++
>  tests/tcg/mips/mips64-dspr2/precr_qb_ph.c      |   23 ++
>  tests/tcg/mips/mips64-dspr2/precr_sra_ph_w.c   |   37 +++
>  tests/tcg/mips/mips64-dspr2/precr_sra_r_ph_w.c |   37 +++
>  tests/tcg/mips/mips64-dspr2/prepend.c          |   35 +++
>  tests/tcg/mips/mips64-dspr2/printf.c           |  266 +++++++++++++++++++++
>  tests/tcg/mips/mips64-dspr2/shra_qb.c          |   35 +++
>  tests/tcg/mips/mips64-dspr2/shra_r_qb.c        |   35 +++
>  tests/tcg/mips/mips64-dspr2/shrav_ob.c         |   22 ++
>  tests/tcg/mips/mips64-dspr2/shrav_qb.c         |   37 +++
>  tests/tcg/mips/mips64-dspr2/shrav_r_ob.c       |   22 ++
>  tests/tcg/mips/mips64-dspr2/shrav_r_qb.c       |   37 +++
>  tests/tcg/mips/mips64-dspr2/shrl_ph.c          |   22 ++
>  tests/tcg/mips/mips64-dspr2/shrlv_ph.c         |   23 ++
>  tests/tcg/mips/mips64-dspr2/subqh_ph.c         |   23 ++
>  tests/tcg/mips/mips64-dspr2/subqh_r_ph.c       |   23 ++
>  tests/tcg/mips/mips64-dspr2/subqh_r_w.c        |   23 ++
>  tests/tcg/mips/mips64-dspr2/subqh_w.c          |   23 ++
>  tests/tcg/mips/mips64-dspr2/subu_ph.c          |   26 ++
>  tests/tcg/mips/mips64-dspr2/subu_qh.c          |   24 ++
>  tests/tcg/mips/mips64-dspr2/subu_s_ph.c        |   25 ++
>  tests/tcg/mips/mips64-dspr2/subu_s_qh.c        |   24 ++
>  tests/tcg/mips/mips64-dspr2/subuh_ob.c         |   23 ++
>  tests/tcg/mips/mips64-dspr2/subuh_qb.c         |   23 ++
>  tests/tcg/mips/mips64-dspr2/subuh_r_ob.c       |   23 ++
>  tests/tcg/mips/mips64-dspr2/subuh_r_qb.c       |   23 ++
>  487 files changed, 15870 insertions(+)
>  create mode 100644 tests/tcg/mips/mips32-dsp/Makefile
>  create mode 100644 tests/tcg/mips/mips32-dsp/absq_s_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/absq_s_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/addq_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/addq_s_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/addsc.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/addu_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/addu_s_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/addwc.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/bitrev.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/bposge32.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/cmp_eq_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/cmp_le_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/cmp_lt_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/cmpgu_eq_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/cmpgu_le_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/cmpgu_lt_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/cmpu_eq_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/cmpu_le_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/cmpu_lt_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/dpaq_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/dpaq_sa_l_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/dpau_h_qbl.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/dpau_h_qbr.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/dpsq_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/dpsq_sa_l_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/dpsu_h_qbl.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/dpsu_h_qbr.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extp.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extpdp.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extpdpv.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extpv.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extr_r_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extr_rs_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extr_s_h.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extr_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extrv_r_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extrv_rs_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extrv_s_h.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/extrv_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/insv.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/lbux.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/lhx.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/lwx.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/madd.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/maddu.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/main.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/maq_s_w_phl.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/maq_s_w_phr.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/maq_sa_w_phl.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/maq_sa_w_phr.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/mfhi.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/mflo.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/modsub.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/msub.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/msubu.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/mthi.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/mthlip.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/mtlo.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/muleq_s_w_phl.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/muleq_s_w_phr.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/muleu_s_ph_qbl.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/muleu_s_ph_qbr.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/mulq_rs_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/mult.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/multu.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/packrl_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/pick_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/pick_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/preceq_w_phl.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/preceq_w_phr.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/precequ_ph_qbl.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/precequ_ph_qbla.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/precequ_ph_qbr.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/precequ_ph_qbra.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/preceu_ph_qbl.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/preceu_ph_qbla.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/preceu_ph_qbr.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/preceu_ph_qbra.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/precrq_ph_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/precrq_qb_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/precrq_rs_ph_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/precrqu_s_qb_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/raddu_w_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/rddsp.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/repl_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/repl_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/replv_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/replv_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shilo.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shilov.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shll_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shll_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shll_s_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shll_s_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shllv_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shllv_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shllv_s_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shllv_s_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shra_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shra_r_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shra_r_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shrav_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shrav_r_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shrav_r_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shrl_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/shrlv_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/subq_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/subq_s_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/subq_s_w.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/subu_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/subu_s_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dsp/wrdsp.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/Makefile
>  create mode 100644 tests/tcg/mips/mips32-dspr2/absq_s_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/addqh_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/addqh_r_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/addqh_r_w.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/addqh_w.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/addu_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/addu_s_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/adduh_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/adduh_r_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/append.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/balign.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/cmpgdu_eq_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/cmpgdu_le_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/cmpgdu_lt_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/dpa_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/dpaqx_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/dpaqx_sa_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/dpax_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/dps_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/dpsqx_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/dpsqx_sa_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/dpsx_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/mul_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/mul_s_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/muleq_s_w_phl.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/mulq_rs_w.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/mulq_s_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/mulq_s_w.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/mulsa_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/mulsaq_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/precr_qb_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/precr_sra_r_ph_w.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/prepend.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/shra_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/shra_r_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/shrav_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/shrav_r_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/shrl_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/shrlv_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/subqh_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/subqh_r_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/subqh_r_w.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/subqh_w.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/subu_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/subu_s_ph.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/subuh_qb.c
>  create mode 100644 tests/tcg/mips/mips32-dspr2/subuh_r_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/Makefile
>  create mode 100644 tests/tcg/mips/mips64-dsp/absq_s_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/absq_s_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/absq_s_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/absq_s_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/absq_s_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addq_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addq_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addq_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addq_s_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addq_s_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addq_s_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addsc.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addu_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addu_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addu_s_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addu_s_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/addwc.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/bitrev.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/bposge32.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/bposge64.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmp_eq_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmp_eq_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmp_eq_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmp_le_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmp_le_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmp_le_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmp_lt_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmp_lt_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmp_lt_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_eq_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_eq_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_le_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_le_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_lt_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpgu_lt_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpu_eq_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpu_eq_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpu_le_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpu_le_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpu_lt_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/cmpu_lt_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dappend.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextp.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextpdp.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextpdpv.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextpv.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextr_l.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextr_r_l.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextr_r_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextr_rs_l.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextr_rs_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextr_s_h.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextr_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextrv_l.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextrv_r_l.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextrv_r_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextrv_rs_l.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextrv_rs_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextrv_s_h.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dextrv_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dinsv.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dmadd.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dmaddu.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dmsub.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dmsubu.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dmthlip.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpaq_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpaq_s_w_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpaq_sa_l_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpaq_sa_l_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpau_h_obl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpau_h_obr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpau_h_qbl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpau_h_qbr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpsq_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpsq_s_w_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpsq_sa_l_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpsq_sa_l_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpsu_h_obl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpsu_h_obr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpsu_h_qbl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dpsu_h_qbr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dshilo.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/dshilov.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extp.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extpdp.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extpdpv.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extpv.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extr_r_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extr_rs_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extr_s_h.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extr_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extrv_r_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extrv_rs_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extrv_s_h.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/extrv_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/head.S
>  create mode 100644 tests/tcg/mips/mips64-dsp/insv.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/io.h
>  create mode 100644 tests/tcg/mips/mips64-dsp/lbux.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/ldx.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/lhx.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/lwx.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/madd.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maddu.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_s_l_pwl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_s_l_pwr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_phl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_phr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_qhll.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_qhlr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_qhrl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_s_w_qhrr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_phl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_phr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_qhll.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_qhlr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_qhrl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/maq_sa_w_qhrr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mfhi.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mflo.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mips_boot.lds
>  create mode 100644 tests/tcg/mips/mips64-dsp/modsub.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/msub.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/msubu.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mthi.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mthlip.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mtlo.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/muleq_s_pw_qhl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/muleq_s_pw_qhr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/muleq_s_w_phl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/muleq_s_w_phr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/muleu_s_ph_qbl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/muleu_s_ph_qbr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/muleu_s_qh_obl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/muleu_s_qh_obr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mulq_rs_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mulq_rs_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mulsaq_s_l_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mulsaq_s_w_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/mult.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/multu.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/packrl_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/packrl_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/pick_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/pick_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/pick_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/pick_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/pick_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceq_l_pwl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceq_l_pwr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceq_pw_qhl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceq_pw_qhla.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceq_pw_qhr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceq_pw_qhra.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceq_w_phl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceq_w_phr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precequ_ph_qbl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precequ_ph_qbla.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precequ_ph_qbr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precequ_ph_qbra.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precequ_qh_obl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precequ_qh_obla.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precequ_qh_obr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precequ_qh_obra.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceu_ph_qbl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceu_ph_qbla.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceu_ph_qbr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceu_ph_qbra.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceu_qh_obl.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceu_qh_obla.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceu_qh_obr.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/preceu_qh_obra.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precr_ob_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precr_sra_qh_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precr_sra_r_qh_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precrq_ob_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precrq_ph_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precrq_pw_l.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precrq_qb_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precrq_qh_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precrq_rs_ph_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precrq_rs_qh_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precrqu_s_ob_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/precrqu_s_qb_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/prependd.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/prependw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/printf.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/raddu_l_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/raddu_w_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/rddsp.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/repl_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/repl_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/repl_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/repl_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/repl_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/replv_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/replv_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/replv_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/replv_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shilo.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shilov.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shll_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shll_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shll_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shll_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shll_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shll_s_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shll_s_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shll_s_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shll_s_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shllv_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shllv_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shllv_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shllv_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shllv_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shllv_s_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shllv_s_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shllv_s_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shllv_s_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shra_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shra_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shra_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shra_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shra_r_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shra_r_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shra_r_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shra_r_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shra_r_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrav_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrav_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrav_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrav_r_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrav_r_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrav_r_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrav_r_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrl_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrl_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrl_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrlv_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrlv_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/shrlv_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subq_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subq_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subq_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subq_s_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subq_s_pw.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subq_s_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subq_s_w.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subu_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subu_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subu_s_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/subu_s_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dsp/wrdsp.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/.directory
>  create mode 100644 tests/tcg/mips/mips64-dspr2/Makefile
>  create mode 100644 tests/tcg/mips/mips64-dspr2/absq_s_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/addqh_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/addqh_r_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/addqh_r_w.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/addqh_w.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/addu_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/addu_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/addu_s_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/addu_s_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/adduh_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/adduh_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/adduh_r_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/adduh_r_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/append.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/balign.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_eq_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_eq_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_le_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_le_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_lt_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/cmpgdu_lt_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dbalign.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dpa_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dpa_w_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dpaqx_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dpaqx_sa_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dpax_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dps_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dps_w_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dpsqx_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dpsqx_sa_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/dpsx_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/head.S
>  create mode 100644 tests/tcg/mips/mips64-dspr2/io.h
>  create mode 100644 tests/tcg/mips/mips64-dspr2/mips_boot.lds
>  create mode 100644 tests/tcg/mips/mips64-dspr2/mul_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/mul_s_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/muleq_s_w_phl.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/mulq_rs_w.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/mulq_s_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/mulq_s_w.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/mulsa_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/mulsaq_s_w_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/precr_qb_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/precr_sra_ph_w.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/precr_sra_r_ph_w.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/prepend.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/printf.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/shra_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/shra_r_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/shrav_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/shrav_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/shrav_r_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/shrav_r_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/shrl_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/shrlv_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subqh_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subqh_r_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subqh_r_w.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subqh_w.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subu_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subu_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subu_s_ph.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subu_s_qh.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subuh_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subuh_qb.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subuh_r_ob.c
>  create mode 100644 tests/tcg/mips/mips64-dspr2/subuh_r_qb.c
> 
> diff --git a/tests/tcg/mips/mips32-dsp/Makefile 
> b/tests/tcg/mips/mips32-dsp/Makefile
> new file mode 100644
> index 0000000..232527b
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/Makefile
> @@ -0,0 +1,135 @@
> +-include ../../config-host.mak
> +
> +CROSS=mips64el-unknown-linux-gnu-
> +
> +SIM=qemu-mipsel
> +SIM_FLAGS=-cpu 74Kf
> +
> +CC      = $(CROSS)gcc
> +CFLAGS  = -mabi=32 -march=mips32r2 -mgp32 -mdsp -static
> +
> +TESTCASES = absq_s_ph.tst
> +TESTCASES += absq_s_w.tst
> +TESTCASES += addq_ph.tst
> +TESTCASES += addq_s_ph.tst
> +TESTCASES += addsc.tst
> +TESTCASES += addu_qb.tst
> +TESTCASES += addu_s_qb.tst
> +TESTCASES += addwc.tst
> +TESTCASES += bitrev.tst
> +TESTCASES += bposge32.tst
> +TESTCASES += cmp_eq_ph.tst
> +TESTCASES += cmpgu_eq_qb.tst
> +TESTCASES += cmpgu_le_qb.tst
> +TESTCASES += cmpgu_lt_qb.tst
> +TESTCASES += cmp_le_ph.tst
> +TESTCASES += cmp_lt_ph.tst
> +TESTCASES += cmpu_eq_qb.tst
> +TESTCASES += cmpu_le_qb.tst
> +TESTCASES += cmpu_lt_qb.tst
> +TESTCASES += dpaq_sa_l_w.tst
> +TESTCASES += dpaq_s_w_ph.tst
> +TESTCASES += dpau_h_qbl.tst
> +TESTCASES += dpau_h_qbr.tst
> +TESTCASES += dpsq_sa_l_w.tst
> +TESTCASES += dpsq_s_w_ph.tst
> +TESTCASES += dpsu_h_qbl.tst
> +TESTCASES += dpsu_h_qbr.tst
> +TESTCASES += extp.tst
> +TESTCASES += extpdp.tst
> +TESTCASES += extpdpv.tst
> +TESTCASES += extpv.tst
> +TESTCASES += extr_rs_w.tst
> +TESTCASES += extr_r_w.tst
> +TESTCASES += extr_s_h.tst
> +TESTCASES += extrv_rs_w.tst
> +TESTCASES += extrv_r_w.tst
> +TESTCASES += extrv_s_h.tst
> +TESTCASES += extrv_w.tst
> +TESTCASES += extr_w.tst
> +TESTCASES += insv.tst
> +TESTCASES += lbux.tst
> +TESTCASES += lhx.tst
> +TESTCASES += lwx.tst
> +TESTCASES += madd.tst
> +TESTCASES += maddu.tst
> +TESTCASES += maq_sa_w_phl.tst
> +TESTCASES += maq_sa_w_phr.tst
> +TESTCASES += maq_s_w_phl.tst
> +TESTCASES += maq_s_w_phr.tst
> +TESTCASES += mfhi.tst
> +TESTCASES += mflo.tst
> +TESTCASES += modsub.tst
> +TESTCASES += msub.tst
> +TESTCASES += msubu.tst
> +TESTCASES += mthi.tst
> +TESTCASES += mthlip.tst
> +TESTCASES += mtlo.tst
> +TESTCASES += muleq_s_w_phl.tst
> +TESTCASES += muleq_s_w_phr.tst
> +TESTCASES += muleu_s_ph_qbl.tst
> +TESTCASES += muleu_s_ph_qbr.tst
> +TESTCASES += mulq_rs_ph.tst
> +TESTCASES += mult.tst
> +TESTCASES += multu.tst
> +TESTCASES += packrl_ph.tst
> +TESTCASES += pick_ph.tst
> +TESTCASES += pick_qb.tst
> +TESTCASES += precequ_ph_qbla.tst
> +TESTCASES += precequ_ph_qbl.tst
> +TESTCASES += precequ_ph_qbra.tst
> +TESTCASES += precequ_ph_qbr.tst
> +TESTCASES += preceq_w_phl.tst
> +TESTCASES += preceq_w_phr.tst
> +TESTCASES += preceu_ph_qbla.tst
> +TESTCASES += preceu_ph_qbl.tst
> +TESTCASES += preceu_ph_qbra.tst
> +TESTCASES += preceu_ph_qbr.tst
> +TESTCASES += precrq_ph_w.tst
> +TESTCASES += precrq_qb_ph.tst
> +TESTCASES += precrq_rs_ph_w.tst
> +TESTCASES += precrqu_s_qb_ph.tst
> +TESTCASES += raddu_w_qb.tst
> +TESTCASES += rddsp.tst
> +TESTCASES += repl_ph.tst
> +TESTCASES += repl_qb.tst
> +TESTCASES += replv_ph.tst
> +TESTCASES += replv_qb.tst
> +TESTCASES += shilo.tst
> +TESTCASES += shilov.tst
> +TESTCASES += shll_ph.tst
> +TESTCASES += shll_qb.tst
> +TESTCASES += shll_s_ph.tst
> +TESTCASES += shll_s_w.tst
> +TESTCASES += shllv_ph.tst
> +TESTCASES += shllv_qb.tst
> +TESTCASES += shllv_s_ph.tst
> +TESTCASES += shllv_s_w.tst
> +TESTCASES += shra_ph.tst
> +TESTCASES += shra_r_ph.tst
> +TESTCASES += shra_r_w.tst
> +TESTCASES += shrav_ph.tst
> +TESTCASES += shrav_r_ph.tst
> +TESTCASES += shrav_r_w.tst
> +TESTCASES += shrl_qb.tst
> +TESTCASES += shrlv_qb.tst
> +TESTCASES += subq_ph.tst
> +TESTCASES += subq_s_ph.tst
> +TESTCASES += subq_s_w.tst
> +TESTCASES += subu_qb.tst
> +TESTCASES += subu_s_qb.tst
> +TESTCASES += wrdsp.tst
> +
> +all: $(TESTCASES)
> +
> +%.tst: %.c
> +     $(CC) $(CFLAGS) $< -o $@
> +
> +check: $(TESTCASES)
> +     @for case in $(TESTCASES); do \
> +        echo $(SIM) $(SIM_FLAGS) ./$$case;\
> +        $(SIM) $(SIM_FLAGS) ./$$case; \
> +     done
> +
> +clean:
> +     $(RM) -rf $(TESTCASES)
> diff --git a/tests/tcg/mips/mips32-dsp/absq_s_ph.c 
> b/tests/tcg/mips/mips32-dsp/absq_s_ph.c
> new file mode 100644
> index 0000000..aa84112
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/absq_s_ph.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt     = 0x10017EFD;
> +    result = 0x10017EFD;
> +
> +    __asm
> +        ("absq_s.ph %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rt     = 0x8000A536;
> +    result = 0x7FFF5ACA;
> +
> +    __asm
> +        ("absq_s.ph %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/absq_s_w.c 
> b/tests/tcg/mips/mips32-dsp/absq_s_w.c
> new file mode 100644
> index 0000000..3f52a48
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/absq_s_w.c
> @@ -0,0 +1,37 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt     = 0x80000000;
> +    result = 0x7FFFFFFF;
> +    __asm
> +        ("absq_s.w %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rt     = 0x80030000;
> +    result = 0x7FFD0000;
> +    __asm
> +        ("absq_s.w %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rt     = 0x31036080;
> +    result = 0x31036080;
> +    __asm
> +        ("absq_s.w %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/addq_ph.c 
> b/tests/tcg/mips/mips32-dsp/addq_ph.c
> new file mode 100644
> index 0000000..2d9b6fc
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/addq_ph.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0xFFFFFFFF;
> +    rt     = 0x10101010;
> +    result = 0x100F100F;
> +    __asm
> +        ("addq.ph   %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    rs     = 0x3712847D;
> +    rt     = 0x0031AF2D;
> +    result = 0x374333AA;
> +    __asm
> +        ("addq.ph   %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/addq_s_ph.c 
> b/tests/tcg/mips/mips32-dsp/addq_s_ph.c
> new file mode 100644
> index 0000000..ace1ecd
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/addq_s_ph.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0xFFFFFFFF;
> +    rt     = 0x10101010;
> +    result = 0x100F100F;
> +    __asm
> +        ("addq_s.ph   %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    rs     = 0x3712847D;
> +    rt     = 0x0031AF2D;
> +    result = 0x37438000;
> +    __asm
> +        ("addq_s.ph   %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/addsc.c 
> b/tests/tcg/mips/mips32-dsp/addsc.c
> new file mode 100644
> index 0000000..9ad974a
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/addsc.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x0000000F;
> +    rt     = 0x00000001;
> +    result = 0x00000010;
> +    __asm
> +        ("addsc %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0x00001110;
> +    __asm
> +        ("addsc %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/addu_qb.c 
> b/tests/tcg/mips/mips32-dsp/addu_qb.c
> new file mode 100644
> index 0000000..1b98e5e
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/addu_qb.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010001;
> +    result = 0x00000000;
> +    __asm
> +        ("addu.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0xFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0xFF011112;
> +    __asm
> +        ("addu.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/addu_s_qb.c 
> b/tests/tcg/mips/mips32-dsp/addu_s_qb.c
> new file mode 100644
> index 0000000..46717ee
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/addu_s_qb.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x10FF01FF;
> +    rt     = 0x10010001;
> +    result = 0x20FF01FF;
> +    __asm
> +        ("addu_s.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0xFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0xFFFF1112;
> +    __asm
> +        ("addu_s.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/addwc.c 
> b/tests/tcg/mips/mips32-dsp/addwc.c
> new file mode 100644
> index 0000000..d47ac65
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/addwc.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x10FF01FF;
> +    rt     = 0x10010001;
> +    result = 0x21000200;
> +    __asm
> +        ("addwc %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0xFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0x00011112;
> +    __asm
> +        ("addwc %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/bitrev.c 
> b/tests/tcg/mips/mips32-dsp/bitrev.c
> new file mode 100644
> index 0000000..04d8a38
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/bitrev.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt     = 0x12345678;
> +    result = 0x00001E6A;
> +
> +    __asm
> +        ("bitrev %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/bposge32.c 
> b/tests/tcg/mips/mips32-dsp/bposge32.c
> new file mode 100644
> index 0000000..d25417e
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/bposge32.c
> @@ -0,0 +1,44 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int dsp, sum;
> +    int result;
> +
> +    dsp =  0x20;
> +    sum = 0x01;
> +    result = 0x02;
> +
> +    __asm
> +        ("wrdsp %1\n\t"
> +         "bposge32 test1\n\t"
> +         "nop\n\t"
> +         "addi %0, 0xA2\n\t"
> +         "nop\n\t"
> +         "test1:\n\t"
> +         "addi %0, 0x01\n\t"
> +         : "+r"(sum)
> +         : "r"(dsp)
> +        );
> +    assert(sum == result);
> +
> +    dsp =  0x10;
> +    sum = 0x01;
> +    result = 0xA4;
> +
> +    __asm
> +        ("wrdsp %1\n\t"
> +         "bposge32 test2\n\t"
> +         "nop\n\t"
> +         "addi %0, 0xA2\n\t"
> +         "nop\n\t"
> +         "test2:\n\t"
> +         "addi %0, 0x01\n\t"
> +         : "+r"(sum)
> +         : "r"(dsp)
> +        );
> +    assert(sum == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/cmp_eq_ph.c 
> b/tests/tcg/mips/mips32-dsp/cmp_eq_ph.c
> new file mode 100644
> index 0000000..957bd88
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/cmp_eq_ph.c
> @@ -0,0 +1,35 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA33FF;
> +    result = 0x00;
> +    __asm
> +        ("cmp.eq.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    rd = (rd >> 24) & 0x03;
> +    assert(rd == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x03;
> +    __asm
> +        ("cmp.eq.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    rd = (rd >> 24) & 0x03;
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/cmp_le_ph.c 
> b/tests/tcg/mips/mips32-dsp/cmp_le_ph.c
> new file mode 100644
> index 0000000..356f156
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/cmp_le_ph.c
> @@ -0,0 +1,35 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA33FF;
> +    result = 0x02;
> +    __asm
> +        ("cmp.le.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    rd = (rd >> 24) & 0x03;
> +    assert(rd == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x03;
> +    __asm
> +        ("cmp.le.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    rd = (rd >> 24) & 0x03;
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/cmp_lt_ph.c 
> b/tests/tcg/mips/mips32-dsp/cmp_lt_ph.c
> new file mode 100644
> index 0000000..3fb4827
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/cmp_lt_ph.c
> @@ -0,0 +1,35 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA33FF;
> +    result = 0x02;
> +    __asm
> +        ("cmp.lt.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    rd = (rd >> 24) & 0x03;
> +    assert(rd == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x00;
> +    __asm
> +        ("cmp.lt.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    rd = (rd >> 24) & 0x03;
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/cmpgu_eq_qb.c 
> b/tests/tcg/mips/mips32-dsp/cmpgu_eq_qb.c
> new file mode 100644
> index 0000000..2615c84
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/cmpgu_eq_qb.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA70FF;
> +    result = 0x02;
> +    __asm
> +        ("cmpgu.eq.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    assert(rd == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x0F;
> +    __asm
> +        ("cmpgu.eq.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/cmpgu_le_qb.c 
> b/tests/tcg/mips/mips32-dsp/cmpgu_le_qb.c
> new file mode 100644
> index 0000000..65d0813
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/cmpgu_le_qb.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA70FF;
> +    result = 0x0F;
> +    __asm
> +        ("cmpgu.le.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    assert(rd == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11766066;
> +    result = 0x09;
> +    __asm
> +        ("cmpgu.le.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/cmpgu_lt_qb.c 
> b/tests/tcg/mips/mips32-dsp/cmpgu_lt_qb.c
> new file mode 100644
> index 0000000..7dddad9
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/cmpgu_lt_qb.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA70FF;
> +    result = 0x0D;
> +    __asm
> +        ("cmpgu.lt.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    assert(rd == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11766066;
> +    result = 0x00;
> +    __asm
> +        ("cmpgu.lt.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/cmpu_eq_qb.c 
> b/tests/tcg/mips/mips32-dsp/cmpu_eq_qb.c
> new file mode 100644
> index 0000000..680f2a1
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/cmpu_eq_qb.c
> @@ -0,0 +1,35 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int dsp;
> +    int result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x02;
> +    __asm
> +        ("cmpu.eq.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(dsp == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x0F;
> +    __asm
> +        ("cmpu.eq.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(dsp == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/cmpu_le_qb.c 
> b/tests/tcg/mips/mips32-dsp/cmpu_le_qb.c
> new file mode 100644
> index 0000000..43cfa50
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/cmpu_le_qb.c
> @@ -0,0 +1,35 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int dsp;
> +    int result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x0F;
> +    __asm
> +        ("cmpu.le.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(dsp == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x0F;
> +    __asm
> +        ("cmpu.le.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(dsp == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/cmpu_lt_qb.c 
> b/tests/tcg/mips/mips32-dsp/cmpu_lt_qb.c
> new file mode 100644
> index 0000000..074ca5b
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/cmpu_lt_qb.c
> @@ -0,0 +1,35 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int dsp;
> +    int result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x0D;
> +    __asm
> +        ("cmpu.lt.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(dsp == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x00;
> +    __asm
> +        ("cmpu.lt.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(dsp == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/dpaq_s_w_ph.c 
> b/tests/tcg/mips/mips32-dsp/dpaq_s_w_ph.c
> new file mode 100644
> index 0000000..a6425b6
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/dpaq_s_w_ph.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, dsp;
> +    int ach = 0, acl = 0;
> +    int resulth, resultl, resultdsp;
> +
> +    rs        = 0x800000FF;
> +    rt        = 0x80000002;
> +    resulth   = 0x00;
> +    resultl   = 0x800003FB;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi        %0, $ac1\n\t"
> +         "mtlo        %1, $ac1\n\t"
> +         "dpaq_s.w.ph $ac1, %3, %4\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         "rddsp       %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = dsp >> 17 & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/dpaq_sa_l_w.c 
> b/tests/tcg/mips/mips32-dsp/dpaq_sa_l_w.c
> new file mode 100644
> index 0000000..02bac2a
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/dpaq_sa_l_w.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, dsp;
> +    int ach = 0, acl = 0;
> +    int resulth, resultl, resultdsp;
> +
> +    rs        = 0x800000FF;
> +    rt        = 0x80000002;
> +    resulth   = 0x7FFFFFFF;
> +    resultl   = 0xFFFFFFFF;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi        %0, $ac1\n\t"
> +         "mtlo        %0, $ac1\n\t"
> +         "dpaq_sa.l.w $ac1, %3, %4\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         "rddsp       %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/dpau_h_qbl.c 
> b/tests/tcg/mips/mips32-dsp/dpau_h_qbl.c
> new file mode 100644
> index 0000000..6017b5e
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/dpau_h_qbl.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int ach = 5, acl = 3;
> +    int resulth, resultl;
> +
> +    rs        = 0x800000FF;
> +    rt        = 0x80000002;
> +    resulth   = 0x05;
> +    resultl   = 0x4003;
> +    __asm
> +        ("mthi       %0, $ac1\n\t"
> +         "mtlo       %1, $ac1\n\t"
> +         "dpau.h.qbl $ac1, %2, %3\n\t"
> +         "mfhi       %0,   $ac1\n\t"
> +         "mflo       %1,   $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/dpau_h_qbr.c 
> b/tests/tcg/mips/mips32-dsp/dpau_h_qbr.c
> new file mode 100644
> index 0000000..e4abb2e
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/dpau_h_qbr.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int ach = 5, acl = 3;
> +    int resulth, resultl;
> +
> +    rs        = 0x800000FF;
> +    rt        = 0x80000002;
> +    resulth   = 0x05;
> +    resultl   = 0x0201;
> +    __asm
> +        ("mthi       %0, $ac1\n\t"
> +         "mtlo       %1, $ac1\n\t"
> +         "dpau.h.qbr $ac1, %2, %3\n\t"
> +         "mfhi       %0,   $ac1\n\t"
> +         "mflo       %1,   $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/dpsq_s_w_ph.c 
> b/tests/tcg/mips/mips32-dsp/dpsq_s_w_ph.c
> new file mode 100644
> index 0000000..70ad443
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/dpsq_s_w_ph.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xEE9794A3;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsq_s.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/dpsq_sa_l_w.c 
> b/tests/tcg/mips/mips32-dsp/dpsq_sa_l_w.c
> new file mode 100644
> index 0000000..3d6b24c
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/dpsq_sa_l_w.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, dsp;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl, resultdsp;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x7FFFFFFF;
> +    resultl = 0xFFFFFFFF;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsq_sa.l.w $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/dpsu_h_qbl.c 
> b/tests/tcg/mips/mips32-dsp/dpsu_h_qbl.c
> new file mode 100644
> index 0000000..94e2bf6
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/dpsu_h_qbl.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFEE5;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsu.h.qbl $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/dpsu_h_qbr.c 
> b/tests/tcg/mips/mips32-dsp/dpsu_h_qbr.c
> new file mode 100644
> index 0000000..a1e6635
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/dpsu_h_qbr.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xFFFFE233;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsu.h.qbr $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extp.c 
> b/tests/tcg/mips/mips32-dsp/extp.c
> new file mode 100644
> index 0000000..21a67af
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extp.c
> @@ -0,0 +1,44 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    result = 0x000C;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extp %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 14) & 0x01;
> +    assert(dsp == 0);
> +    assert(result == rt);
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x01;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extp %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 14) & 0x01;
> +    assert(dsp == 1);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extpdp.c 
> b/tests/tcg/mips/mips32-dsp/extpdp.c
> new file mode 100644
> index 0000000..15ba082
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extpdp.c
> @@ -0,0 +1,46 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, ach, acl, dsp, pos, efi;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    result = 0x000C;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpdp %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    pos =  dsp & 0x3F;
> +    efi = (dsp >> 14) & 0x01;
> +    assert(pos == 3);
> +    assert(efi == 0);
> +    assert(result == rt);
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x01;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpdp %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    efi = (dsp >> 14) & 0x01;
> +    assert(efi == 1);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extpdpv.c 
> b/tests/tcg/mips/mips32-dsp/extpdpv.c
> new file mode 100644
> index 0000000..f5774ee
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extpdpv.c
> @@ -0,0 +1,47 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs, ach, acl, dsp, pos, efi;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0x000C;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpdpv %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl), "r"(rs)
> +        );
> +    pos =  dsp & 0x3F;
> +    efi = (dsp >> 14) & 0x01;
> +    assert(pos == 3);
> +    assert(efi == 0);
> +    assert(result == rt);
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x01;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpdpv %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl), "r"(rs)
> +        );
> +    efi = (dsp >> 14) & 0x01;
> +    assert(efi == 1);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extpv.c 
> b/tests/tcg/mips/mips32-dsp/extpv.c
> new file mode 100644
> index 0000000..401b94a
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extpv.c
> @@ -0,0 +1,45 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, ac, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    ac  = 0x03;
> +    result = 0x000C;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpv %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl), "r"(ac)
> +        );
> +    dsp = (dsp >> 14) & 0x01;
> +    assert(dsp == 0);
> +    assert(result == rt);
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x01;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpv %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl), "r"(ac)
> +        );
> +    dsp = (dsp >> 14) & 0x01;
> +    assert(dsp == 1);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extr_r_w.c 
> b/tests/tcg/mips/mips32-dsp/extr_r_w.c
> new file mode 100644
> index 0000000..570dfbd
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extr_r_w.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    result = 0xA0001699;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extr_r.w %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    assert(dsp == 1);
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extr_rs_w.c 
> b/tests/tcg/mips/mips32-dsp/extr_rs_w.c
> new file mode 100644
> index 0000000..a0bf7b4
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extr_rs_w.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    result = 0x7FFFFFFF;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extr_rs.w %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    assert(dsp == 1);
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extr_s_h.c 
> b/tests/tcg/mips/mips32-dsp/extr_s_h.c
> new file mode 100644
> index 0000000..c863f29
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extr_s_h.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    result = 0x00007FFF;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extr_s.h %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    assert(dsp == 1);
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extr_w.c 
> b/tests/tcg/mips/mips32-dsp/extr_w.c
> new file mode 100644
> index 0000000..40994cb
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extr_w.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    result = 0xA0001699;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extr.w %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    assert(dsp == 1);
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extrv_r_w.c 
> b/tests/tcg/mips/mips32-dsp/extrv_r_w.c
> new file mode 100644
> index 0000000..43aba53
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extrv_r_w.c
> @@ -0,0 +1,29 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0xA0001699;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "extrv_r.w %0, $ac1, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(rs), "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    assert(dsp == 1);
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extrv_rs_w.c 
> b/tests/tcg/mips/mips32-dsp/extrv_rs_w.c
> new file mode 100644
> index 0000000..60e0d43
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extrv_rs_w.c
> @@ -0,0 +1,29 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0x7FFFFFFF;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "extrv_rs.w %0, $ac1, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(rs), "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    assert(dsp == 1);
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extrv_s_h.c 
> b/tests/tcg/mips/mips32-dsp/extrv_s_h.c
> new file mode 100644
> index 0000000..c7f70e3
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extrv_s_h.c
> @@ -0,0 +1,29 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0x00007FFF;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "extrv_s.h %0, $ac1, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(rs), "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    assert(dsp == 1);
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/extrv_w.c 
> b/tests/tcg/mips/mips32-dsp/extrv_w.c
> new file mode 100644
> index 0000000..c63a25c
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/extrv_w.c
> @@ -0,0 +1,29 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs, ach, acl, dsp;
> +    int result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0xA0001699;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "extrv.w %0, $ac1, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(rs), "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    assert(dsp == 1);
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/insv.c 
> b/tests/tcg/mips/mips32-dsp/insv.c
> new file mode 100644
> index 0000000..7e3b047
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/insv.c
> @@ -0,0 +1,23 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs, dsp;
> +    int result;
> +
> +    /* msb = 10, lsb = 5 */
> +    dsp    = 0x305;
> +    rt     = 0x12345678;
> +    rs     = 0x87654321;
> +    result = 0x12345338;
> +    __asm
> +        ("wrdsp %2, 0x03\n\t"
> +         "insv  %0, %1\n\t"
> +         : "+r"(rt)
> +         : "r"(rs), "r"(dsp)
> +        );
> +    assert(rt == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/lbux.c 
> b/tests/tcg/mips/mips32-dsp/lbux.c
> new file mode 100644
> index 0000000..2337abe
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/lbux.c
> @@ -0,0 +1,25 @@
> +#include <stdio.h>
> +#include <assert.h>
> +
> +int main(void)
> +{
> +    int value, rd;
> +    int *p;
> +    unsigned long addr, index;
> +    int result;
> +
> +    value  = 0xBCDEF389;
> +    p = &value;
> +    addr = (unsigned long)p;
> +    index  = 0;
> +    result = value & 0xFF;
> +    __asm
> +        ("lbux %0, %1(%2)\n\t"
> +         : "=r"(rd)
> +         : "r"(index), "r"(addr)
> +        );
> +
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/lhx.c b/tests/tcg/mips/mips32-dsp/lhx.c
> new file mode 100644
> index 0000000..10be3b3
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/lhx.c
> @@ -0,0 +1,25 @@
> +#include <stdio.h>
> +#include <assert.h>
> +
> +int main(void)
> +{
> +    int value, rd;
> +    int *p;
> +    unsigned long addr, index;
> +    int result;
> +
> +    value  = 0xBCDEF389;
> +    p = &value;
> +    addr = (unsigned long)p;
> +    index  = 0;
> +    result = 0xFFFFF389;
> +    __asm
> +        ("lhx %0, %1(%2)\n\t"
> +         : "=r"(rd)
> +         : "r"(index), "r"(addr)
> +        );
> +
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/lwx.c b/tests/tcg/mips/mips32-dsp/lwx.c
> new file mode 100644
> index 0000000..e6543c9
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/lwx.c
> @@ -0,0 +1,25 @@
> +#include <stdio.h>
> +#include <assert.h>
> +
> +int main(void)
> +{
> +    int value, rd;
> +    int *p;
> +    unsigned long addr, index;
> +    int result;
> +
> +    value  = 0xBCDEF389;
> +    p = &value;
> +    addr = (unsigned long)p;
> +    index  = 0;
> +    result = 0xBCDEF389;
> +    __asm
> +        ("lwx %0, %1(%2)\n\t"
> +         : "=r"(rd)
> +         : "r"(index), "r"(addr)
> +        );
> +
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/madd.c 
> b/tests/tcg/mips/mips32-dsp/madd.c
> new file mode 100644
> index 0000000..af4bfcf
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/madd.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs;
> +    int achi, acli;
> +    int acho, aclo;
> +    int resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0x01;
> +    rt  = 0x01;
> +    resulth = 0x05;
> +    resultl = 0xB4CC;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "madd $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    assert(resulth == acho);
> +    assert(resultl == aclo);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/maddu.c 
> b/tests/tcg/mips/mips32-dsp/maddu.c
> new file mode 100644
> index 0000000..af4bfcf
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/maddu.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs;
> +    int achi, acli;
> +    int acho, aclo;
> +    int resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0x01;
> +    rt  = 0x01;
> +    resulth = 0x05;
> +    resultl = 0xB4CC;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "madd $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    assert(resulth == acho);
> +    assert(resultl == aclo);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/main.c 
> b/tests/tcg/mips/mips32-dsp/main.c
> new file mode 100644
> index 0000000..b296b20
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/main.c
> @@ -0,0 +1,6 @@
> +#include<stdio.h>
> +
> +int main()
> +{
> +    printf("hello world\n");
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/maq_s_w_phl.c 
> b/tests/tcg/mips/mips32-dsp/maq_s_w_phl.c
> new file mode 100644
> index 0000000..f5de818
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/maq_s_w_phl.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs;
> +    int achi, acli;
> +    int acho, aclo;
> +    int resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0xFF060000;
> +    rt  = 0xCB000000;
> +    resulth = 0x04;
> +    resultl = 0x947438CB;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.w.phl $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    assert(resulth == acho);
> +    assert(resultl == aclo);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/maq_s_w_phr.c 
> b/tests/tcg/mips/mips32-dsp/maq_s_w_phr.c
> new file mode 100644
> index 0000000..8336f00
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/maq_s_w_phr.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs;
> +    int achi, acli;
> +    int acho, aclo;
> +    int resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0xFF06;
> +    rt  = 0xCB00;
> +    resulth = 0x04;
> +    resultl = 0x947438CB;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.w.phr $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    assert(resulth == acho);
> +    assert(resultl == aclo);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/maq_sa_w_phl.c 
> b/tests/tcg/mips/mips32-dsp/maq_sa_w_phl.c
> new file mode 100644
> index 0000000..6111d8d
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/maq_sa_w_phl.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs;
> +    int achi, acli;
> +    int acho, aclo;
> +    int resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0xFF060000;
> +    rt  = 0xCB000000;
> +    resulth = 0x00;
> +    resultl = 0x7FFFFFFF;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_sa.w.phl $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    assert(resulth == acho);
> +    assert(resultl == aclo);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/maq_sa_w_phr.c 
> b/tests/tcg/mips/mips32-dsp/maq_sa_w_phr.c
> new file mode 100644
> index 0000000..96b4915
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/maq_sa_w_phr.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rt, rs;
> +    int achi, acli;
> +    int acho, aclo;
> +    int resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0xFF06;
> +    rt  = 0xCB00;
> +    resulth = 0x00;
> +    resultl = 0x7FFFFFFF;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_sa.w.phr $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    assert(resulth == acho);
> +    assert(resultl == aclo);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/mfhi.c 
> b/tests/tcg/mips/mips32-dsp/mfhi.c
> new file mode 100644
> index 0000000..43a8066
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/mfhi.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int achi, acho;
> +    int result;
> +
> +    achi   = 0x004433;
> +    result = 0x004433;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         : "=r"(acho)
> +         : "r"(achi)
> +        );
> +    assert(result == acho);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/mflo.c 
> b/tests/tcg/mips/mips32-dsp/mflo.c
> new file mode 100644
> index 0000000..caeafdb
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/mflo.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int acli, aclo;
> +    int result;
> +
> +    acli   = 0x004433;
> +    result = 0x004433;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         : "=r"(aclo)
> +         : "r"(acli)
> +        );
> +    assert(result == aclo);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/modsub.c 
> b/tests/tcg/mips/mips32-dsp/modsub.c
> new file mode 100644
> index 0000000..c294eeb
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/modsub.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0xFFFFFFFF;
> +    rt     = 0x000000FF;
> +    result = 0xFFFFFF00;
> +    __asm
> +        ("modsub %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    rs     = 0x00000000;
> +    rt     = 0x00CD1FFF;
> +    result = 0x0000CD1F;
> +    __asm
> +        ("modsub %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/msub.c 
> b/tests/tcg/mips/mips32-dsp/msub.c
> new file mode 100644
> index 0000000..5779e6f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/msub.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int achi, acli, rs, rt;
> +    int acho, aclo;
> +    int resulth, resultl;
> +
> +    rs      = 0x00BBAACC;
> +    rt      = 0x0B1C3D2F;
> +    achi    = 0x00004433;
> +    acli    = 0xFFCC0011;
> +    resulth = 0xFFF81F29;
> +    resultl = 0xB355089D;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "msub $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    assert(acho == resulth);
> +    assert(aclo == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/msubu.c 
> b/tests/tcg/mips/mips32-dsp/msubu.c
> new file mode 100644
> index 0000000..e0f9b5a
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/msubu.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int achi, acli, rs, rt;
> +    int acho, aclo;
> +    int resulth, resultl;
> +
> +    rs      = 0x00BBAACC;
> +    rt      = 0x0B1C3D2F;
> +    achi    = 0x00004433;
> +    acli    = 0xFFCC0011;
> +    resulth = 0xFFF81F29;
> +    resultl = 0xB355089D;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "msubu $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    assert(acho == resulth);
> +    assert(aclo == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/mthi.c 
> b/tests/tcg/mips/mips32-dsp/mthi.c
> new file mode 100644
> index 0000000..43a8066
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/mthi.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int achi, acho;
> +    int result;
> +
> +    achi   = 0x004433;
> +    result = 0x004433;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         : "=r"(acho)
> +         : "r"(achi)
> +        );
> +    assert(result == acho);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/mthlip.c 
> b/tests/tcg/mips/mips32-dsp/mthlip.c
> new file mode 100644
> index 0000000..74e83bf
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/mthlip.c
> @@ -0,0 +1,34 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, ach, acl, dsp;
> +    int result, resulth, resultl;
> +
> +    dsp = 0x07;
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    rs  = 0x00FFBBAA;
> +    resulth = 0xB4CB;
> +    resultl = 0x00FFBBAA;
> +    result  = 0x27;
> +
> +    __asm
> +        ("wrdsp %0, 0x01\n\t"
> +         "mthi %1, $ac1\n\t"
> +         "mtlo %2, $ac1\n\t"
> +         "mthlip %3, $ac1\n\t"
> +         "mfhi %1, $ac1\n\t"
> +         "mflo %2, $ac1\n\t"
> +         "rddsp %0\n\t"
> +         : "+r"(dsp), "+r"(ach), "+r"(acl)
> +         : "r"(rs)
> +        );
> +    dsp = dsp & 0x3F;
> +    assert(dsp == result);
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/mtlo.c 
> b/tests/tcg/mips/mips32-dsp/mtlo.c
> new file mode 100644
> index 0000000..caeafdb
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/mtlo.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int acli, aclo;
> +    int result;
> +
> +    acli   = 0x004433;
> +    result = 0x004433;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         : "=r"(aclo)
> +         : "r"(acli)
> +        );
> +    assert(result == aclo);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/muleq_s_w_phl.c 
> b/tests/tcg/mips/mips32-dsp/muleq_s_w_phl.c
> new file mode 100644
> index 0000000..b3a5370
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/muleq_s_w_phl.c
> @@ -0,0 +1,41 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80001234;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    rs = 0x12349988;
> +    rt = 0x43219988;
> +    result = 0x98be968;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips32-dsp/muleq_s_w_phr.c 
> b/tests/tcg/mips/mips32-dsp/muleq_s_w_phr.c
> new file mode 100644
> index 0000000..8066d7d
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/muleq_s_w_phr.c
> @@ -0,0 +1,40 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x8000;
> +    rt = 0x8000;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phr %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    rs = 0x1234;
> +    rt = 0x4321;
> +    result = 0x98be968;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phr %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbl.c 
> b/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbl.c
> new file mode 100644
> index 0000000..66a3828
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbl.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0xFFFF0000;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleu_s.ph.qbl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbr.c 
> b/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbr.c
> new file mode 100644
> index 0000000..4cc6c8f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/muleu_s_ph_qbr.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x8000;
> +    rt = 0x80004321;
> +    result = 0xFFFF0000;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleu_s.ph.qbr %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/mulq_rs_ph.c 
> b/tests/tcg/mips/mips32-dsp/mulq_rs_ph.c
> new file mode 100644
> index 0000000..c720603
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/mulq_rs_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0x7FFF098C;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mulq_rs.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/mult.c 
> b/tests/tcg/mips/mips32-dsp/mult.c
> new file mode 100644
> index 0000000..15e6fde
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/mult.c
> @@ -0,0 +1,24 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, ach, acl;
> +    int result, resulth, resultl;
> +
> +    rs  = 0x00FFBBAA;
> +    rt  = 0x4B231000;
> +    resulth = 0x4b0f01;
> +    resultl = 0x71f8a000;
> +    __asm
> +        ("mult $ac1, %2, %3\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(ach), "=r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/multu.c 
> b/tests/tcg/mips/mips32-dsp/multu.c
> new file mode 100644
> index 0000000..15e6fde
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/multu.c
> @@ -0,0 +1,24 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, ach, acl;
> +    int result, resulth, resultl;
> +
> +    rs  = 0x00FFBBAA;
> +    rt  = 0x4B231000;
> +    resulth = 0x4b0f01;
> +    resultl = 0x71f8a000;
> +    __asm
> +        ("mult $ac1, %2, %3\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(ach), "=r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/packrl_ph.c 
> b/tests/tcg/mips/mips32-dsp/packrl_ph.c
> new file mode 100644
> index 0000000..1f8e699
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/packrl_ph.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x56788765;
> +
> +    __asm
> +        ("packrl.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/pick_ph.c 
> b/tests/tcg/mips/mips32-dsp/pick_ph.c
> new file mode 100644
> index 0000000..73342cb
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/pick_ph.c
> @@ -0,0 +1,23 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    dsp = 0x0A000000;
> +    result = 0x12344321;
> +
> +    __asm
> +        ("wrdsp %3, 0x10\n\t"
> +         "pick.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt), "r"(dsp)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/pick_qb.c 
> b/tests/tcg/mips/mips32-dsp/pick_qb.c
> new file mode 100644
> index 0000000..052cc58
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/pick_qb.c
> @@ -0,0 +1,23 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    dsp = 0x0A000000;
> +    result = 0x12655621;
> +
> +    __asm
> +        ("wrdsp %3, 0x10\n\t"
> +         "pick.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt), "r"(dsp)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/preceq_w_phl.c 
> b/tests/tcg/mips/mips32-dsp/preceq_w_phl.c
> new file mode 100644
> index 0000000..bf70bf7
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/preceq_w_phl.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x87650000;
> +
> +    __asm
> +        ("preceq.w.phl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/preceq_w_phr.c 
> b/tests/tcg/mips/mips32-dsp/preceq_w_phr.c
> new file mode 100644
> index 0000000..3f885ef
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/preceq_w_phr.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x43210000;
> +
> +    __asm
> +        ("preceq.w.phr %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/precequ_ph_qbl.c 
> b/tests/tcg/mips/mips32-dsp/precequ_ph_qbl.c
> new file mode 100644
> index 0000000..63b7a95
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/precequ_ph_qbl.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x43803280;
> +
> +    __asm
> +        ("precequ.ph.qbl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/precequ_ph_qbla.c 
> b/tests/tcg/mips/mips32-dsp/precequ_ph_qbla.c
> new file mode 100644
> index 0000000..31627f0
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/precequ_ph_qbla.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x43802180;
> +
> +    __asm
> +        ("precequ.ph.qbla %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/precequ_ph_qbr.c 
> b/tests/tcg/mips/mips32-dsp/precequ_ph_qbr.c
> new file mode 100644
> index 0000000..b6f72d3
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/precequ_ph_qbr.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x21801080;
> +
> +    __asm
> +        ("precequ.ph.qbr %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/precequ_ph_qbra.c 
> b/tests/tcg/mips/mips32-dsp/precequ_ph_qbra.c
> new file mode 100644
> index 0000000..4764fd0
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/precequ_ph_qbra.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x32801080;
> +
> +    __asm
> +        ("precequ.ph.qbra %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/preceu_ph_qbl.c 
> b/tests/tcg/mips/mips32-dsp/preceu_ph_qbl.c
> new file mode 100644
> index 0000000..fa95c26
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/preceu_ph_qbl.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x00870065;
> +
> +    __asm
> +        ("preceu.ph.qbl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/preceu_ph_qbla.c 
> b/tests/tcg/mips/mips32-dsp/preceu_ph_qbla.c
> new file mode 100644
> index 0000000..021f21a
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/preceu_ph_qbla.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x00870043;
> +
> +    __asm
> +        ("preceu.ph.qbla %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/preceu_ph_qbr.c 
> b/tests/tcg/mips/mips32-dsp/preceu_ph_qbr.c
> new file mode 100644
> index 0000000..03df18c
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/preceu_ph_qbr.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x00430021;
> +
> +    __asm
> +        ("preceu.ph.qbr %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/preceu_ph_qbra.c 
> b/tests/tcg/mips/mips32-dsp/preceu_ph_qbra.c
> new file mode 100644
> index 0000000..6343276
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/preceu_ph_qbra.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x87654321;
> +    result = 0x00650021;
> +
> +    __asm
> +        ("preceu.ph.qbra %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/precrq_ph_w.c 
> b/tests/tcg/mips/mips32-dsp/precrq_ph_w.c
> new file mode 100644
> index 0000000..25d45f1
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/precrq_ph_w.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x12348765;
> +
> +    __asm
> +        ("precrq.ph.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/precrq_qb_ph.c 
> b/tests/tcg/mips/mips32-dsp/precrq_qb_ph.c
> new file mode 100644
> index 0000000..fe23acc
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/precrq_qb_ph.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x12568743;
> +
> +    __asm
> +        ("precrq.qb.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/precrq_rs_ph_w.c 
> b/tests/tcg/mips/mips32-dsp/precrq_rs_ph_w.c
> new file mode 100644
> index 0000000..87214b8
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/precrq_rs_ph_w.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x12348765;
> +
> +    __asm
> +        ("precrq_rs.ph.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/precrqu_s_qb_ph.c 
> b/tests/tcg/mips/mips32-dsp/precrqu_s_qb_ph.c
> new file mode 100644
> index 0000000..9a459cc
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/precrqu_s_qb_ph.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x24AC0086;
> +
> +    __asm
> +        ("precrqu_s.qb.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/raddu_w_qb.c 
> b/tests/tcg/mips/mips32-dsp/raddu_w_qb.c
> new file mode 100644
> index 0000000..77a983c
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/raddu_w_qb.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs;
> +    int result;
> +
> +    rs = 0x12345678;
> +    result = 0x114;
> +
> +    __asm
> +        ("raddu.w.qb %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/rddsp.c 
> b/tests/tcg/mips/mips32-dsp/rddsp.c
> new file mode 100644
> index 0000000..e8948ec
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/rddsp.c
> @@ -0,0 +1,54 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int dsp_i, dsp_o;
> +    int ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i;
> +    int ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o;
> +    int ccond_r, outflag_r, efi_r, c_r, scount_r, pos_r;
> +
> +    ccond_i   = 0x000000BC;/* 4 */
> +    outflag_i = 0x0000001B;/* 3 */
> +    efi_i     = 0x00000001;/* 5 */
> +    c_i       = 0x00000001;/* 2 */
> +    scount_i  = 0x0000000F;/* 1 */
> +    pos_i     = 0x0000000C;/* 0 */
> +
> +    dsp_i = (ccond_i   << 24) | \
> +            (outflag_i << 16) | \
> +            (efi_i     << 14) | \
> +            (c_i       << 13) | \
> +            (scount_i  <<  7) | \
> +            pos_i;
> +
> +    ccond_r   = ccond_i;
> +    outflag_r = outflag_i;
> +    efi_r     = efi_i;
> +    c_r       = c_i;
> +    scount_r  = scount_i;
> +    pos_r     = pos_i;
> +
> +    __asm
> +        ("wrdsp %1, 0x3F\n\t"
> +         "rddsp %0, 0x3F\n\t"
> +         : "=r"(dsp_o)
> +         : "r"(dsp_i)
> +        );
> +
> +    ccond_o   = (dsp_o >> 24) & 0xFF;
> +    outflag_o = (dsp_o >> 16) & 0xFF;
> +    efi_o     = (dsp_o >> 14) & 0x01;
> +    c_o       = (dsp_o >> 14) & 0x01;
> +    scount_o  = (dsp_o >>  7) & 0x3F;
> +    pos_o     =  dsp_o & 0x1F;
> +
> +    assert(ccond_o   == ccond_r);
> +    assert(outflag_o == outflag_r);
> +    assert(efi_o     == efi_r);
> +    assert(c_o       == c_r);
> +    assert(scount_o  == scount_r);
> +    assert(pos_o     == pos_r);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/repl_ph.c 
> b/tests/tcg/mips/mips32-dsp/repl_ph.c
> new file mode 100644
> index 0000000..2107495
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/repl_ph.c
> @@ -0,0 +1,23 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, result;
> +
> +    result = 0x01BF01BF;
> +    __asm
> +        ("repl.ph %0, 0x1BF\n\t"
> +         : "=r"(rd)
> +        );
> +    assert(rd == result);
> +
> +    result = 0x01FF01FF;
> +    __asm
> +        ("repl.ph %0, 0x01FF\n\t"
> +         : "=r"(rd)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/repl_qb.c 
> b/tests/tcg/mips/mips32-dsp/repl_qb.c
> new file mode 100644
> index 0000000..6631393
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/repl_qb.c
> @@ -0,0 +1,16 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, result;
> +
> +    result = 0xBFBFBFBF;
> +    __asm
> +        ("repl.qb %0, 0xBF\n\t"
> +         : "=r"(rd)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/replv_ph.c 
> b/tests/tcg/mips/mips32-dsp/replv_ph.c
> new file mode 100644
> index 0000000..07fb15f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/replv_ph.c
> @@ -0,0 +1,19 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x12345678;
> +    result = 0x56785678;
> +    __asm
> +        ("replv.ph %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/replv_qb.c 
> b/tests/tcg/mips/mips32-dsp/replv_qb.c
> new file mode 100644
> index 0000000..dd1271f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/replv_qb.c
> @@ -0,0 +1,19 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt     = 0x12345678;
> +    result = 0x78787878;
> +    __asm
> +        ("replv.qb %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shilo.c 
> b/tests/tcg/mips/mips32-dsp/shilo.c
> new file mode 100644
> index 0000000..b686616
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shilo.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int ach, acl;
> +    int resulth, resultl;
> +
> +    ach = 0xBBAACCFF;
> +    acl = 0x1C3B001D;
> +
> +    resulth = 0x17755;
> +    resultl = 0x99fe3876;
> +
> +    __asm
> +        ("mthi %0, $ac1\n\t"
> +         "mtlo %1, $ac1\n\t"
> +         "shilo $ac1, 0x0F\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shilov.c 
> b/tests/tcg/mips/mips32-dsp/shilov.c
> new file mode 100644
> index 0000000..f186032
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shilov.c
> @@ -0,0 +1,29 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, ach, acl;
> +    int resulth, resultl;
> +
> +    rs  = 0x0F;
> +    ach = 0xBBAACCFF;
> +    acl = 0x1C3B001D;
> +
> +    resulth = 0x17755;
> +    resultl = 0x99fe3876;
> +
> +    __asm
> +        ("mthi %0, $ac1\n\t"
> +         "mtlo %1, $ac1\n\t"
> +         "shilov $ac1, %2\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shll_ph.c 
> b/tests/tcg/mips/mips32-dsp/shll_ph.c
> new file mode 100644
> index 0000000..b8f1ff5
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shll_ph.c
> @@ -0,0 +1,24 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt, dsp;
> +    int result, resultdsp;
> +
> +    rt        = 0x12345678;
> +    result    = 0xA000C000;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shll.ph %0, %2, 0x0B\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shll_qb.c 
> b/tests/tcg/mips/mips32-dsp/shll_qb.c
> new file mode 100644
> index 0000000..d79814c
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shll_qb.c
> @@ -0,0 +1,23 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt, dsp;
> +    int result, resultdsp;
> +
> +    rt     = 0x87654321;
> +    result = 0x38281808;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shll.qb %0, %2, 0x03\n\t"
> +         "rddsp   %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shll_s_ph.c 
> b/tests/tcg/mips/mips32-dsp/shll_s_ph.c
> new file mode 100644
> index 0000000..910fea3
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shll_s_ph.c
> @@ -0,0 +1,24 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt, dsp;
> +    int result, resultdsp;
> +
> +    rt        = 0x12345678;
> +    result    = 0x7FFF7FFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shll_s.ph %0, %2, 0x0B\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shll_s_w.c 
> b/tests/tcg/mips/mips32-dsp/shll_s_w.c
> new file mode 100644
> index 0000000..c42c168
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shll_s_w.c
> @@ -0,0 +1,24 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt, dsp;
> +    int result, resultdsp;
> +
> +    rt        = 0x12345678;
> +    result    = 0x7FFFFFFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shll_s.w %0, %2, 0x0B\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shllv_ph.c 
> b/tests/tcg/mips/mips32-dsp/shllv_ph.c
> new file mode 100644
> index 0000000..b0fcae8
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shllv_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs        = 0x0B;
> +    rt        = 0x12345678;
> +    result    = 0xA000C000;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shllv.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shllv_qb.c 
> b/tests/tcg/mips/mips32-dsp/shllv_qb.c
> new file mode 100644
> index 0000000..0bcc24c
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shllv_qb.c
> @@ -0,0 +1,24 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs     = 0x03;
> +    rt     = 0x87654321;
> +    result = 0x38281808;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shllv.qb %0, %2, %3\n\t"
> +         "rddsp   %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shllv_s_ph.c 
> b/tests/tcg/mips/mips32-dsp/shllv_s_ph.c
> new file mode 100644
> index 0000000..a6d61b1
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shllv_s_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs        = 0x0B;
> +    rt        = 0x12345678;
> +    result    = 0x7FFF7FFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shllv_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shllv_s_w.c 
> b/tests/tcg/mips/mips32-dsp/shllv_s_w.c
> new file mode 100644
> index 0000000..69c896d
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shllv_s_w.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs        = 0x0B;
> +    rt        = 0x12345678;
> +    result    = 0x7FFFFFFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shllv_s.w %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shra_ph.c 
> b/tests/tcg/mips/mips32-dsp/shra_ph.c
> new file mode 100644
> index 0000000..be7711a
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shra_ph.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt     = 0x87654321;
> +    result = 0xF0EC0864;
> +
> +    __asm
> +        ("shra.ph %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shra_r_ph.c 
> b/tests/tcg/mips/mips32-dsp/shra_r_ph.c
> new file mode 100644
> index 0000000..bb64683
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shra_r_ph.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt     = 0x87654321;
> +    result = 0xF0ED0864;
> +
> +    __asm
> +        ("shra_r.ph %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shra_r_w.c 
> b/tests/tcg/mips/mips32-dsp/shra_r_w.c
> new file mode 100644
> index 0000000..b94748c
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shra_r_w.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt     = 0x87654321;
> +    result = 0xF0ECA864;
> +
> +    __asm
> +        ("shra_r.w %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shrav_ph.c 
> b/tests/tcg/mips/mips32-dsp/shrav_ph.c
> new file mode 100644
> index 0000000..a4db736
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shrav_ph.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x03;
> +    rt     = 0x87654321;
> +    result = 0xF0EC0864;
> +
> +    __asm
> +        ("shrav.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shrav_r_ph.c 
> b/tests/tcg/mips/mips32-dsp/shrav_r_ph.c
> new file mode 100644
> index 0000000..f6d3c70
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shrav_r_ph.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x03;
> +    rt     = 0x87654321;
> +    result = 0xF0ED0864;
> +
> +    __asm
> +        ("shrav_r.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shrav_r_w.c 
> b/tests/tcg/mips/mips32-dsp/shrav_r_w.c
> new file mode 100644
> index 0000000..1841381
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shrav_r_w.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x03;
> +    rt     = 0x87654321;
> +    result = 0xF0ECA864;
> +
> +    __asm
> +        ("shrav_r.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shrl_qb.c 
> b/tests/tcg/mips/mips32-dsp/shrl_qb.c
> new file mode 100644
> index 0000000..ccc991f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shrl_qb.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt     = 0x12345678;
> +    result = 0x00010203;
> +
> +    __asm
> +        ("shrl.qb %0, %1, 0x05\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/shrlv_qb.c 
> b/tests/tcg/mips/mips32-dsp/shrlv_qb.c
> new file mode 100644
> index 0000000..4b0a826
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/shrlv_qb.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x05;
> +    rt     = 0x12345678;
> +    result = 0x00010203;
> +
> +    __asm
> +        ("shrlv.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/subq_ph.c 
> b/tests/tcg/mips/mips32-dsp/subq_ph.c
> new file mode 100644
> index 0000000..e9d349a
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/subq_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0x8ACF1357;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subq.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/subq_s_ph.c 
> b/tests/tcg/mips/mips32-dsp/subq_s_ph.c
> new file mode 100644
> index 0000000..56fed9b
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/subq_s_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0x7FFF1357;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subq_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/subq_s_w.c 
> b/tests/tcg/mips/mips32-dsp/subq_s_w.c
> new file mode 100644
> index 0000000..f44f36e
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/subq_s_w.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0x7FFFFFFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subq_s.w %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/subu_qb.c 
> b/tests/tcg/mips/mips32-dsp/subu_qb.c
> new file mode 100644
> index 0000000..4209096
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/subu_qb.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0x8BCF1357;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subu.qb %0, %2, %3\n\t"
> +         "rddsp   %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/subu_s_qb.c 
> b/tests/tcg/mips/mips32-dsp/subu_s_qb.c
> new file mode 100644
> index 0000000..3d65053
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/subu_s_qb.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0x00001357;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subu_s.qb %0, %2, %3\n\t"
> +         "rddsp   %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dsp/wrdsp.c 
> b/tests/tcg/mips/mips32-dsp/wrdsp.c
> new file mode 100644
> index 0000000..e8948ec
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dsp/wrdsp.c
> @@ -0,0 +1,54 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int dsp_i, dsp_o;
> +    int ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i;
> +    int ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o;
> +    int ccond_r, outflag_r, efi_r, c_r, scount_r, pos_r;
> +
> +    ccond_i   = 0x000000BC;/* 4 */
> +    outflag_i = 0x0000001B;/* 3 */
> +    efi_i     = 0x00000001;/* 5 */
> +    c_i       = 0x00000001;/* 2 */
> +    scount_i  = 0x0000000F;/* 1 */
> +    pos_i     = 0x0000000C;/* 0 */
> +
> +    dsp_i = (ccond_i   << 24) | \
> +            (outflag_i << 16) | \
> +            (efi_i     << 14) | \
> +            (c_i       << 13) | \
> +            (scount_i  <<  7) | \
> +            pos_i;
> +
> +    ccond_r   = ccond_i;
> +    outflag_r = outflag_i;
> +    efi_r     = efi_i;
> +    c_r       = c_i;
> +    scount_r  = scount_i;
> +    pos_r     = pos_i;
> +
> +    __asm
> +        ("wrdsp %1, 0x3F\n\t"
> +         "rddsp %0, 0x3F\n\t"
> +         : "=r"(dsp_o)
> +         : "r"(dsp_i)
> +        );
> +
> +    ccond_o   = (dsp_o >> 24) & 0xFF;
> +    outflag_o = (dsp_o >> 16) & 0xFF;
> +    efi_o     = (dsp_o >> 14) & 0x01;
> +    c_o       = (dsp_o >> 14) & 0x01;
> +    scount_o  = (dsp_o >>  7) & 0x3F;
> +    pos_o     =  dsp_o & 0x1F;
> +
> +    assert(ccond_o   == ccond_r);
> +    assert(outflag_o == outflag_r);
> +    assert(efi_o     == efi_r);
> +    assert(c_o       == c_r);
> +    assert(scount_o  == scount_r);
> +    assert(pos_o     == pos_r);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/Makefile 
> b/tests/tcg/mips/mips32-dspr2/Makefile
> new file mode 100644
> index 0000000..5a07a72
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/Makefile
> @@ -0,0 +1,72 @@
> +-include ../../config-host.mak
> +
> +CROSS=mips64el-unknown-linux-gnu-
> +
> +SIM=qemu-mipsel
> +SIM_FLAGS=-cpu 74Kf
> +
> +CC      = $(CROSS)gcc
> +CFLAGS  = -mabi=32 -march=mips32r2 -mgp32 -mdspr2 -static
> +
> +TESTCASES = absq_s_qb.tst
> +TESTCASES += addqh_ph.tst
> +TESTCASES += addqh_r_ph.tst
> +TESTCASES += addqh_r_w.tst
> +TESTCASES += addqh_w.tst
> +TESTCASES += adduh_qb.tst
> +TESTCASES += adduh_r_qb.tst
> +TESTCASES += addu_ph.tst
> +TESTCASES += addu_s_ph.tst
> +TESTCASES += append.tst
> +TESTCASES += balign.tst
> +TESTCASES += cmpgdu_eq_qb.tst
> +TESTCASES += cmpgdu_le_qb.tst
> +TESTCASES += cmpgdu_lt_qb.tst
> +TESTCASES += dpaqx_sa_w_ph.tst
> +TESTCASES += dpa_w_ph.tst
> +TESTCASES += dpax_w_ph.tst
> +TESTCASES += dpaqx_s_w_ph.tst
> +TESTCASES += dpsqx_sa_w_ph.tst
> +TESTCASES += dpsqx_s_w_ph.tst
> +TESTCASES += dps_w_ph.tst
> +TESTCASES += dpsx_w_ph.tst
> +TESTCASES += muleq_s_w_phl.tst
> +TESTCASES += mul_ph.tst
> +TESTCASES += mulq_rs_w.tst
> +TESTCASES += mulq_s_ph.tst
> +TESTCASES += mulq_s_w.tst
> +TESTCASES += mulsaq_s_w_ph.tst
> +TESTCASES += mulsa_w_ph.tst
> +TESTCASES += mul_s_ph.tst
> +TESTCASES += precr_qb_ph.tst
> +TESTCASES += precr_sra_ph_w.tst
> +TESTCASES += precr_sra_r_ph_w.tst
> +TESTCASES += prepend.tst
> +TESTCASES += shra_qb.tst
> +TESTCASES += shra_r_qb.tst
> +TESTCASES += shrav_qb.tst
> +TESTCASES += shrav_r_qb.tst
> +TESTCASES += shrl_ph.tst
> +TESTCASES += shrlv_ph.tst
> +TESTCASES += subqh_ph.tst
> +TESTCASES += subqh_r_ph.tst
> +TESTCASES += subqh_r_w.tst
> +TESTCASES += subqh_w.tst
> +TESTCASES += subuh_qb.tst
> +TESTCASES += subuh_r_qb.tst
> +TESTCASES += subu_ph.tst
> +TESTCASES += subu_s_ph.tst
> +
> +all: $(TESTCASES)
> +
> +%.tst: %.c
> +     $(CC) $(CFLAGS) $< -o $@
> +
> +check: $(TESTCASES)
> +     @for case in $(TESTCASES); do \
> +        echo $(SIM) $(SIM_FLAGS) ./$$case;\
> +             $(SIM) $(SIM_FLAGS) ./$$case; \
> +     done
> +
> +clean:
> +     $(RM) -rf $(TESTCASES)
> diff --git a/tests/tcg/mips/mips32-dspr2/absq_s_qb.c 
> b/tests/tcg/mips/mips32-dspr2/absq_s_qb.c
> new file mode 100644
> index 0000000..af4683f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/absq_s_qb.c
> @@ -0,0 +1,35 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int input, result, dsp;
> +    int hope;
> +
> +    input = 0x701BA35E;
> +    hope  = 0x701B5D5E;
> +
> +    __asm
> +        ("absq_s.qb %0, %1\n\t"
> +         : "=r"(result)
> +         : "r"(input)
> +        );
> +    assert(result == hope);
> +
> +
> +    input = 0x801BA35E;
> +    hope  = 0x7F1B5D5E;
> +
> +    __asm
> +        ("absq_s.qb %0, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(result), "=r"(dsp)
> +         : "r"(input)
> +        );
> +    dsp = dsp >> 20;
> +    dsp &= 0x01;
> +    assert(dsp == 1);
> +    assert(result == hope);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/addqh_ph.c 
> b/tests/tcg/mips/mips32-dspr2/addqh_ph.c
> new file mode 100644
> index 0000000..11f8597
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/addqh_ph.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x706A13FE;
> +    rt     = 0x13065174;
> +    result = 0x41B832B9;
> +    __asm
> +        ("addqh.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0x01000100;
> +    rt     = 0x02000100;
> +    result = 0x01800100;
> +    __asm
> +        ("addqh.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/addqh_r_ph.c 
> b/tests/tcg/mips/mips32-dspr2/addqh_r_ph.c
> new file mode 100644
> index 0000000..ab91c0f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/addqh_r_ph.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x706A13FE;
> +    rt     = 0x13065174;
> +    result = 0x41B832B9;
> +    __asm
> +        ("addqh_r.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0x01000100;
> +    rt     = 0x02000100;
> +    result = 0x01800100;
> +    __asm
> +        ("addqh_r.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/addqh_r_w.c 
> b/tests/tcg/mips/mips32-dspr2/addqh_r_w.c
> new file mode 100644
> index 0000000..75a75c5
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/addqh_r_w.c
> @@ -0,0 +1,34 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x00000010;
> +    rt     = 0x00000001;
> +    result = 0x00000009;
> +
> +    __asm
> +        ("addqh_r.w  %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    assert(rd == result);
> +
> +    rs     = 0xFFFFFFFE;
> +    rt     = 0x00000001;
> +    result = 0x00000000;
> +
> +    __asm
> +        ("addqh_r.w  %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/addqh_w.c 
> b/tests/tcg/mips/mips32-dspr2/addqh_w.c
> new file mode 100644
> index 0000000..de6926e
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/addqh_w.c
> @@ -0,0 +1,34 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x00000010;
> +    rt     = 0x00000001;
> +    result = 0x00000008;
> +
> +    __asm
> +        ("addqh.w  %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    assert(rd == result);
> +
> +    rs     = 0xFFFFFFFE;
> +    rt     = 0x00000001;
> +    result = 0xFFFFFFFF;
> +
> +    __asm
> +        ("addqh.w  %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/addu_ph.c 
> b/tests/tcg/mips/mips32-dspr2/addu_ph.c
> new file mode 100644
> index 0000000..01efb3d
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/addu_ph.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010001;
> +    result = 0x01000100;
> +    __asm
> +        ("addu.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0xFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0x00011112;
> +    __asm
> +        ("addu.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/addu_s_ph.c 
> b/tests/tcg/mips/mips32-dspr2/addu_s_ph.c
> new file mode 100644
> index 0000000..51cc2ac
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/addu_s_ph.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x00FE00FE;
> +    rt     = 0x00020001;
> +    result = 0x010000FF;
> +    __asm
> +        ("addu_s.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0xFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0xFFFF1112;
> +    __asm
> +        ("addu_s.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/adduh_qb.c 
> b/tests/tcg/mips/mips32-dspr2/adduh_qb.c
> new file mode 100644
> index 0000000..a1f5d63
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/adduh_qb.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0xFF0055AA;
> +    rt     = 0x0113421B;
> +    result = 0x80094B62;
> +    __asm
> +        ("adduh.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0x7F800888;
> +    __asm
> +        ("adduh.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/adduh_r_qb.c 
> b/tests/tcg/mips/mips32-dspr2/adduh_r_qb.c
> new file mode 100644
> index 0000000..81e98c1
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/adduh_r_qb.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0xFF0055AA;
> +    rt     = 0x01112211;
> +    result = 0x80093C5E;
> +    __asm
> +        ("adduh_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0x80800888;
> +    __asm
> +        ("adduh_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/append.c 
> b/tests/tcg/mips/mips32-dspr2/append.c
> new file mode 100644
> index 0000000..9a91e16
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/append.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int result;
> +
> +    rs     = 0xFF0055AA;
> +    rt     = 0x0113421B;
> +    result = 0x02268436;
> +    __asm
> +        ("append %0, %1, 0x01\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(rt == result);
> +
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0x0010111F;
> +    __asm
> +        ("append %0, %1, 0x04\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(rt == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/balign.c 
> b/tests/tcg/mips/mips32-dspr2/balign.c
> new file mode 100644
> index 0000000..537cf04
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/balign.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int result;
> +
> +    rs     = 0xFF0055AA;
> +    rt     = 0x0113421B;
> +    result = 0x13421BFF;
> +    __asm
> +        ("balign %0, %1, 0x01\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(rt == result);
> +
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0x11FFFF0F;
> +    __asm
> +        ("balign %0, %1, 0x03\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(rt == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/cmpgdu_eq_qb.c 
> b/tests/tcg/mips/mips32-dspr2/cmpgdu_eq_qb.c
> new file mode 100644
> index 0000000..fccd975
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/cmpgdu_eq_qb.c
> @@ -0,0 +1,37 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int dsp;
> +    int result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x02;
> +    __asm
> +        ("cmpgdu.eq.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(rd  == result);
> +    assert(dsp == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x0F;
> +    __asm
> +        ("cmpgdu.eq.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(rd  == result);
> +    assert(dsp == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/cmpgdu_le_qb.c 
> b/tests/tcg/mips/mips32-dspr2/cmpgdu_le_qb.c
> new file mode 100644
> index 0000000..a0ecdca
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/cmpgdu_le_qb.c
> @@ -0,0 +1,37 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int dsp;
> +    int result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x0F;
> +    __asm
> +        ("cmpgdu.le.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(rd  == result);
> +    assert(dsp == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11707066;
> +    result = 0x0B;
> +    __asm
> +        ("cmpgdu.le.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(rd  == result);
> +    assert(dsp == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/cmpgdu_lt_qb.c 
> b/tests/tcg/mips/mips32-dspr2/cmpgdu_lt_qb.c
> new file mode 100644
> index 0000000..dba99e3
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/cmpgdu_lt_qb.c
> @@ -0,0 +1,37 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int dsp;
> +    int result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x0D;
> +    __asm
> +        ("cmpgdu.lt.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(rd  == result);
> +    assert(dsp == result);
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x00;
> +    __asm
> +        ("cmpgdu.lt.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    assert(rd  == result);
> +    assert(dsp == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/dpa_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/dpa_w_ph.c
> new file mode 100644
> index 0000000..d2bf3be
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/dpa_w_ph.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x05;
> +    resultl = 0x0302;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpa.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/dpaqx_s_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/dpaqx_s_w_ph.c
> new file mode 100644
> index 0000000..841808d
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/dpaqx_s_w_ph.c
> @@ -0,0 +1,57 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, dsp;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl, resultdsp;
> +
> +    rs     = 0x800000FF;
> +    rt     = 0x00018000;
> +    resulth = 0x05;
> +    resultl = 0x80000202;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpaqx_s.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    ach    = 5;
> +    acl    = 5;
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x05;
> +    resultl = 0x05FF;
> +    /***********************************************************
> +     * Because of we set outflag at last time, although this
> +     * time we set nothing, but it is stay the last time value.
> +     **********************************************************/
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpaqx_s.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/dpaqx_sa_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/dpaqx_sa_w_ph.c
> new file mode 100644
> index 0000000..65d3993
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/dpaqx_sa_w_ph.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, dsp;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl, resultdsp;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x00;
> +    resultl = 0x7FFFFFFF;
> +    resultdsp = 0x01;
> +    __asm
> +        ("wrdsp %2\n\t"
> +         "mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpaqx_sa.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "+r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(dsp >> (16 + 1) == resultdsp);
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/dpax_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/dpax_w_ph.c
> new file mode 100644
> index 0000000..f756997
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/dpax_w_ph.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x05;
> +    resultl = 0x0302;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpax.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/dps_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/dps_w_ph.c
> new file mode 100644
> index 0000000..8303643
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/dps_w_ph.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFD08;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dps.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/dpsqx_s_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/dpsqx_s_w_ph.c
> new file mode 100644
> index 0000000..0f26071
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/dpsqx_s_w_ph.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, dsp;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl, resultdsp;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xAEA3E09B;
> +    resultdsp = 0x00;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsqx_s.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/dpsqx_sa_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/dpsqx_sa_w_ph.c
> new file mode 100644
> index 0000000..4688caf
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/dpsqx_sa_w_ph.c
> @@ -0,0 +1,31 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, dsp;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl, resultdsp;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x00;
> +    resultl = 0x7FFFFFFF;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsqx_sa.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/dpsx_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/dpsx_w_ph.c
> new file mode 100644
> index 0000000..6db59a4
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/dpsx_w_ph.c
> @@ -0,0 +1,27 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int ach = 5, acl = 5;
> +    int resulth, resultl;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xD751F050;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsx.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/mul_ph.c 
> b/tests/tcg/mips/mips32-dspr2/mul_ph.c
> new file mode 100644
> index 0000000..fc91f5d
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/mul_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x03FB1234;
> +    rt = 0x0BCC4321;
> +    result = 0xF504F4B4;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mul.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/mul_s_ph.c 
> b/tests/tcg/mips/mips32-dspr2/mul_s_ph.c
> new file mode 100644
> index 0000000..949ea5e
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/mul_s_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x03FB1234;
> +    rt = 0x0BCC4321;
> +    result = 0x7fff7FFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mul_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/muleq_s_w_phl.c 
> b/tests/tcg/mips/mips32-dspr2/muleq_s_w_phl.c
> new file mode 100644
> index 0000000..4e3262f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/muleq_s_w_phl.c
> @@ -0,0 +1,40 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    rs = 0x12340000;
> +    rt = 0x43210000;
> +    result = 0x98be968;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/mulq_rs_w.c 
> b/tests/tcg/mips/mips32-dspr2/mulq_rs_w.c
> new file mode 100644
> index 0000000..669405f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/mulq_rs_w.c
> @@ -0,0 +1,36 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0x80005555;
> +
> +    __asm
> +        ("mulq_rs.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd  == result);
> +
> +    rs = 0x80000000;
> +    rt = 0x80000000;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mulq_rs.w %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/mulq_s_ph.c 
> b/tests/tcg/mips/mips32-dspr2/mulq_s_ph.c
> new file mode 100644
> index 0000000..d0f7674
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/mulq_s_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0x7FFF098B;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mulq_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/mulq_s_w.c 
> b/tests/tcg/mips/mips32-dspr2/mulq_s_w.c
> new file mode 100644
> index 0000000..df148b7
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/mulq_s_w.c
> @@ -0,0 +1,36 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0x80005555;
> +
> +    __asm
> +        ("mulq_s.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd  == result);
> +
> +    rs = 0x80000000;
> +    rt = 0x80000000;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mulq_s.w %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    assert(rd  == result);
> +    assert(dsp == resultdsp);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/mulsa_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/mulsa_w_ph.c
> new file mode 100644
> index 0000000..a694093
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/mulsa_w_ph.c
> @@ -0,0 +1,29 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, ach, acl;
> +    int resulth, resultl;
> +
> +    ach = 0x05;
> +    acl = 0x00BBDDCC;
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    resulth = 0x05;
> +    resultl = 0x3BF5E918;
> +
> +    __asm
> +        ("mthi %0, $ac1\n\t"
> +         "mtlo %1, $ac1\n\t"
> +         "mulsa.w.ph $ac1, %2, %3\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/mulsaq_s_w_ph.c 
> b/tests/tcg/mips/mips32-dspr2/mulsaq_s_w_ph.c
> new file mode 100644
> index 0000000..06c91a4
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/mulsaq_s_w_ph.c
> @@ -0,0 +1,29 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt, ach, acl;
> +    int resulth, resultl;
> +
> +    ach = 0x05;
> +    acl = 0x00BBDDCC;
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    resulth = 0x05;
> +    resultl = 0x772ff463;
> +
> +    __asm
> +        ("mthi %0, $ac1\n\t"
> +         "mtlo %1, $ac1\n\t"
> +         "mulsaq_s.w.ph $ac1, %2, %3\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(ach == resulth);
> +    assert(acl == resultl);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/precr_qb_ph.c 
> b/tests/tcg/mips/mips32-dspr2/precr_qb_ph.c
> new file mode 100644
> index 0000000..3a2b3fd
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/precr_qb_ph.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x34786521;
> +
> +    __asm
> +        ("precr.qb.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(result == rd);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c 
> b/tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c
> new file mode 100644
> index 0000000..5c9baab
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/precr_sra_ph_w.c
> @@ -0,0 +1,32 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x43215678;
> +
> +    __asm
> +        ("precr_sra.ph.w %0, %1, 0x00\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(result == rt);
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xFFFF0000;
> +
> +    __asm
> +        ("precr_sra.ph.w %0, %1, 0x1F\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/precr_sra_r_ph_w.c 
> b/tests/tcg/mips/mips32-dspr2/precr_sra_r_ph_w.c
> new file mode 100644
> index 0000000..6474a10
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/precr_sra_r_ph_w.c
> @@ -0,0 +1,32 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x43215678;
> +
> +    __asm
> +        ("precr_sra_r.ph.w %0, %1, 0x00\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(result == rt);
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xFFFF0000;
> +
> +    __asm
> +        ("precr_sra_r.ph.w %0, %1, 0x1F\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(result == rt);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/prepend.c 
> b/tests/tcg/mips/mips32-dspr2/prepend.c
> new file mode 100644
> index 0000000..f6bcd47
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/prepend.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x87654321;
> +    __asm
> +        ("prepend %0, %1, 0x00\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(rt == result);
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xACF10ECA;
> +    __asm
> +        ("prepend %0, %1, 0x0F\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    assert(rt == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/shra_qb.c 
> b/tests/tcg/mips/mips32-dspr2/shra_qb.c
> new file mode 100644
> index 0000000..48193de
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/shra_qb.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x12345678;
> +    result = 0x02060A0F;
> +
> +    __asm
> +        ("shra.qb %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rt = 0x87654321;
> +    result = 0xF00C0804;
> +
> +    __asm
> +        ("shra.qb %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/shra_r_qb.c 
> b/tests/tcg/mips/mips32-dspr2/shra_r_qb.c
> new file mode 100644
> index 0000000..29afa0e
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/shra_r_qb.c
> @@ -0,0 +1,30 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x12345678;
> +    result = 0x02070B0F;
> +
> +    __asm
> +        ("shra_r.qb %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    rt = 0x87654321;
> +    result = 0xF10D0804;
> +
> +    __asm
> +        ("shra_r.qb %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/shrav_qb.c 
> b/tests/tcg/mips/mips32-dspr2/shrav_qb.c
> new file mode 100644
> index 0000000..b21e1b7
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/shrav_qb.c
> @@ -0,0 +1,32 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x03;
> +    rt = 0x12345678;
> +    result = 0x02060A0F;
> +
> +    __asm
> +        ("shrav.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    rs = 0x03;
> +    rt = 0x87654321;
> +    result = 0xF00C0804;
> +
> +    __asm
> +        ("shrav.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/shrav_r_qb.c 
> b/tests/tcg/mips/mips32-dspr2/shrav_r_qb.c
> new file mode 100644
> index 0000000..9ea8aa0
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/shrav_r_qb.c
> @@ -0,0 +1,32 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x03;
> +    rt = 0x12345678;
> +    result = 0x02070B0F;
> +
> +    __asm
> +        ("shrav_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    rs = 0x03;
> +    rt = 0x87654321;
> +    result = 0xF10D0804;
> +
> +    __asm
> +        ("shrav_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/shrl_ph.c 
> b/tests/tcg/mips/mips32-dspr2/shrl_ph.c
> new file mode 100644
> index 0000000..724b9a7
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/shrl_ph.c
> @@ -0,0 +1,20 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt     = 0x12345678;
> +    result = 0x009102B3;
> +
> +    __asm
> +        ("shrl.ph %0, %1, 0x05\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/shrlv_ph.c 
> b/tests/tcg/mips/mips32-dspr2/shrlv_ph.c
> new file mode 100644
> index 0000000..ac79aa6
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/shrlv_ph.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs     = 0x05;
> +    rt     = 0x12345678;
> +    result = 0x009102B3;
> +
> +    __asm
> +        ("shrlv.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/subqh_ph.c 
> b/tests/tcg/mips/mips32-dspr2/subqh_ph.c
> new file mode 100644
> index 0000000..dbc0967
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/subqh_ph.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x456709AB;
> +
> +    __asm
> +        ("subqh.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/subqh_r_ph.c 
> b/tests/tcg/mips/mips32-dspr2/subqh_r_ph.c
> new file mode 100644
> index 0000000..24ef0f1
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/subqh_r_ph.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x456809AC;
> +
> +    __asm
> +        ("subqh_r.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/subqh_r_w.c 
> b/tests/tcg/mips/mips32-dspr2/subqh_r_w.c
> new file mode 100644
> index 0000000..d460f86
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/subqh_r_w.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x456789AC;
> +
> +    __asm
> +        ("subqh_r.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/subqh_w.c 
> b/tests/tcg/mips/mips32-dspr2/subqh_w.c
> new file mode 100644
> index 0000000..42be3de
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/subqh_w.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x456789AB;
> +
> +    __asm
> +        ("subqh.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/subu_ph.c 
> b/tests/tcg/mips/mips32-dspr2/subu_ph.c
> new file mode 100644
> index 0000000..244ecea
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/subu_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x87654321;
> +    rt = 0x12345678;
> +    result    = 0x7531ECA9;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subu.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/subu_s_ph.c 
> b/tests/tcg/mips/mips32-dspr2/subu_s_ph.c
> new file mode 100644
> index 0000000..8e4da4f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/subu_s_ph.c
> @@ -0,0 +1,25 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt, dsp;
> +    int result, resultdsp;
> +
> +    rs = 0x87654321;
> +    rt = 0x12345678;
> +    result    = 0x75310000;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subu_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    assert(dsp == resultdsp);
> +    assert(rd  == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/subuh_qb.c 
> b/tests/tcg/mips/mips32-dspr2/subuh_qb.c
> new file mode 100644
> index 0000000..92cfc76
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/subuh_qb.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xC5E7092B;
> +
> +    __asm
> +        ("subuh.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips32-dspr2/subuh_r_qb.c 
> b/tests/tcg/mips/mips32-dspr2/subuh_r_qb.c
> new file mode 100644
> index 0000000..d9e6f2f
> --- /dev/null
> +++ b/tests/tcg/mips/mips32-dspr2/subuh_r_qb.c
> @@ -0,0 +1,21 @@
> +#include<stdio.h>
> +#include<assert.h>
> +
> +int main()
> +{
> +    int rd, rs, rt;
> +    int result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xC6E80A2C;
> +
> +    __asm
> +        ("subuh_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    assert(rd == result);
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/Makefile 
> b/tests/tcg/mips/mips64-dsp/Makefile
> new file mode 100644
> index 0000000..b6e358d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/Makefile
> @@ -0,0 +1,305 @@
> +
> +CROSS_COMPILE        ?= mips64el-unknown-linux-gnu-
> +
> +SIM = qemu-system-mips64el
> +SIMFLAGS = -nographic -cpu mips64dspr2 -kernel
> +
> +AS      = $(CROSS_COMPILE)as
> +LD      = $(CROSS_COMPILE)ld
> +CC      = $(CROSS_COMPILE)gcc
> +AR      = $(CROSS_COMPILE)ar
> +NM      = $(CROSS_COMPILE)nm
> +STRIP       = $(CROSS_COMPILE)strip
> +RANLIB      = $(CROSS_COMPILE)ranlib
> +OBJCOPY     = $(CROSS_COMPILE)objcopy
> +OBJDUMP     = $(CROSS_COMPILE)objdump
> +
> +VECTORS_OBJ ?= ./head.o ./printf.o
> +
> +HEAD_FLAGS ?= -nostdinc -mabi=64 -G 0 -mno-abicalls -fno-pic -pipe \
> +              -msoft-float -march=mips64 -Wa,-mips64 -Wa,--trap \
> +              -msym32 -DKBUILD_64BIT_SYM32 -I./
> +
> +CFLAGS ?= -nostdinc -mabi=64 -G 0 -mno-abicalls -fno-pic -fno-builtin  \
> +          -pipe -march=mips64r2 -mgp64 -mdsp -static -Wa,--trap -msym32 \
> +          -DKBUILD_64BIT_SYM32 -I./
> +
> +LDFLAGS = -T./mips_boot.lds -L./
> +FLAGS = -nostdlib -mabi=64 -march=mips64r2 -mgp64 -mdsp
> +
> +
> +#TESTCASES = absq_s_ob.tst
> +TESTCASES = absq_s_ph.tst
> +TESTCASES += absq_s_pw.tst
> +TESTCASES += absq_s_qh.tst
> +TESTCASES += absq_s_w.tst
> +TESTCASES += addq_ph.tst
> +TESTCASES += addq_pw.tst
> +TESTCASES += addq_qh.tst
> +TESTCASES += addq_s_ph.tst
> +TESTCASES += addq_s_pw.tst
> +TESTCASES += addq_s_qh.tst
> +TESTCASES += addsc.tst
> +TESTCASES += addu_ob.tst
> +TESTCASES += addu_qb.tst
> +TESTCASES += addu_s_ob.tst
> +TESTCASES += addu_s_qb.tst
> +TESTCASES += addwc.tst
> +TESTCASES += bitrev.tst
> +TESTCASES += bposge32.tst
> +TESTCASES += bposge64.tst
> +TESTCASES += cmp_eq_ph.tst
> +TESTCASES += cmp_eq_pw.tst
> +TESTCASES += cmp_eq_qh.tst
> +TESTCASES += cmpgu_eq_ob.tst
> +TESTCASES += cmpgu_eq_qb.tst
> +TESTCASES += cmpgu_le_ob.tst
> +TESTCASES += cmpgu_le_qb.tst
> +TESTCASES += cmpgu_lt_ob.tst
> +TESTCASES += cmpgu_lt_qb.tst
> +TESTCASES += cmp_le_ph.tst
> +TESTCASES += cmp_le_pw.tst
> +TESTCASES += cmp_le_qh.tst
> +TESTCASES += cmp_lt_ph.tst
> +TESTCASES += cmp_lt_pw.tst
> +TESTCASES += cmp_lt_qh.tst
> +TESTCASES += cmpu_eq_ob.tst
> +TESTCASES += cmpu_eq_qb.tst
> +TESTCASES += cmpu_le_ob.tst
> +TESTCASES += cmpu_le_qb.tst
> +TESTCASES += cmpu_lt_ob.tst
> +TESTCASES += cmpu_lt_qb.tst
> +#TESTCASES += dappend.tst
> +TESTCASES += dextp.tst
> +TESTCASES += dextpdp.tst
> +TESTCASES += dextpdpv.tst
> +TESTCASES += dextpv.tst
> +TESTCASES += dextr_l.tst
> +TESTCASES += dextr_r_l.tst
> +TESTCASES += dextr_rs_l.tst
> +TESTCASES += dextr_rs_w.tst
> +TESTCASES += dextr_r_w.tst
> +TESTCASES += dextr_s_h.tst
> +TESTCASES += dextrv_l.tst
> +TESTCASES += dextrv_r_l.tst
> +TESTCASES += dextrv_rs_l.tst
> +TESTCASES += dextrv_rs_w.tst
> +TESTCASES += dextrv_r_w.tst
> +TESTCASES += dextrv_s_h.tst
> +TESTCASES += dextrv_w.tst
> +TESTCASES += dextr_w.tst
> +TESTCASES += dinsv.tst
> +TESTCASES += dmadd.tst
> +TESTCASES += dmaddu.tst
> +TESTCASES += dmsub.tst
> +TESTCASES += dmsubu.tst
> +TESTCASES += dmthlip.tst
> +TESTCASES += dpaq_sa_l_pw.tst
> +TESTCASES += dpaq_sa_l_w.tst
> +TESTCASES += dpaq_s_w_ph.tst
> +TESTCASES += dpaq_s_w_qh.tst
> +TESTCASES += dpau_h_obl.tst
> +TESTCASES += dpau_h_obr.tst
> +TESTCASES += dpau_h_qbl.tst
> +TESTCASES += dpau_h_qbr.tst
> +TESTCASES += dpsq_sa_l_pw.tst
> +TESTCASES += dpsq_sa_l_w.tst
> +TESTCASES += dpsq_s_w_ph.tst
> +TESTCASES += dpsq_s_w_qh.tst
> +TESTCASES += dpsu_h_obl.tst
> +TESTCASES += dpsu_h_obr.tst
> +TESTCASES += dpsu_h_qbl.tst
> +TESTCASES += dpsu_h_qbr.tst
> +TESTCASES += dshilo.tst
> +TESTCASES += dshilov.tst
> +TESTCASES += extp.tst
> +TESTCASES += extpdp.tst
> +TESTCASES += extpdpv.tst
> +TESTCASES += extpv.tst
> +TESTCASES += extr_rs_w.tst
> +TESTCASES += extr_r_w.tst
> +TESTCASES += extr_s_h.tst
> +TESTCASES += extrv_rs_w.tst
> +TESTCASES += extrv_r_w.tst
> +TESTCASES += extrv_s_h.tst
> +TESTCASES += extrv_w.tst
> +TESTCASES += extr_w.tst
> +TESTCASES += insv.tst
> +TESTCASES += lbux.tst
> +TESTCASES += lhx.tst
> +TESTCASES += lwx.tst
> +TESTCASES += ldx.tst
> +TESTCASES += madd.tst
> +TESTCASES += maddu.tst
> +TESTCASES += maq_sa_w_phl.tst
> +TESTCASES += maq_sa_w_phr.tst
> +TESTCASES += maq_sa_w_qhll.tst
> +TESTCASES += maq_sa_w_qhlr.tst
> +TESTCASES += maq_sa_w_qhrl.tst
> +TESTCASES += maq_sa_w_qhrr.tst
> +TESTCASES += maq_s_l_pwl.tst
> +TESTCASES += maq_s_l_pwr.tst
> +TESTCASES += maq_s_w_phl.tst
> +TESTCASES += maq_s_w_phr.tst
> +TESTCASES += maq_s_w_qhll.tst
> +TESTCASES += maq_s_w_qhlr.tst
> +TESTCASES += maq_s_w_qhrl.tst
> +TESTCASES += maq_s_w_qhrr.tst
> +TESTCASES += mfhi.tst
> +TESTCASES += mflo.tst
> +TESTCASES += modsub.tst
> +TESTCASES += msub.tst
> +TESTCASES += msubu.tst
> +TESTCASES += mthi.tst
> +TESTCASES += mthlip.tst
> +TESTCASES += mtlo.tst
> +TESTCASES += muleq_s_pw_qhl.tst
> +TESTCASES += muleq_s_pw_qhr.tst
> +TESTCASES += muleq_s_w_phl.tst
> +TESTCASES += muleq_s_w_phr.tst
> +TESTCASES += muleu_s_ph_qbl.tst
> +TESTCASES += muleu_s_ph_qbr.tst
> +TESTCASES += muleu_s_qh_obl.tst
> +TESTCASES += muleu_s_qh_obr.tst
> +TESTCASES += mulq_rs_ph.tst
> +TESTCASES += mulq_rs_qh.tst
> +TESTCASES += mulsaq_s_l_pw.tst
> +TESTCASES += mulsaq_s_w_qh.tst
> +TESTCASES += mult.tst
> +TESTCASES += multu.tst
> +TESTCASES += packrl_ph.tst
> +TESTCASES += packrl_pw.tst
> +TESTCASES += pick_ob.tst
> +TESTCASES += pick_ph.tst
> +TESTCASES += pick_pw.tst
> +TESTCASES += pick_qb.tst
> +TESTCASES += pick_qh.tst
> +#TESTCASES += preceq_l_pwl.tst
> +#TESTCASES += preceq_l_pwr.tst
> +TESTCASES += preceq_pw_qhla.tst
> +TESTCASES += preceq_pw_qhl.tst
> +TESTCASES += preceq_pw_qhra.tst
> +TESTCASES += preceq_pw_qhr.tst
> +TESTCASES += precequ_ph_qbla.tst
> +TESTCASES += precequ_ph_qbl.tst
> +TESTCASES += precequ_ph_qbra.tst
> +TESTCASES += precequ_ph_qbr.tst
> +#TESTCASES += precequ_qh_obla.tst
> +#TESTCASES += precequ_qh_obl.tst
> +#TESTCASES += precequ_qh_obra.tst
> +#TESTCASES += precequ_qh_obr.tst
> +TESTCASES += preceq_w_phl.tst
> +TESTCASES += preceq_w_phr.tst
> +TESTCASES += preceu_ph_qbla.tst
> +TESTCASES += preceu_ph_qbl.tst
> +TESTCASES += preceu_ph_qbra.tst
> +TESTCASES += preceu_ph_qbr.tst
> +TESTCASES += preceu_qh_obla.tst
> +TESTCASES += preceu_qh_obl.tst
> +TESTCASES += preceu_qh_obra.tst
> +TESTCASES += preceu_qh_obr.tst
> +#TESTCASES += precr_ob_qh.tst
> +TESTCASES += precrq_ob_qh.tst
> +TESTCASES += precrq_ph_w.tst
> +TESTCASES += precrq_pw_l.tst
> +TESTCASES += precrq_qb_ph.tst
> +TESTCASES += precrq_qh_pw.tst
> +TESTCASES += precrq_rs_ph_w.tst
> +TESTCASES += precrq_rs_qh_pw.tst
> +TESTCASES += precrqu_s_ob_qh.tst
> +TESTCASES += precrqu_s_qb_ph.tst
> +#TESTCASES += precr_sra_qh_pw.tst
> +#TESTCASES += precr_sra_r_qh_pw.tst
> +#TESTCASES += prependd.tst
> +#TESTCASES += prependw.tst
> +#TESTCASES += raddu_l_ob.tst
> +TESTCASES += raddu_w_qb.tst
> +TESTCASES += rddsp.tst
> +TESTCASES += repl_ob.tst
> +TESTCASES += repl_ph.tst
> +TESTCASES += repl_pw.tst
> +TESTCASES += repl_qb.tst
> +TESTCASES += repl_qh.tst
> +TESTCASES += replv_ob.tst
> +TESTCASES += replv_ph.tst
> +TESTCASES += replv_pw.tst
> +TESTCASES += replv_qb.tst
> +TESTCASES += shilo.tst
> +TESTCASES += shilov.tst
> +TESTCASES += shll_ob.tst
> +TESTCASES += shll_ph.tst
> +TESTCASES += shll_pw.tst
> +TESTCASES += shll_qb.tst
> +TESTCASES += shll_qh.tst
> +TESTCASES += shll_s_ph.tst
> +TESTCASES += shll_s_pw.tst
> +TESTCASES += shll_s_qh.tst
> +TESTCASES += shll_s_w.tst
> +TESTCASES += shllv_ob.tst
> +TESTCASES += shllv_ph.tst
> +TESTCASES += shllv_pw.tst
> +TESTCASES += shllv_qb.tst
> +TESTCASES += shllv_qh.tst
> +TESTCASES += shllv_s_ph.tst
> +TESTCASES += shllv_s_pw.tst
> +TESTCASES += shllv_s_qh.tst
> +TESTCASES += shllv_s_w.tst
> +#TESTCASES += shra_ob.tst
> +TESTCASES += shra_ph.tst
> +TESTCASES += shra_pw.tst
> +TESTCASES += shra_qh.tst
> +#TESTCASES += shra_r_ob.tst
> +TESTCASES += shra_r_ph.tst
> +TESTCASES += shra_r_pw.tst
> +TESTCASES += shra_r_qh.tst
> +TESTCASES += shra_r_w.tst
> +TESTCASES += shrav_ph.tst
> +TESTCASES += shrav_pw.tst
> +TESTCASES += shrav_qh.tst
> +TESTCASES += shrav_r_ph.tst
> +TESTCASES += shrav_r_pw.tst
> +TESTCASES += shrav_r_qh.tst
> +TESTCASES += shrav_r_w.tst
> +TESTCASES += shrl_ob.tst
> +TESTCASES += shrl_qb.tst
> +#TESTCASES += shrl_qh.tst
> +TESTCASES += shrlv_ob.tst
> +TESTCASES += shrlv_qb.tst
> +#TESTCASES += shrlv_qh.tst
> +TESTCASES += subq_ph.tst
> +TESTCASES += subq_pw.tst
> +TESTCASES += subq_qh.tst
> +TESTCASES += subq_s_ph.tst
> +TESTCASES += subq_s_pw.tst
> +TESTCASES += subq_s_qh.tst
> +TESTCASES += subq_s_w.tst
> +TESTCASES += subu_ob.tst
> +TESTCASES += subu_qb.tst
> +TESTCASES += subu_s_ob.tst
> +TESTCASES += subu_s_qb.tst
> +TESTCASES += wrdsp.tst
> +
> +all: build
> +
> +head.o : head.S
> +     $(Q)$(CC) $(HEAD_FLAGS) -D"STACK_TOP=0xffffffff80200000" -c $< -o $@
> +
> +%.o  : %.S
> +     $(CC) $(CFLAGS) -c $< -o $@
> +
> +%.o  : %.c
> +     $(CC) $(CFLAGS) -c $< -o $@
> +
> +%.tst: %.o $(VECTORS_OBJ)
> +     $(CC) $(VECTORS_OBJ) $(FLAGS) $(LDFLAGS) $< -o $@
> +
> +build: $(VECTORS_OBJ) $(MIPSSOC_LIB) $(TESTCASES)
> +
> +check:  $(VECTORS_OBJ) $(MIPSSOC_LIB) $(TESTCASES)
> +     @for case in $(TESTCASES); do \
> +             echo $(SIM) $(SIMFLAGS) ./$$case; \
> +             $(SIM) $(SIMFLAGS) ./$$case & (sleep 1; killall $(SIM)); \
> +     done
> +
> +clean:
> +     $(Q)rm -f *.o *.tst *.a
> diff --git a/tests/tcg/mips/mips64-dsp/absq_s_ob.c 
> b/tests/tcg/mips/mips64-dsp/absq_s_ob.c
> new file mode 100644
> index 0000000..6214031
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/absq_s_ob.c
> @@ -0,0 +1,63 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result, dspcontrol;
> +    rt = 0x7F7F7F7F7F7F7F7F;
> +    result = 0x7F7F7F7F7F7F7F7F;
> +
> +
> +    __asm
> +        (".set mips64\n\t"
> +         "absq_s.ob %0 %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("absq_s.ob test 1 error\n");
> +
> +        return -1;
> +    }
> +
> +    __asm
> +        ("rddsp %0\n\t"
> +         : "=r"(rd)
> +        );
> +    rd >> 20;
> +    rd = rd & 0x1;
> +    if (rd != 0) {
> +        printf("absq_s.ob test 1 dspcontrol overflow flag error\n");
> +
> +        return -1;
> +    }
> +
> +    rt = 0x80FFFFFFFFFFFFFF;
> +    result = 0x7F01010101010101;
> +
> +    __asm
> +        ("absq_s.ob %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("absq_s.ob test 2 error\n");
> +
> +        return -1;
> +    }
> +
> +    __asm
> +        ("rddsp %0\n\t"
> +         : "=r"(rd)
> +        );
> +    rd = rd >> 20;
> +    rd = rd & 0x1;
> +    if (rd != 1) {
> +        printf("absq_s.ob test 2 dspcontrol overflow flag error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/absq_s_ph.c 
> b/tests/tcg/mips/mips64-dsp/absq_s_ph.c
> new file mode 100644
> index 0000000..238416d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/absq_s_ph.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt     = 0x10017EFD;
> +    result = 0x10017EFD;
> +
> +    __asm
> +        ("absq_s.ph %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("absq_s.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rt     = 0x8000A536;
> +    result = 0x7FFF5ACA;
> +
> +    __asm
> +        ("absq_s.ph %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("absq_s.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/absq_s_pw.c 
> b/tests/tcg/mips/mips64-dsp/absq_s_pw.c
> new file mode 100644
> index 0000000..48fc763
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/absq_s_pw.c
> @@ -0,0 +1,66 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result, dspcontrol;
> +    rd = 0;
> +    rt = 0x7F7F7F7F7F7F7F7F;
> +    result = 0x7F7F7F7F7F7F7F7F;
> +
> +
> +    __asm
> +        ("absq_s.pw %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("absq_s.pw test 1 error\n");
> +
> +        return -1;
> +    }
> +
> +    rd = 0;
> +    __asm
> +        ("rddsp %0\n\t"
> +         : "=r"(rd)
> +        );
> +    rd >> 20;
> +    rd = rd & 0x1;
> +    if (rd != 0) {
> +        printf("absq_s.pw test 1 dspcontrol overflow flag error\n");
> +
> +        return -1;
> +    }
> +
> +    rd = 0;
> +    rt = 0x80000000FFFFFFFF;
> +    result = 0x7FFFFFFF00000001;
> +
> +    __asm
> +        ("absq_s.pw %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("absq_s.pw test 2 error\n");
> +
> +        return -1;
> +    }
> +
> +    rd = 0;
> +    __asm
> +        ("rddsp %0\n\t"
> +         : "=r"(rd)
> +        );
> +    rd = rd >> 20;
> +    rd = rd & 0x1;
> +    if (rd != 1) {
> +        printf("absq_s.pw test 2 dspcontrol overflow flag error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/absq_s_qh.c 
> b/tests/tcg/mips/mips64-dsp/absq_s_qh.c
> new file mode 100644
> index 0000000..9001a9e
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/absq_s_qh.c
> @@ -0,0 +1,40 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result, dspcontrol;
> +    rd = 0;
> +    rt = 0x7F7F7F7F7F7F7F7F;
> +    result = 0x7F7F7F7F7F7F7F7F;
> +
> +
> +    __asm
> +        ("absq_s.qh %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("absq_s.qh test 1 error\n");
> +
> +        return -1;
> +    }
> +
> +    rd = 0;
> +    rt = 0x8000FFFFFFFFFFFF;
> +    result = 0x7FFF000100000001;
> +
> +    __asm
> +        ("absq_s.pw %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("absq_s.rw test 2 error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/absq_s_w.c 
> b/tests/tcg/mips/mips64-dsp/absq_s_w.c
> new file mode 100644
> index 0000000..414c8bd
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/absq_s_w.c
> @@ -0,0 +1,48 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt     = 0x80000000;
> +    result = 0x7FFFFFFF;
> +    __asm
> +        ("absq_s.w %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("absq_s_w.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rt     = 0x80030000;
> +    result = 0x7FFD0000;
> +    __asm
> +        ("absq_s.w %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("absq_s_w.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rt     = 0x31036080;
> +    result = 0x31036080;
> +    __asm
> +        ("absq_s.w %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("absq_s_w.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addq_ph.c 
> b/tests/tcg/mips/mips64-dsp/addq_ph.c
> new file mode 100644
> index 0000000..212d3d9
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addq_ph.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0xFFFFFFFF;
> +    rt     = 0x10101010;
> +    result = 0x100F100F;
> +    __asm
> +        ("addq.ph   %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addq.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x3712847D;
> +    rt     = 0x0031AF2D;
> +    result = 0x374333AA;
> +    __asm
> +        ("addq.ph   %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addq.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addq_pw.c 
> b/tests/tcg/mips/mips64-dsp/addq_pw.c
> new file mode 100644
> index 0000000..e170256
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addq_pw.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rs = 0x123456787FFFFFFF;
> +    rt = 0x1111111100000001;
> +    result = 0x2345678980000000;
> +    dspresult = 0x1;
> +
> +    __asm
> +        ("addq.pw %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addq.pw error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addq_qh.c 
> b/tests/tcg/mips/mips64-dsp/addq_qh.c
> new file mode 100644
> index 0000000..415f743
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addq_qh.c
> @@ -0,0 +1,28 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +
> +    rs = 0x123456787FFF0000;
> +    rt = 0x1111111100010000;
> +    result = 0x2345678980000000;
> +    dspresult = 0x1;
> +
> +    __asm
> +        ("addq.qh %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addq.qh error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addq_s_ph.c 
> b/tests/tcg/mips/mips64-dsp/addq_s_ph.c
> new file mode 100644
> index 0000000..5cc94c4
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addq_s_ph.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0xFFFFFFFF;
> +    rt     = 0x10101010;
> +    result = 0x100F100F;
> +    __asm
> +        ("addq_s.ph   %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addq_s.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x3712847D;
> +    rt     = 0x0031AF2D;
> +    result = 0x37438000;
> +    __asm
> +        ("addq_s.ph   %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addq_s.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addq_s_pw.c 
> b/tests/tcg/mips/mips64-dsp/addq_s_pw.c
> new file mode 100644
> index 0000000..6cd2314
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addq_s_pw.c
> @@ -0,0 +1,45 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rs = 0x123456787FFFFFFF;
> +    rt = 0x1111111100000001;
> +    result = 0x234567897FFFFFFF;
> +    dspresult = 0x1;
> +
> +    __asm
> +        ("addq_s.pw %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addq_s.pw error\n");
> +
> +        return -1;
> +    }
> +
> +    rs = 0x7FFFFFFFE00000FF;
> +    rt = 0x00000001200000DD;
> +    result = 0x7FFFFFFF000001DC;
> +    dspresult = 0x01;
> +
> +    __asm
> +        ("addq_s.pw %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addq_s.pw error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addq_s_qh.c 
> b/tests/tcg/mips/mips64-dsp/addq_s_qh.c
> new file mode 100644
> index 0000000..3057ce6
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addq_s_qh.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rs = 0x123456787FFF0000;
> +    rt = 0x1111111100020000;
> +    result = 0x234567897FFF0000;
> +    dspresult = 0x1;
> +
> +    __asm
> +        ("addq_s.qh %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addq_s.qh error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addsc.c 
> b/tests/tcg/mips/mips64-dsp/addsc.c
> new file mode 100644
> index 0000000..c753376
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addsc.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x0000000F;
> +    rt     = 0x00000001;
> +    result = 0x00000010;
> +    __asm
> +        ("addsc %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addsc wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0x00001110;
> +    __asm
> +        ("addsc %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addsc wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addu_ob.c 
> b/tests/tcg/mips/mips64-dsp/addu_ob.c
> new file mode 100644
> index 0000000..1069e68
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addu_ob.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x3456123498DEF390;
> +    result = 0x468A68AC329AD180;
> +    dspresult = 0x01;
> +
> +    __asm
> +        ("addu.ob %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addu.ob error\n\t");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addu_qb.c 
> b/tests/tcg/mips/mips64-dsp/addu_qb.c
> new file mode 100644
> index 0000000..a5ecdcd
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addu_qb.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010001;
> +    result = 0x00000000;
> +    __asm
> +        ("addu.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addu.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0xFFFFFFFFFF011112;
> +    __asm
> +        ("addu.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addu.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addu_s_ob.c 
> b/tests/tcg/mips/mips64-dsp/addu_s_ob.c
> new file mode 100644
> index 0000000..e89a463
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addu_s_ob.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x3456123498DEF390;
> +    result = 0x468A68ACFFFFFFFF;
> +    dspresult = 0x01;
> +
> +    __asm
> +        ("addu_s.ob %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addu_s.ob error\n\t");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addu_s_qb.c 
> b/tests/tcg/mips/mips64-dsp/addu_s_qb.c
> new file mode 100644
> index 0000000..7a09965
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addu_s_qb.c
> @@ -0,0 +1,38 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x10FF01FF;
> +    rt     = 0x10010001;
> +    result = 0x20FF01FF;
> +    __asm
> +        ("addu_s.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addu_s.qb error 1\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFFFFFFFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0xFFFFFFFFFFFF1112;
> +    __asm
> +        ("addu_s.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addu_s.qb error 2\n");
> +
> +        return -1;
> +    }
> +
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/addwc.c 
> b/tests/tcg/mips/mips64-dsp/addwc.c
> new file mode 100644
> index 0000000..fb3ef11
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/addwc.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x10FF01FF;
> +    rt     = 0x10010001;
> +    result = 0x21000200;
> +    __asm
> +        ("addwc %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addwc wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0x00011112;
> +    __asm
> +        ("addwc %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addwc wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/bitrev.c 
> b/tests/tcg/mips/mips64-dsp/bitrev.c
> new file mode 100644
> index 0000000..ac24ef3
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/bitrev.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt     = 0x12345678;
> +    result = 0x00001E6A;
> +
> +    __asm
> +        ("bitrev %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("bitrev wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/bposge32.c 
> b/tests/tcg/mips/mips64-dsp/bposge32.c
> new file mode 100644
> index 0000000..97bce44
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/bposge32.c
> @@ -0,0 +1,50 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long dsp, sum;
> +    long long result;
> +
> +    dsp =  0x20;
> +    sum = 0x01;
> +    result = 0x02;
> +
> +    __asm
> +        ("wrdsp %1\n\t"
> +         "bposge32 test1\n\t"
> +         "nop\n\t"
> +         "addi %0, 0xA2\n\t"
> +         "nop\n\t"
> +         "test1:\n\t"
> +         "addi %0, 0x01\n\t"
> +         : "+r"(sum)
> +         : "r"(dsp)
> +        );
> +    if (sum != result) {
> +        printf("bposge32 wrong\n");
> +
> +        return -1;
> +    }
> +
> +    dsp =  0x10;
> +    sum = 0x01;
> +    result = 0xA4;
> +
> +    __asm
> +        ("wrdsp %1\n\t"
> +         "bposge32 test2\n\t"
> +         "nop\n\t"
> +         "addi %0, 0xA2\n\t"
> +         "nop\n\t"
> +         "test2:\n\t"
> +         "addi %0, 0x01\n\t"
> +         : "+r"(sum)
> +         : "r"(dsp)
> +        );
> +    if (sum != result) {
> +        printf("bposge32 wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/bposge64.c 
> b/tests/tcg/mips/mips64-dsp/bposge64.c
> new file mode 100644
> index 0000000..961fb61
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/bposge64.c
> @@ -0,0 +1,50 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long dsp, sum;
> +    long long result;
> +
> +    dsp =  0x40;
> +    sum = 0x01;
> +    result = 0x02;
> +
> +    __asm
> +        ("wrdsp %1\n\t"
> +         "bposge32 test1\n\t"
> +         "nop\n\t"
> +         "addi %0, 0xA2\n\t"
> +         "nop\n\t"
> +         "test1:\n\t"
> +         "addi %0, 0x01\n\t"
> +         : "+r"(sum)
> +         : "r"(dsp)
> +        );
> +    if (sum != result) {
> +        printf("bposge32 wrong\n");
> +
> +        return -1;
> +    }
> +
> +    dsp =  0x10;
> +    sum = 0x01;
> +    result = 0xA4;
> +
> +    __asm
> +        ("wrdsp %1\n\t"
> +         "bposge32 test2\n\t"
> +         "nop\n\t"
> +         "addi %0, 0xA2\n\t"
> +         "nop\n\t"
> +         "test2:\n\t"
> +         "addi %0, 0x01\n\t"
> +         : "+r"(sum)
> +         : "r"(dsp)
> +        );
> +    if (sum != result) {
> +        printf("bposge32 wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmp_eq_ph.c 
> b/tests/tcg/mips/mips64-dsp/cmp_eq_ph.c
> new file mode 100644
> index 0000000..63069d0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmp_eq_ph.c
> @@ -0,0 +1,42 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA33FF;
> +    result = 0x00;
> +    __asm
> +        ("cmp.eq.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    rd = (rd >> 24) & 0x03;
> +    if (rd != result) {
> +        printf("cmp.eq.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x03;
> +    __asm
> +        ("cmp.eq.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    rd = (rd >> 24) & 0x03;
> +    if (rd != result) {
> +        printf("cmp.eq.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmp_eq_pw.c 
> b/tests/tcg/mips/mips64-dsp/cmp_eq_pw.c
> new file mode 100644
> index 0000000..46e3417
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmp_eq_pw.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +  long long rs, rt, dspreg, dspresult;
> +
> +  rs = 0x123456789ABCDEF0;
> +  rt = 0x123456789ABCDEFF;
> +  dspresult = 0x02;
> +
> +  __asm
> +      ("cmp.eq.pw %1, %2\n\t"
> +       "rddsp %0\n\t"
> +       : "=r"(dspreg)
> +       : "r"(rs), "r"(rt)
> +      );
> +
> +  dspreg = ((dspreg >> 24) & 0x03);
> +
> +  if (dspreg != dspresult) {
> +    printf("cmp.eq.pw error\n");
> +
> +    return -1;
> +  }
> +
> +  return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmp_eq_qh.c 
> b/tests/tcg/mips/mips64-dsp/cmp_eq_qh.c
> new file mode 100644
> index 0000000..7b5381c
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmp_eq_qh.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +  long long rs, rt, dspreg, dspresult;
> +
> +  rs = 0x123456789ABCDEF0;
> +  rt = 0x123456789ABCDEFF;
> +  dspresult = 0x0E;
> +
> +  __asm
> +      ("cmp.eq.qh %1, %2\n\t"
> +        "rddsp %0\n\t"
> +        : "=r"(dspreg)
> +        : "r"(rs), "r"(rt)
> +       );
> +
> +  dspreg = ((dspreg >> 24) & 0x0F);
> +
> +  if (dspreg != dspresult) {
> +    printf("cmp.eq.qh error\n");
> +
> +    return -1;
> +  }
> +
> +  return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmp_le_ph.c 
> b/tests/tcg/mips/mips64-dsp/cmp_le_ph.c
> new file mode 100644
> index 0000000..12d24f1
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmp_le_ph.c
> @@ -0,0 +1,40 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA33FF;
> +    result = 0x02;
> +    __asm
> +        ("cmp.le.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    rd = (rd >> 24) & 0x03;
> +    if (rd != result) {
> +        printf("cmp.le.ph wrong\n");
> +
> +        return -1;
> +    }
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x03;
> +    __asm
> +        ("cmp.le.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    rd = (rd >> 24) & 0x03;
> +    if (rd != result) {
> +        printf("cmp.le.ph wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmp_le_pw.c 
> b/tests/tcg/mips/mips64-dsp/cmp_le_pw.c
> new file mode 100644
> index 0000000..51bdec4
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmp_le_pw.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    dspresult = 0x03;
> +
> +    __asm
> +        ("cmp.le.pw %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 24) & 0x03);
> +
> +    if (dspreg != dspresult) {
> +        printf("cmp.le.pw error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmp_le_qh.c 
> b/tests/tcg/mips/mips64-dsp/cmp_le_qh.c
> new file mode 100644
> index 0000000..0dff2b1
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmp_le_qh.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    dspresult = 0x0F;
> +
> +    __asm
> +        ("cmp.le.qh %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 24) & 0x0F);
> +
> +    if (dspreg != dspresult) {
> +        printf("cmp.le.qh error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmp_lt_ph.c 
> b/tests/tcg/mips/mips64-dsp/cmp_lt_ph.c
> new file mode 100644
> index 0000000..1d91228
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmp_lt_ph.c
> @@ -0,0 +1,41 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA33FF;
> +    result = 0x02;
> +    __asm
> +        ("cmp.lt.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    rd = (rd >> 24) & 0x03;
> +    if (rd != result) {
> +        printf("cmp.lt.ph wrong\n");
> +
> +        return -1;
> +    }
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x00;
> +    __asm
> +        ("cmp.lt.ph %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    rd = (rd >> 24) & 0x03;
> +    if (rd != result) {
> +        printf("cmp.lt.ph2 wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmp_lt_pw.c 
> b/tests/tcg/mips/mips64-dsp/cmp_lt_pw.c
> new file mode 100644
> index 0000000..9c7f8a2
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmp_lt_pw.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    dspresult = 0x01;
> +
> +    __asm
> +        ("cmp.lt.pw %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 24) & 0x03);
> +
> +    if (dspreg != dspresult) {
> +        printf("cmp.lt.pw error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmp_lt_qh.c 
> b/tests/tcg/mips/mips64-dsp/cmp_lt_qh.c
> new file mode 100644
> index 0000000..56fee15
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmp_lt_qh.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    dspresult = 0x01;
> +
> +    __asm
> +        ("cmp.lt.qh %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 24) & 0x0F);
> +
> +    if (dspreg != dspresult) {
> +        printf("cmp.lt.qh error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_eq_ob.c 
> b/tests/tcg/mips/mips64-dsp/cmpgu_eq_ob.c
> new file mode 100644
> index 0000000..2232073
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpgu_eq_ob.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    result = 0xFE;
> +
> +    __asm
> +        ("cmpgu.eq.ob %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("cmpgu.eq.ob error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_eq_qb.c 
> b/tests/tcg/mips/mips64-dsp/cmpgu_eq_qb.c
> new file mode 100644
> index 0000000..b41c443
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpgu_eq_qb.c
> @@ -0,0 +1,38 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA70FF;
> +    result = 0x02;
> +    __asm
> +        ("cmpgu.eq.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("cmpgu.eq.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x0F;
> +    __asm
> +        ("cmpgu.eq.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("cmpgu.eq.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_le_ob.c 
> b/tests/tcg/mips/mips64-dsp/cmpgu_le_ob.c
> new file mode 100644
> index 0000000..f28dceb
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpgu_le_ob.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    result = 0xFF;
> +
> +    __asm
> +        ("cmpgu.le.ob %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("cmpgu.le.ob error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_le_qb.c 
> b/tests/tcg/mips/mips64-dsp/cmpgu_le_qb.c
> new file mode 100644
> index 0000000..dd2b091
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpgu_le_qb.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA70FF;
> +    result = 0x0F;
> +    __asm
> +        ("cmpgu.le.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("cmpgu.le.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11766066;
> +    result = 0x09;
> +    __asm
> +        ("cmpgu.le.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("cmpgu.le.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_lt_ob.c 
> b/tests/tcg/mips/mips64-dsp/cmpgu_lt_ob.c
> new file mode 100644
> index 0000000..aa335ac
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpgu_lt_ob.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    result = 0x01;
> +
> +    __asm
> +        ("cmpgu.lt.ob %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("cmpgu.lt.ob error\n");
> +
> +        return -1;
> +    }
> +
> +   return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpgu_lt_qb.c 
> b/tests/tcg/mips/mips64-dsp/cmpgu_lt_qb.c
> new file mode 100644
> index 0000000..a467cb7
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpgu_lt_qb.c
> @@ -0,0 +1,38 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x11777066;
> +    rt     = 0x55AA70FF;
> +    result = 0x0D;
> +    __asm
> +        ("cmpgu.lt.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("cmpgu.lt.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11766066;
> +    result = 0x00;
> +    __asm
> +        ("cmpgu.lt.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("cmpgu.lt.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpu_eq_ob.c 
> b/tests/tcg/mips/mips64-dsp/cmpu_eq_ob.c
> new file mode 100644
> index 0000000..a2b5681
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpu_eq_ob.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    dspresult = 0xFE;
> +
> +    __asm
> +        ("cmpu.eq.ob %1, %2\n\t"
> +         "rddsp %0"
> +         : "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = ((dspreg >> 24) & 0xFF);
> +
> +    if (dspreg != dspresult) {
> +        printf("cmpu.eq.ob error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpu_eq_qb.c 
> b/tests/tcg/mips/mips64-dsp/cmpu_eq_qb.c
> new file mode 100644
> index 0000000..28f3bec
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpu_eq_qb.c
> @@ -0,0 +1,42 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long dsp;
> +    long long result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x02;
> +    __asm
> +        ("cmpu.eq.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (dsp != result) {
> +        printf("cmpu.eq.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x0F;
> +    __asm
> +        ("cmpu.eq.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (dsp != result) {
> +        printf("cmpu.eq.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpu_le_ob.c 
> b/tests/tcg/mips/mips64-dsp/cmpu_le_ob.c
> new file mode 100644
> index 0000000..71845bc
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpu_le_ob.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    dspresult = 0xFF;
> +
> +    __asm
> +        ("cmpu.le.ob %1, %2\n\t"
> +         "rddsp %0"
> +         : "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = dspreg >> 24;
> +    if (dspreg != dspresult) {
> +        printf("cmpu.le.ob error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpu_le_qb.c 
> b/tests/tcg/mips/mips64-dsp/cmpu_le_qb.c
> new file mode 100644
> index 0000000..8a17a08
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpu_le_qb.c
> @@ -0,0 +1,41 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long dsp;
> +    long long result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x0F;
> +    __asm
> +        ("cmpu.le.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (dsp != result) {
> +        printf("cmpu.le.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x0F;
> +    __asm
> +        ("cmpu.le.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (dsp != result) {
> +        printf("cmpu.le.qb wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpu_lt_ob.c 
> b/tests/tcg/mips/mips64-dsp/cmpu_lt_ob.c
> new file mode 100644
> index 0000000..832f6d3
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpu_lt_ob.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    dspresult = 0x01;
> +
> +    __asm
> +        ("cmpu.lt.ob %1, %2\n\t"
> +         "rddsp %0"
> +         : "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dspreg = dspreg >> 24;
> +    if (dspreg != dspresult) {
> +        printf("cmpu.lt.ob error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/cmpu_lt_qb.c 
> b/tests/tcg/mips/mips64-dsp/cmpu_lt_qb.c
> new file mode 100644
> index 0000000..adb75ee
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/cmpu_lt_qb.c
> @@ -0,0 +1,42 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long dsp;
> +    long long result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x0D;
> +    __asm
> +        ("cmpu.lt.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (dsp != result) {
> +        printf("cmpu.lt.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x00;
> +    __asm
> +        ("cmpu.lt.qb %1, %2\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (dsp != result) {
> +        printf("cmpu.lt.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dappend.c 
> b/tests/tcg/mips/mips64-dsp/dappend.c
> new file mode 100644
> index 0000000..ba8e121
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dappend.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long res;
> +    rt = 0x1234567887654321;
> +    rs = 0xabcd1234abcd8765;
> +
> +    res = 0x1234567887654321;
> +    __asm
> +        ("dappend %0, %1, 0x0\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("dappend error\n");
> +        return -1;
> +    }
> +
> +    rt = 0x1234567887654321;
> +    rs = 0xabcd1234abcd8765;
> +
> +    res = 0x2345678876543215;
> +    __asm
> +        ("dappend %0, %1, 0x4\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("dappend error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextp.c 
> b/tests/tcg/mips/mips64-dsp/dextp.c
> new file mode 100644
> index 0000000..794ad48
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextp.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +    int rs;
> +    rs = 0xabcd1234;
> +
> +    achi = 0x12345678;
> +    acli = 0x87654321;
> +    res = 0xff;
> +    resdsp = 0x0;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "wrdsp %4, 0x1\n\t"
> +         "wrdsp %4\n\t"
> +         "dextp %0, $ac1, 0x7\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +    dsp = (dsp >> 14) & 0x1;
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextp error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextpdp.c 
> b/tests/tcg/mips/mips64-dsp/dextpdp.c
> new file mode 100644
> index 0000000..a0cb069
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextpdp.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, dsp;
> +    long long achi, acli;
> +    long long res, resdsp, resdsppos;
> +    int rs;
> +    int tmp1, tmp2;
> +    rs = 0xabcd1234;
> +
> +    achi = 0x12345678;
> +    acli = 0x87654321;
> +    res = 0xff;
> +    resdsp = 0x0;
> +    resdsppos = 0x2c;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "wrdsp %4, 0x1\n\t"
> +         "wrdsp %4\n\t"
> +         "dextpdp %0, $ac1, 0x7\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +    tmp1 = (dsp >> 14) & 0x1;
> +    tmp2 = dsp & 0x3f;
> +
> +    if ((tmp1 != resdsp) || (rt != res) || (tmp2 != resdsppos)) {
> +        printf("dextpdp error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextpdpv.c 
> b/tests/tcg/mips/mips64-dsp/dextpdpv.c
> new file mode 100644
> index 0000000..70b3ed8
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextpdpv.c
> @@ -0,0 +1,38 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long res, resdsp, resdsppos;
> +    int rsdsp;
> +    int tmp1, tmp2;
> +    rsdsp = 0xabcd1234;
> +    rs = 0x7;
> +    achi = 0x12345678;
> +    acli = 0x87654321;
> +    res = 0xff;
> +    resdsp = 0x0;
> +    resdsppos = 0x2c;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "wrdsp %4, 0x1\n\t"
> +         "wrdsp %4\n\t"
> +         "dextpdpv %0, $ac1, %5\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rsdsp), "r"(rs)
> +        );
> +
> +    tmp1 = (dsp >> 14) & 0x1;
> +    tmp2 = dsp & 0x3f;
> +
> +    if ((tmp1 != resdsp) || (rt != res) || (tmp2 != resdsppos)) {
> +        printf("dextpdpv error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextpv.c 
> b/tests/tcg/mips/mips64-dsp/dextpv.c
> new file mode 100644
> index 0000000..78b6aec
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextpv.c
> @@ -0,0 +1,34 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +    int rsdsp;
> +    rsdsp = 0xabcd1234;
> +    rs = 0x7;
> +
> +    achi = 0x12345678;
> +    acli = 0x87654321;
> +    res = 0xff;
> +    resdsp = 0x0;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "wrdsp %4, 0x1\n\t"
> +         "wrdsp %4\n\t"
> +         "dextpv %0, $ac1, %5\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rsdsp), "r"(rs)
> +        );
> +    dsp = (dsp >> 14) & 0x1;
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextpv error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextr_l.c 
> b/tests/tcg/mips/mips64-dsp/dextr_l.c
> new file mode 100644
> index 0000000..dd0565f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextr_l.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt;
> +    long long achi, acli;
> +    long long res;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +
> +    res = 0x2100000000123456;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mtlo %2, $ac1\n\t"
> +         "dextr.l %0, $ac1, 0x8\n\t"
> +         : "=r"(rt)
> +         : "r"(achi), "r"(acli)
> +        );
> +    if (rt != res) {
> +        printf("dextr.l error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextr_r_l.c 
> b/tests/tcg/mips/mips64-dsp/dextr_r_l.c
> new file mode 100644
> index 0000000..ab3c351
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextr_r_l.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +
> +    res = 0x2100000000123456;
> +    resdsp = 0x01;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextr_r.l %0, $ac1, 0x8\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli)
> +        );
> +
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextr_r.l error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextr_r_w.c 
> b/tests/tcg/mips/mips64-dsp/dextr_r_w.c
> new file mode 100644
> index 0000000..e4a2072
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextr_r_w.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +
> +    res = 0x123456;
> +    resdsp = 0x01;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextr_r.w %0, $ac1, 0x8\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli)
> +        );
> +
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextr_r.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextr_rs_l.c 
> b/tests/tcg/mips/mips64-dsp/dextr_rs_l.c
> new file mode 100644
> index 0000000..fbe021d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextr_rs_l.c
> @@ -0,0 +1,31 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +
> +    res = 0x8000000000000000;
> +    resdsp = 0x1;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextr_rs.l %0, $ac1, 0x8\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli)
> +        );
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextr_rs.l error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextr_rs_w.c 
> b/tests/tcg/mips/mips64-dsp/dextr_rs_w.c
> new file mode 100644
> index 0000000..c97e2e5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextr_rs_w.c
> @@ -0,0 +1,31 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +
> +    res = 0xffffffff80000000;
> +    resdsp = 0x1;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextr_rs.w %0, $ac1, 0x8\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli)
> +        );
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextr_rs.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextr_s_h.c 
> b/tests/tcg/mips/mips64-dsp/dextr_s_h.c
> new file mode 100644
> index 0000000..a664b73
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextr_s_h.c
> @@ -0,0 +1,31 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +
> +    res = 0xffffffffffff8000;
> +    resdsp = 0x1;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextr_s.h %0, $ac1, 0x8\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli)
> +        );
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextr_s.h error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextr_w.c 
> b/tests/tcg/mips/mips64-dsp/dextr_w.c
> new file mode 100644
> index 0000000..654dfaf
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextr_w.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt;
> +    long long achi, acli;
> +    long long res;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +
> +    res = 0x123456;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mtlo %2, $ac1\n\t"
> +         "dextr.w %0, $ac1, 0x8\n\t"
> +         : "=r"(rt)
> +         : "r"(achi), "r"(acli)
> +        );
> +    if (rt != res) {
> +        printf("dextr.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextrv_l.c 
> b/tests/tcg/mips/mips64-dsp/dextrv_l.c
> new file mode 100644
> index 0000000..44b0160
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextrv_l.c
> @@ -0,0 +1,28 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long res;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +    rs = 0x8;
> +
> +    res = 0x2100000000123456;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mtlo %2, $ac1\n\t"
> +         "dextrv.l %0, $ac1, %3\n\t"
> +         : "=r"(rt)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +    if (rt != res) {
> +        printf("dextrv.l error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextrv_r_l.c 
> b/tests/tcg/mips/mips64-dsp/dextrv_r_l.c
> new file mode 100644
> index 0000000..c5b3850
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextrv_r_l.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, dsp, rs;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +    rs = 0x8;
> +
> +    res = 0x2100000000123456;
> +    resdsp = 0x01;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextrv_r.l %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextrv_r.l error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextrv_r_w.c 
> b/tests/tcg/mips/mips64-dsp/dextrv_r_w.c
> new file mode 100644
> index 0000000..7cefdab
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextrv_r_w.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +    rs = 0x8;
> +
> +    res = 0x123456;
> +    resdsp = 0x01;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextrv_r.w %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextrv_r.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextrv_rs_l.c 
> b/tests/tcg/mips/mips64-dsp/dextrv_rs_l.c
> new file mode 100644
> index 0000000..6a2594f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextrv_rs_l.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +    rs = 0x8;
> +
> +    res = 0x8000000000000000;
> +    resdsp = 0x1;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextrv_rs.l %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextrv_rs.l error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextrv_rs_w.c 
> b/tests/tcg/mips/mips64-dsp/dextrv_rs_w.c
> new file mode 100644
> index 0000000..9f8a9b3
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextrv_rs_w.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +    rs = 0x8;
> +
> +    res = 0xffffffff80000000;
> +    resdsp = 0x1;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextrv_rs.w %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextrv_rs.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextrv_s_h.c 
> b/tests/tcg/mips/mips64-dsp/dextrv_s_h.c
> new file mode 100644
> index 0000000..87d3aee
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextrv_s_h.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long res, resdsp;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +    rs = 0x8;
> +
> +    res = 0xffffffffffff8000;
> +    resdsp = 0x1;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dextrv_s.h %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +    dsp = (dsp >> 23) & 0x1;
> +
> +    if ((dsp != resdsp) || (rt != res)) {
> +        printf("dextrv_s.h error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dextrv_w.c 
> b/tests/tcg/mips/mips64-dsp/dextrv_w.c
> new file mode 100644
> index 0000000..4028a7a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dextrv_w.c
> @@ -0,0 +1,28 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long res;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +    rs = 0x8;
> +
> +    res = 0x123456;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mtlo %2, $ac1\n\t"
> +         "dextrv.w %0, $ac1, %3\n\t"
> +         : "=r"(rt)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +    if (rt != res) {
> +        printf("dextrv.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dinsv.c 
> b/tests/tcg/mips/mips64-dsp/dinsv.c
> new file mode 100644
> index 0000000..25152c0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dinsv.c
> @@ -0,0 +1,25 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long res;
> +
> +    rs = 0x1234567887654321;
> +    rt = 0x1234567812345678;
> +    dsp = 0x2222;
> +    res = 0x1234567812345678;
> +    __asm
> +        ("wrdsp  %1, 0x3\n\t"
> +         "wrdsp %1\n\t"
> +         "dinsv %0, %2\n\t"
> +         : "+r"(rt)
> +         : "r"(dsp), "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("dinsv error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dmadd.c 
> b/tests/tcg/mips/mips64-dsp/dmadd.c
> new file mode 100644
> index 0000000..fb22614
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dmadd.c
> @@ -0,0 +1,57 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +
> +    achi = 0x1;
> +    acli = 0x1;
> +
> +    rs = 0x0000000100000001;
> +    rt = 0x0000000200000002;
> +
> +    resh = 0x1;
> +    resl = 0x5;
> +    __asm
> +       ("mthi %2, $ac1 \t\n"
> +        "mtlo %3, $ac1 \t\n"
> +        "dmadd $ac1, %4, %5\t\n"
> +        "mfhi %0, $ac1 \t\n"
> +        "mflo %1, $ac1 \t\n"
> +        : "=r"(acho), "=r"(aclo)
> +        : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +      );
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dmadd error\n");
> +
> +        return -1;
> +    }
> +
> +    achi = 0x1;
> +    acli = 0x1;
> +
> +    rs = 0xaaaabbbbccccdddd;
> +    rt = 0xaaaabbbbccccdddd;
> +
> +    resh = 0x0000000000000000;
> +    resl = 0xffffffffca860b63;
> +
> +    __asm
> +       ("mthi %2, $ac1 \t\n"
> +        "mtlo %3, $ac1 \t\n"
> +        "dmadd $ac1, %4, %5\t\n"
> +        "mfhi %0, $ac1 \t\n"
> +        "mflo %1, $ac1 \t\n"
> +        : "=r"(acho), "=r"(aclo)
> +        : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +      );
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("2 dmadd error\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dmaddu.c 
> b/tests/tcg/mips/mips64-dsp/dmaddu.c
> new file mode 100644
> index 0000000..39ab0c1
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dmaddu.c
> @@ -0,0 +1,56 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +    achi = 0x1;
> +    acli = 0x2;
> +
> +    rs = 0x0000000200000002;
> +    rt = 0x0000000200000002;
> +    resh = 0x1;
> +    resl = 0xa;
> +    __asm
> +        ("mthi %2, $ac1 \t\n"
> +         "mtlo %3, $ac1 \t\n"
> +         "dmaddu $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1 \t\n"
> +         "mflo %1, $ac1 \t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dmaddu error\n");
> +
> +        return -1;
> +    }
> +
> +    achi = 0x1;
> +    acli = 0x1;
> +
> +    rs = 0xaaaabbbbccccdddd;
> +    rt = 0xaaaabbbbccccdddd;
> +
> +    resh = 0x0000000000000002;
> +    resl = 0xffffffffca860b63;
> +
> +    __asm
> +        ("mthi %2, $ac1 \t\n"
> +         "mtlo %3, $ac1 \t\n"
> +         "dmaddu $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1 \t\n"
> +         "mflo %1, $ac1 \t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("2 dmaddu error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dmsub.c 
> b/tests/tcg/mips/mips64-dsp/dmsub.c
> new file mode 100644
> index 0000000..16be617
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dmsub.c
> @@ -0,0 +1,59 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +    achi = 0x1;
> +    acli = 0x8;
> +
> +    rs = 0x0000000100000001;
> +    rt = 0x0000000200000002;
> +
> +    resh = 0x1;
> +    resl = 0x4;
> +
> +    __asm
> +        ("mthi %2, $ac1 \t\n"
> +         "mtlo %3, $ac1 \t\n"
> +         "dmsub $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1 \t\n"
> +         "mflo %1, $ac1 \t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dmsub error\n");
> +
> +        return -1;
> +    }
> +
> +    achi = 0xfffffffF;
> +    acli = 0xfffffffF;
> +
> +    rs = 0x8888999977776666;
> +    rt = 0x9999888877776666;
> +
> +    resh = 0xffffffffffffffff;
> +    resl = 0x789aae13;
> +
> +    __asm
> +        ("mthi %2, $ac1 \t\n"
> +         "mtlo %3, $ac1 \t\n"
> +         "dmsub $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1 \t\n"
> +         "mflo %1, $ac1 \t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("2 dmsub error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dmsubu.c 
> b/tests/tcg/mips/mips64-dsp/dmsubu.c
> new file mode 100644
> index 0000000..cc4838a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dmsubu.c
> @@ -0,0 +1,59 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +    achi = 0x1;
> +    acli = 0x8;
> +
> +    rs = 0x0000000100000001;
> +    rt = 0x0000000200000002;
> +
> +    resh = 0x1;
> +    resl = 0x4;
> +
> +    __asm
> +        ("mthi %2, $ac1 \t\n"
> +         "mtlo %3, $ac1 \t\n"
> +         "dmsubu $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1 \t\n"
> +         "mflo %1, $ac1 \t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dmsubu error\n");
> +
> +        return -1;
> +    }
> +
> +    achi = 0xfffffffF;
> +    acli = 0xfffffffF;
> +
> +    rs = 0x8888999977776666;
> +    rt = 0x9999888877776666;
> +
> +    resh = 0xffffffffffffffff;
> +    resl = 0x789aae13;
> +
> +    __asm
> +        ("mthi %2, $ac1 \t\n"
> +         "mtlo %3, $ac1 \t\n"
> +         "dmsubu $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1 \t\n"
> +         "mflo %1, $ac1 \t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("2 dmsubu error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dmthlip.c 
> b/tests/tcg/mips/mips64-dsp/dmthlip.c
> new file mode 100644
> index 0000000..4a001f2
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dmthlip.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, dsp;
> +    long long achi, acli;
> +    long long res, rsdsp;
> +
> +
> +    rs = 0xaaaabbbbccccdddd;
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +    dsp = 0x22;
> +
> +    res = 0x62;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mtlo %2, $ac1\n\t"
> +         "wrdsp %3\n\t"
> +         "dmthlip %4, $ac1\n\t"
> +         "rddsp %0\n\t"
> +         : "=r"(rsdsp)
> +         : "r"(achi), "r"(acli), "r"(dsp), "r"(rs)
> +        );
> +    if (rsdsp != res) {
> +        printf("dmthlip error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpaq_s_w_ph.c 
> b/tests/tcg/mips/mips64-dsp/dpaq_s_w_ph.c
> new file mode 100644
> index 0000000..1bca935
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpaq_s_w_ph.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long ach = 0, acl = 0;
> +    long long resulth, resultl, resultdsp;
> +
> +    rs        = 0x800000FF;
> +    rt        = 0x80000002;
> +    resulth   = 0x00;
> +    resultl   = 0xFFFFFFFF800003FB;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi        %0, $ac1\n\t"
> +         "mtlo        %1, $ac1\n\t"
> +         "dpaq_s.w.ph $ac1, %3, %4\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         "rddsp       %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = dsp >> 17 & 0x01;
> +    if ((dsp != resultdsp) || (ach != resulth) || (acl != resultl)) {
> +        printf("dpaq_w.w.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpaq_s_w_qh.c 
> b/tests/tcg/mips/mips64-dsp/dpaq_s_w_qh.c
> new file mode 100644
> index 0000000..94fc8c1
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpaq_s_w_qh.c
> @@ -0,0 +1,57 @@
> +#include"io.h"
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +
> +    achi = 0x1;
> +    acli = 0x1;
> +    rs = 0x0001000100010001;
> +    rt = 0x0002000200020002;
> +    resh = 0x1;
> +    resl = 0x11;
> +
> +    __asm
> +        ("mthi %2, $ac1\t\n"
> +         "mtlo %3, $ac1\t\n"
> +         "dpaq_s.w.qh $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1\t\n"
> +         "mflo %1, $ac1\t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dpaq_s.w.qh error\n");
> +
> +        return -1;
> +    }
> +
> +    achi = 0xffffffff;
> +    acli = 0xaaaaaaaa;
> +
> +    rs = 0x1111222233334444;
> +    rt = 0xffffeeeeddddcccc;
> +
> +    resh = 0xffffffffffffffff;
> +    resl = 0xffffffffd27ad82e;
> +
> +    __asm
> +        ("mthi %2, $ac1\t\n"
> +         "mtlo %3, $ac1\t\n"
> +         "dpaq_s.w.qh $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1\t\n"
> +         "mflo %1, $ac1\t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("2 dpaq_s.w.qh error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpaq_sa_l_pw.c 
> b/tests/tcg/mips/mips64-dsp/dpaq_sa_l_pw.c
> new file mode 100644
> index 0000000..8789e84
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpaq_sa_l_pw.c
> @@ -0,0 +1,62 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long dsp;
> +    long long resh, resl;
> +    long long resdsp;
> +
> +    rs = 0x0000000100000001;
> +    rt = 0x0000000200000002;
> +    achi = 0x1;
> +    acli = 0x1;
> +    resh = 0x1;
> +    resl = 0x9;
> +    resdsp = 0x00;
> +
> +    __asm
> +        ("mthi        %3, $ac1\n\t"
> +         "mtlo        %4, $ac1\n\t"
> +         "dpaq_sa.l.pw $ac1, %5, %6\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         "rddsp       %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl) || ((dsp >> (16 + 1)) != resdsp)) {
> +        printf("1 dpaq_sa_l_pw error\n");
> +
> +        return -1;
> +    }
> +
> +    rs = 0xaaaabbbbccccdddd;
> +    rt = 0x3333444455556666;
> +    achi = 0x88888888;
> +    acli = 0x66666666;
> +
> +    resh = 0xffffffff88888887;
> +    resl = 0xffffffff9e2661da;
> +
> +    __asm
> +        ("mthi        %2, $ac1\n\t"
> +         "mtlo        %3, $ac1\n\t"
> +         "dpaq_sa.l.pw $ac1, %4, %5\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dpaq_sa_l_pw error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpaq_sa_l_w.c 
> b/tests/tcg/mips/mips64-dsp/dpaq_sa_l_w.c
> new file mode 100644
> index 0000000..54490f2
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpaq_sa_l_w.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long ach = 0, acl = 0;
> +    long long resulth, resultl, resultdsp;
> +
> +    rs        = 0x800000FF;
> +    rt        = 0x80000002;
> +    resulth   = 0x7FFFFFFF;
> +    resultl   = 0xFFFFFFFFFFFFFFFF;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi        %0, $ac1\n\t"
> +         "mtlo        %0, $ac1\n\t"
> +         "dpaq_sa.l.w $ac1, %3, %4\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         "rddsp       %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    if ((dsp != resultdsp) || (ach != resulth) || (acl != resultl)) {
> +        printf("dpaq_sa.l.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpau_h_obl.c 
> b/tests/tcg/mips/mips64-dsp/dpau_h_obl.c
> new file mode 100644
> index 0000000..54905e8
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpau_h_obl.c
> @@ -0,0 +1,59 @@
> +
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +
> +    rs = 0x0000000100000001;
> +    rt = 0x0000000200000002;
> +    achi = 0x1;
> +    acli = 0x1;
> +    resh = 0x1;
> +    resl = 0x3;
> +
> +    __asm
> +        ("mthi        %2, $ac1\n\t"
> +         "mtlo        %3, $ac1\n\t"
> +         "dpau.h.obl $ac1, %4, %5\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dpau.h.obl error\n");
> +
> +        return -1;
> +    }
> +
> +    rs = 0xaaaabbbbccccdddd;
> +    rt = 0x3333444455556666;
> +    achi = 0x88888888;
> +    acli = 0x66666666;
> +
> +    resh = 0xffffffff88888888;
> +    resl = 0x66670d7a;
> +
> +    __asm
> +        ("mthi        %2, $ac1\n\t"
> +         "mtlo        %3, $ac1\n\t"
> +         "dpau.h.obl $ac1, %4, %5\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dpau.h.obl error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpau_h_obr.c 
> b/tests/tcg/mips/mips64-dsp/dpau_h_obr.c
> new file mode 100644
> index 0000000..d7aa60b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpau_h_obr.c
> @@ -0,0 +1,59 @@
> +
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +
> +    rs = 0x0000000100000001;
> +    rt = 0x0000000200000002;
> +    achi = 0x1;
> +    acli = 0x1;
> +    resh = 0x1;
> +    resl = 0x3;
> +
> +    __asm
> +        ("mthi        %2, $ac1\n\t"
> +         "mtlo        %3, $ac1\n\t"
> +         "dpau.h.obr $ac1, %4, %5\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dpau.h.obr error\n");
> +
> +        return -1;
> +    }
> +
> +    rs = 0xccccddddaaaabbbb;
> +    rt = 0x5555666633334444;
> +    achi = 0x88888888;
> +    acli = 0x66666666;
> +
> +    resh = 0xffffffff88888888;
> +    resl = 0x66670d7a;
> +
> +    __asm
> +        ("mthi        %2, $ac1\n\t"
> +         "mtlo        %3, $ac1\n\t"
> +         "dpau.h.obr $ac1, %4, %5\n\t"
> +         "mfhi        %0,   $ac1\n\t"
> +         "mflo        %1,   $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dpau.h.obr error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpau_h_qbl.c 
> b/tests/tcg/mips/mips64-dsp/dpau_h_qbl.c
> new file mode 100644
> index 0000000..fcfd764
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpau_h_qbl.c
> @@ -0,0 +1,29 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 3;
> +    long long resulth, resultl;
> +
> +    rs        = 0x800000FF;
> +    rt        = 0x80000002;
> +    resulth   = 0x05;
> +    resultl   = 0x4003;
> +    __asm
> +        ("mthi       %0, $ac1\n\t"
> +         "mtlo       %1, $ac1\n\t"
> +         "dpau.h.qbl $ac1, %2, %3\n\t"
> +         "mfhi       %0,   $ac1\n\t"
> +         "mflo       %1,   $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("dpau.h.qbl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpau_h_qbr.c 
> b/tests/tcg/mips/mips64-dsp/dpau_h_qbr.c
> new file mode 100644
> index 0000000..3282461
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpau_h_qbr.c
> @@ -0,0 +1,29 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 3;
> +    long long resulth, resultl;
> +
> +    rs        = 0x800000FF;
> +    rt        = 0x80000002;
> +    resulth   = 0x05;
> +    resultl   = 0x0201;
> +    __asm
> +        ("mthi       %0, $ac1\n\t"
> +         "mtlo       %1, $ac1\n\t"
> +         "dpau.h.qbr $ac1, %2, %3\n\t"
> +         "mfhi       %0,   $ac1\n\t"
> +         "mflo       %1,   $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("dpau.h.qbr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpsq_s_w_ph.c 
> b/tests/tcg/mips/mips64-dsp/dpsq_s_w_ph.c
> new file mode 100644
> index 0000000..c8a414b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpsq_s_w_ph.c
> @@ -0,0 +1,29 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFFEE9794A3;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsq_s.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("dpsq_s.w.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpsq_s_w_qh.c 
> b/tests/tcg/mips/mips64-dsp/dpsq_s_w_qh.c
> new file mode 100644
> index 0000000..8fd5e25
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpsq_s_w_qh.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +
> +    rs      = 0xffffeeeeddddcccc;
> +    rt      = 0x9999888877776666;
> +    achi = 0x67576;
> +    acli = 0x98878;
> +
> +    resh = 0x67576;
> +    resl = 0x5b1682c4;
> +    __asm
> +        ("mthi  %2, $ac1\n\t"
> +         "mtlo  %3, $ac1\n\t"
> +         "dpsq_s.w.qh $ac1, %4, %5\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("dpsq_s.w.qh wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpsq_sa_l_pw.c 
> b/tests/tcg/mips/mips64-dsp/dpsq_sa_l_pw.c
> new file mode 100644
> index 0000000..4bfb00b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpsq_sa_l_pw.c
> @@ -0,0 +1,39 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long achi, acli;
> +    long long resh, resl, resdsp;
> +
> +    rs      = 0x89789BC0123AD;
> +    rt      = 0x5467591643721;
> +
> +    achi = 0x98765437;
> +    acli = 0x65489709;
> +
> +    resh = 0xffffffffffffffff;
> +    resl = 0x00;
> +
> +    resdsp = 0x01;
> +
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsq_sa.l.pw $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(achi), "+r"(acli), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x01;
> +    if ((dsp != resdsp) || (achi != resh) || (acli != resl)) {
> +        printf("dpsq_sa.l.pw wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpsq_sa_l_w.c 
> b/tests/tcg/mips/mips64-dsp/dpsq_sa_l_w.c
> new file mode 100644
> index 0000000..9a5b090
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpsq_sa_l_w.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl, resultdsp;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x7FFFFFFF;
> +    resultl = 0xFFFFFFFFFFFFFFFF;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsq_sa.l.w $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    if ((dsp != resultdsp) || (ach != resulth) || (acl != resultl)) {
> +        printf("dpsq_sa.l.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpsu_h_obl.c 
> b/tests/tcg/mips/mips64-dsp/dpsu_h_obl.c
> new file mode 100644
> index 0000000..c0a8f4d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpsu_h_obl.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl;
> +
> +    rs      = 0x88886666BC0123AD;
> +    rt      = 0x9999888801643721;
> +
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFFFFFEF115;
> +
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsu.h.obl $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("dpsu.h.obl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpsu_h_obr.c 
> b/tests/tcg/mips/mips64-dsp/dpsu_h_obr.c
> new file mode 100644
> index 0000000..aa0d47a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpsu_h_obr.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl;
> +
> +    rs      = 0x7878878888886666;
> +    rt      = 0x9865454399998888;
> +
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFFFFFeF115;
> +
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsu.h.obr $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("dpsu.h.qbr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpsu_h_qbl.c 
> b/tests/tcg/mips/mips64-dsp/dpsu_h_qbl.c
> new file mode 100644
> index 0000000..da6dbb6
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpsu_h_qbl.c
> @@ -0,0 +1,29 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFFFFFFFEE5;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsu.h.qbl $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("dpsu.h.qbl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dpsu_h_qbr.c 
> b/tests/tcg/mips/mips64-dsp/dpsu_h_qbr.c
> new file mode 100644
> index 0000000..bf00b70
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dpsu_h_qbr.c
> @@ -0,0 +1,29 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFFFFFFE233;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsu.h.qbr $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("dpsu.h.qbr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dshilo.c 
> b/tests/tcg/mips/mips64-dsp/dshilo.c
> new file mode 100644
> index 0000000..2784f58
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dshilo.c
> @@ -0,0 +1,31 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long reshi, reslo;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +
> +    reshi = 0xfffffffff8765432;
> +    reslo = 0x1234567;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dshilo $ac1, 0x4\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli)
> +        );
> +
> +    if ((acho != reshi) || (aclo != reslo)) {
> +        printf("dshilo error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/dshilov.c 
> b/tests/tcg/mips/mips64-dsp/dshilov.c
> new file mode 100644
> index 0000000..dd5fa94
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/dshilov.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long achi, acli, rs;
> +    long long acho, aclo;
> +    long long reshi, reslo;
> +
> +    achi = 0x87654321;
> +    acli = 0x12345678;
> +    rs = 0x4;
> +
> +    reshi = 0xfffffffff8765432;
> +    reslo = 0x1234567;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "dshilov $ac1, %4\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs)
> +        );
> +
> +    if ((acho != reshi) || (aclo != reslo)) {
> +        printf("dshilov error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extp.c 
> b/tests/tcg/mips/mips64-dsp/extp.c
> new file mode 100644
> index 0000000..c72f54b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extp.c
> @@ -0,0 +1,50 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    result = 0x000C;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extp %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 14) & 0x01;
> +    if ((dsp != 0) || (result != rt)) {
> +        printf("extp wrong\n");
> +
> +        return -1;
> +    }
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x01;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extp %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 14) & 0x01;
> +    if (dsp != 1) {
> +        printf("extp wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extpdp.c 
> b/tests/tcg/mips/mips64-dsp/extpdp.c
> new file mode 100644
> index 0000000..f430193
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extpdp.c
> @@ -0,0 +1,51 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, ach, acl, dsp, pos, efi;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    result = 0x000C;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpdp %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    pos =  dsp & 0x3F;
> +    efi = (dsp >> 14) & 0x01;
> +    if ((pos != 3) || (efi != 0) || (result != rt)) {
> +        printf("extpdp wrong\n");
> +
> +        return -1;
> +    }
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x01;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpdp %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    efi = (dsp >> 14) & 0x01;
> +    if (efi != 1) {
> +        printf("extpdp wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extpdpv.c 
> b/tests/tcg/mips/mips64-dsp/extpdpv.c
> new file mode 100644
> index 0000000..ba57426
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extpdpv.c
> @@ -0,0 +1,52 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, ach, acl, dsp, pos, efi;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0x000C;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpdpv %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl), "r"(rs)
> +        );
> +    pos =  dsp & 0x3F;
> +    efi = (dsp >> 14) & 0x01;
> +    if ((pos != 3) || (efi != 0) || (result != rt)) {
> +        printf("extpdpv wrong\n");
> +
> +        return -1;
> +    }
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x01;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpdpv %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl), "r"(rs)
> +        );
> +    efi = (dsp >> 14) & 0x01;
> +    if (efi != 1) {
> +        printf("extpdpv wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extpv.c 
> b/tests/tcg/mips/mips64-dsp/extpv.c
> new file mode 100644
> index 0000000..158472b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extpv.c
> @@ -0,0 +1,51 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, ac, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    ac  = 0x03;
> +    result = 0x000C;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpv %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl), "r"(ac)
> +        );
> +    dsp = (dsp >> 14) & 0x01;
> +    if ((dsp != 0) || (result != rt)) {
> +        printf("extpv wrong\n");
> +
> +        return -1;
> +    }
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x01;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extpv %0, $ac1, %4\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(ach), "r"(acl), "r"(ac)
> +        );
> +    dsp = (dsp >> 14) & 0x01;
> +    if (dsp != 1) {
> +        printf("extpv wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extr_r_w.c 
> b/tests/tcg/mips/mips64-dsp/extr_r_w.c
> new file mode 100644
> index 0000000..097b5e5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extr_r_w.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    result = 0xFFFFFFFFA0001699;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extr_r.w %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    if ((dsp != 1) || (result != rt)) {
> +        printf("extr_r.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extr_rs_w.c 
> b/tests/tcg/mips/mips64-dsp/extr_rs_w.c
> new file mode 100644
> index 0000000..b9798a3
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extr_rs_w.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    result = 0x7FFFFFFF;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extr_rs.w %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    if ((dsp != 1) || (result != rt)) {
> +        printf("extr_rs.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extr_s_h.c 
> b/tests/tcg/mips/mips64-dsp/extr_s_h.c
> new file mode 100644
> index 0000000..2c2328f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extr_s_h.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    result = 0x00007FFF;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extr_s.h %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    if ((dsp != 1) || (result != rt)) {
> +        printf("extr_s.h wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extr_w.c 
> b/tests/tcg/mips/mips64-dsp/extr_w.c
> new file mode 100644
> index 0000000..a5142d9
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extr_w.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    result = 0xFFFFFFFFA0001699;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "extr.w %0, $ac1, 0x03\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "=r"(dsp)
> +         : "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    if ((dsp != 1) || (result != rt)) {
> +        printf("extr.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extrv_r_w.c 
> b/tests/tcg/mips/mips64-dsp/extrv_r_w.c
> new file mode 100644
> index 0000000..ebe0700
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extrv_r_w.c
> @@ -0,0 +1,31 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0xFFFFFFFFA0001699;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "extrv_r.w %0, $ac1, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(rs), "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    if ((dsp != 1) || (result != rt)) {
> +        printf("extrv_r.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extrv_rs_w.c 
> b/tests/tcg/mips/mips64-dsp/extrv_rs_w.c
> new file mode 100644
> index 0000000..b551f51
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extrv_rs_w.c
> @@ -0,0 +1,31 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0x7FFFFFFF;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "extrv_rs.w %0, $ac1, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(rs), "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    if ((dsp != 1) || (result != rt)) {
> +        printf("extrv_rs.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extrv_s_h.c 
> b/tests/tcg/mips/mips64-dsp/extrv_s_h.c
> new file mode 100644
> index 0000000..a8b3860
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extrv_s_h.c
> @@ -0,0 +1,31 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0x00007FFF;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "extrv_s.h %0, $ac1, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(rs), "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    if ((dsp != 1) || (result != rt)) {
> +        printf("extrv_s.h wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/extrv_w.c 
> b/tests/tcg/mips/mips64-dsp/extrv_w.c
> new file mode 100644
> index 0000000..a553f6b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/extrv_w.c
> @@ -0,0 +1,31 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, ach, acl, dsp;
> +    long long result;
> +
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    dsp = 0x07;
> +    rs  = 0x03;
> +    result = 0xFFFFFFFFA0001699;
> +
> +    __asm
> +        ("wrdsp %1, 0x01\n\t"
> +         "mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "extrv.w %0, $ac1, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rt), "+r"(dsp)
> +         : "r"(rs), "r"(ach), "r"(acl)
> +        );
> +    dsp = (dsp >> 23) & 0x01;
> +    if ((dsp != 1) || (result != rt)) {
> +        printf("extrv.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/head.S 
> b/tests/tcg/mips/mips64-dsp/head.S
> new file mode 100644
> index 0000000..9a099ae
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/head.S
> @@ -0,0 +1,16 @@
> +/*
> + *  Startup Code for MIPS64 CPU-core
> + *
> + */
> +.text
> +.globl _start
> +.align 4
> +_start:
> +    ori    $2, $2, 0xffff
> +    sll    $2, $2, 16
> +    ori    $2, $2, 0xffff
> +    mtc0   $2, $12, 0
> +    jal    main
> +
> +end:
> +    b end
> diff --git a/tests/tcg/mips/mips64-dsp/insv.c 
> b/tests/tcg/mips/mips64-dsp/insv.c
> new file mode 100644
> index 0000000..fc5696f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/insv.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long result;
> +
> +    /* msb = 10, lsb = 5 */
> +    dsp    = 0x305;
> +    rt     = 0x12345678;
> +    rs     = 0xffffffff87654321;
> +    result = 0x12345338;
> +    __asm
> +        ("wrdsp %2, 0x03\n\t"
> +         "insv  %0, %1\n\t"
> +         : "+r"(rt)
> +         : "r"(rs), "r"(dsp)
> +        );
> +    if (rt != result) {
> +        printf("insv wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/io.h b/tests/tcg/mips/mips64-dsp/io.h
> new file mode 100644
> index 0000000..b7db61d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/io.h
> @@ -0,0 +1,22 @@
> +#ifndef _ASM_IO_H
> +#define _ASM_IO_H
> +extern int printf(const char *fmt, ...);
> +extern unsigned long get_ticks(void);
> +
> +#define _read(source)                \
> +({ unsigned long __res;                \
> +    __asm__ __volatile__(            \
> +        "mfc0\t%0, " #source "\n\t"    \
> +        : "=r" (__res));        \
> +    __res;                    \
> +})
> +
> +#define __read(source)                \
> +({ unsigned long __res;                \
> +    __asm__ __volatile__(            \
> +        "move\t%0, " #source "\n\t"    \
> +        : "=r" (__res));        \
> +    __res;                    \
> +})
> +
> +#endif
> diff --git a/tests/tcg/mips/mips64-dsp/lbux.c 
> b/tests/tcg/mips/mips64-dsp/lbux.c
> new file mode 100644
> index 0000000..dbdc87b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/lbux.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long value, rd;
> +    long long *p;
> +    unsigned long long addr, index;
> +    long long result;
> +
> +    value  = 0xBCDEF389;
> +    p = &value;
> +    addr = (unsigned long long)p;
> +    index  = 0;
> +    result = value & 0xFF;
> +    __asm
> +        ("lbux %0, %1(%2)\n\t"
> +         : "=r"(rd)
> +         : "r"(index), "r"(addr)
> +        );
> +    if (rd != result) {
> +        printf("lbux wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/ldx.c b/tests/tcg/mips/mips64-dsp/ldx.c
> new file mode 100644
> index 0000000..787d9f0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/ldx.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long value, rd;
> +    long long *p;
> +    unsigned long long addr, index;
> +    long long result;
> +
> +    value  = 0xBCDEF389;
> +    p = &value;
> +    addr = (unsigned long long)p;
> +    index  = 0;
> +    result = 0xBCDEF389;
> +    __asm
> +        ("ldx %0, %1(%2)\n\t"
> +         : "=r"(rd)
> +         : "r"(index), "r"(addr)
> +        );
> +    if (rd != result) {
> +        printf("lwx wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/lhx.c b/tests/tcg/mips/mips64-dsp/lhx.c
> new file mode 100644
> index 0000000..2020e56
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/lhx.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long value, rd;
> +    long long *p;
> +    unsigned long long addr, index;
> +    long long result;
> +
> +    value  = 0xBCDEF389;
> +    p = &value;
> +    addr = (unsigned long long)p;
> +    index  = 0;
> +    result = 0xFFFFFFFFFFFFF389;
> +    __asm
> +        ("lhx %0, %1(%2)\n\t"
> +         : "=r"(rd)
> +         : "r"(index), "r"(addr)
> +        );
> +    if (rd != result) {
> +        printf("lhx wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/lwx.c b/tests/tcg/mips/mips64-dsp/lwx.c
> new file mode 100644
> index 0000000..6a81414
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/lwx.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long value, rd;
> +    long long *p;
> +    unsigned long long addr, index;
> +    long long result;
> +
> +    value  = 0xBCDEF389;
> +    p = &value;
> +    addr = (unsigned long long)p;
> +    index  = 0;
> +    result = 0xFFFFFFFFBCDEF389;
> +    __asm
> +        ("lwx %0, %1(%2)\n\t"
> +         : "=r"(rd)
> +         : "r"(index), "r"(addr)
> +        );
> +    if (rd != result) {
> +        printf("lwx wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/madd.c 
> b/tests/tcg/mips/mips64-dsp/madd.c
> new file mode 100644
> index 0000000..de6e44f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/madd.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0x01;
> +    rt  = 0x01;
> +    resulth = 0x05;
> +    resultl = 0xB4CC;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "madd $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("madd wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maddu.c 
> b/tests/tcg/mips/mips64-dsp/maddu.c
> new file mode 100644
> index 0000000..e9f426a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maddu.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0x01;
> +    rt  = 0x01;
> +    resulth = 0x05;
> +    resultl = 0xB4CC;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "madd $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("maddu wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_s_l_pwl.c 
> b/tests/tcg/mips/mips64-dsp/maq_s_l_pwl.c
> new file mode 100644
> index 0000000..c196b43
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_s_l_pwl.c
> @@ -0,0 +1,56 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0x98765432FF060000;
> +    rt  = 0xfdeca987CB000000;
> +    resulth = 0x05;
> +    resultl = 0x18278587;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.l.pwl $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("maq_s_l.w.pwl wrong 1\n");
> +
> +        return -1;
> +    }
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0x80000000FF060000;
> +    rt  = 0x80000000CB000000;
> +    resulth = 0x05;
> +    resultl = 0xb4ca;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_s.l.pwl $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("maq_s_l.w.pwl wrong 2\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_s_l_pwr.c 
> b/tests/tcg/mips/mips64-dsp/maq_s_l_pwr.c
> new file mode 100644
> index 0000000..e2af69f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_s_l_pwr.c
> @@ -0,0 +1,56 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0x87898765432;
> +    rt  = 0x7878fdeca987;
> +    resulth = 0x05;
> +    resultl = 0x18278587;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.l.pwr $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("maq_s.w.pwr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0x89899980000000;
> +    rt  = 0x88780000000;
> +    resulth = 0x05;
> +    resultl = 0xb4ca;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_s.l.pwr $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("maq_s.w.pwr wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_phl.c 
> b/tests/tcg/mips/mips64-dsp/maq_s_w_phl.c
> new file mode 100644
> index 0000000..2f511d9
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_s_w_phl.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0xFF060000;
> +    rt  = 0xCB000000;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFF947438CB;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.w.phl $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("maq_s.w.phl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_phr.c 
> b/tests/tcg/mips/mips64-dsp/maq_s_w_phr.c
> new file mode 100644
> index 0000000..4c8f899
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_s_w_phr.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0xFF06;
> +    rt  = 0xCB00;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFF947438CB;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.w.phr $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("maq_s.w.phr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_qhll.c 
> b/tests/tcg/mips/mips64-dsp/maq_s_w_qhll.c
> new file mode 100644
> index 0000000..234a0af
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_s_w_qhll.c
> @@ -0,0 +1,62 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0x05;
> +
> +    rs  = 0x1234888899990000;
> +    rt  = 0x9876888899990000;
> +
> +    resulth = 0x05;
> +    resultl = 0x15ae87f5;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.w.qhll $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("maq_s.w.qhll wrong\n");
> +
> +        return -1;
> +    }
> +
> +
> +    achi = 0x04;
> +    acli = 0x06;
> +    rs  = 0x8000888899990000;
> +    rt  = 0x8000888899990000;
> +
> +    resulth = 0x04;
> +    resultl = 0xffffffff80000005;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_s.w.qhll $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("maq_s.w.qhll wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_qhlr.c 
> b/tests/tcg/mips/mips64-dsp/maq_s_w_qhlr.c
> new file mode 100644
> index 0000000..8768cba
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_s_w_qhlr.c
> @@ -0,0 +1,62 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0x05;
> +
> +    rs  = 0x1234123412340000;
> +    rt  = 0x9876987698760000;
> +
> +    resulth = 0x05;
> +    resultl = 0x15ae87f5;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.w.qhlr $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("1 maq_s.w.qhlr wrong\n");
> +
> +        return -1;
> +    }
> +
> +
> +    achi = 0x04;
> +    acli = 0x06;
> +    rs  = 0x8000800080000000;
> +    rt  = 0x8000800080000000;
> +
> +    resulth = 0x04;
> +    resultl = 0xffffffff80000005;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_s.w.qhlr $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("2 maq_s.w.qhlr wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_qhrl.c 
> b/tests/tcg/mips/mips64-dsp/maq_s_w_qhrl.c
> new file mode 100644
> index 0000000..5006e2b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_s_w_qhrl.c
> @@ -0,0 +1,63 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0x05;
> +
> +    rs  = 0x1234888812340000;
> +    rt  = 0x9876888898760000;
> +
> +    resulth = 0x05;
> +    resultl = 0x15ae87f5;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.w.qhrl $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("1 maq_s.w.qhrl wrong\n");
> +
> +        return -1;
> +    }
> +
> +
> +    achi = 0x04;
> +    acli = 0x06;
> +    rs  = 0x8888999980000000;
> +    rt  = 0x8888999980000000;
> +
> +    resulth = 0x04;
> +    resultl = 0xffffffff80000005;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_s.w.qhrl $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("2 maq_s.w.qhrl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_s_w_qhrr.c 
> b/tests/tcg/mips/mips64-dsp/maq_s_w_qhrr.c
> new file mode 100644
> index 0000000..1d213a5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_s_w_qhrr.c
> @@ -0,0 +1,63 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0x05;
> +
> +    rs  = 0x1234888812341234;
> +    rt  = 0x9876888898769876;
> +
> +    resulth = 0x05;
> +    resultl = 0x15ae87f5;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_s.w.qhrr $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("1 maq_s.w.qhrr wrong\n");
> +
> +        return -1;
> +    }
> +
> +
> +    achi = 0x04;
> +    acli = 0x06;
> +    rs  = 0x8000888899998000;
> +    rt  = 0x8000888899998000;
> +
> +    resulth = 0x04;
> +    resultl = 0xffffffff80000005;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_s.w.qhrr $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("2 maq_s.w.qhrr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_phl.c 
> b/tests/tcg/mips/mips64-dsp/maq_sa_w_phl.c
> new file mode 100644
> index 0000000..b8101f7
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_sa_w_phl.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0xFF060000;
> +    rt  = 0xCB000000;
> +    resulth = 0xFFFFFFFFFFFFFFFF;
> +    resultl = 0xFFFFFFFF947438cb;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_sa.w.phl $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("maq_sa.w.phl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_phr.c 
> b/tests/tcg/mips/mips64-dsp/maq_sa_w_phr.c
> new file mode 100644
> index 0000000..7da8cf6
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_sa_w_phr.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0xB4CB;
> +    rs  = 0xFF06;
> +    rt  = 0xCB00;
> +    resulth = 0xFFFFFFFFFFFFFFFF;
> +    resultl = 0xFFFFFFFF947438cb;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_sa.w.phr $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("maq_sa.w.phr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhll.c 
> b/tests/tcg/mips/mips64-dsp/maq_sa_w_qhll.c
> new file mode 100644
> index 0000000..e467aa2
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_sa_w_qhll.c
> @@ -0,0 +1,62 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0x05;
> +
> +    rs  = 0x1234888899990000;
> +    rt  = 0x9876888899990000;
> +
> +    resulth = 0x00;
> +    resultl = 0x15ae87f5;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "maq_sa.w.qhll $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((resulth != acho) || (resultl != aclo)) {
> +        printf("1 maq_sa.w.qhll wrong\n");
> +
> +        return -1;
> +    }
> +
> +
> +    achi = 0x04;
> +    acli = 0x06;
> +    rs  = 0x8000888899990000;
> +    rt  = 0x8000888899990000;
> +
> +    resulth = 0xffffffffffffffff;
> +    resultl = 0xffffffff80000000;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_sa.w.qhll $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("2 maq_sa.w.qhll wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhlr.c 
> b/tests/tcg/mips/mips64-dsp/maq_sa_w_qhlr.c
> new file mode 100644
> index 0000000..40eefca
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_sa_w_qhlr.c
> @@ -0,0 +1,64 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0x05;
> +
> +    rs  = 0x1234123412340000;
> +    rt  = 0x9876987699990000;
> +
> +    resulth = 0x0;
> +    resultl = 0x15ae87f5;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_sa.w.qhlr $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x0) || (resulth != acho) || (resultl != aclo)) {
> +        printf("maq_sa.w.qhlr wrong\n");
> +
> +        return -1;
> +    }
> +
> +
> +    achi = 0x04;
> +    acli = 0x06;
> +    rs  = 0x8000800099990000;
> +    rt  = 0x8000800099990000;
> +
> +    resulth = 0xffffffffffffffff;
> +    resultl = 0xffffffff80000000;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_sa.w.qhlr $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("maq_sa.w.qhlr wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrl.c 
> b/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrl.c
> new file mode 100644
> index 0000000..0f970fc
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrl.c
> @@ -0,0 +1,64 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0x05;
> +
> +    rs  = 0x1234123412340000;
> +    rt  = 0x9876987698760000;
> +
> +    resulth = 0x0;
> +    resultl = 0x15ae87f5;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_sa.w.qhrl $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x0) || (resulth != acho) || (resultl != aclo)) {
> +        printf("1 maq_sa.w.qhrl wrong\n");
> +
> +        return -1;
> +    }
> +
> +
> +    achi = 0x04;
> +    acli = 0x06;
> +    rs  = 0x8000800080000000;
> +    rt  = 0x8000800080000000;
> +
> +    resulth = 0xffffffffffffffff;
> +    resultl = 0xffffffff80000000;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_sa.w.qhrl $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("2 maq_sa.w.qhrl wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrr.c 
> b/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrr.c
> new file mode 100644
> index 0000000..1f75665
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/maq_sa_w_qhrr.c
> @@ -0,0 +1,64 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    achi = 0x05;
> +    acli = 0x05;
> +
> +    rs  = 0x1234123412341234;
> +    rt  = 0x9876987698769876;
> +
> +    resulth = 0x0;
> +    resultl = 0x15ae87f5;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_sa.w.qhrr $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x0) || (resulth != acho) || (resultl != aclo)) {
> +        printf("1 maq_sa.w.qhrr wrong\n");
> +
> +        return -1;
> +    }
> +
> +
> +    achi = 0x04;
> +    acli = 0x06;
> +    rs  = 0x8000800080008000;
> +    rt  = 0x8000800080008000;
> +
> +    resulth = 0xffffffffffffffff;
> +    resultl = 0xffffffff80000000;
> +
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "maq_sa.w.qhrr $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (resulth != acho) || (resultl != aclo)) {
> +        printf("2 maq_sa.w.qhrr wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mfhi.c 
> b/tests/tcg/mips/mips64-dsp/mfhi.c
> new file mode 100644
> index 0000000..ee915f7
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mfhi.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long achi, acho;
> +    long long result;
> +
> +    achi   = 0x004433;
> +    result = 0x004433;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         : "=r"(acho)
> +         : "r"(achi)
> +        );
> +    if (result != acho) {
> +        printf("mfhi wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mflo.c 
> b/tests/tcg/mips/mips64-dsp/mflo.c
> new file mode 100644
> index 0000000..cdc646b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mflo.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long acli, aclo;
> +    long long result;
> +
> +    acli   = 0x004433;
> +    result = 0x004433;
> +
> +    __asm
> +        ("mtlo %1, $ac1\n\t"
> +         "mflo %0, $ac1\n\t"
> +         : "=r"(aclo)
> +         : "r"(acli)
> +        );
> +    if (result != aclo) {
> +        printf("mflo wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mips_boot.lds 
> b/tests/tcg/mips/mips64-dsp/mips_boot.lds
> new file mode 100644
> index 0000000..bd7c0c0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mips_boot.lds
> @@ -0,0 +1,31 @@
> +OUTPUT_ARCH(mips)
> +SECTIONS
> +{
> +    . = 0xffffffff80100000;
> +    . = ALIGN((1 << 13));
> +    .text :
> +    {
> +        *(.text)
> +        *(.rodata)
> +        *(.rodata.*)
> +    }
> +
> +    __init_begin = .;
> +    . = ALIGN((1 << 12));
> +    .init.text : AT(ADDR(.init.text) - 0)
> +    {
> +        *(.init.text)
> +    }
> +    .init.data : AT(ADDR(.init.data) - 0)
> +    {
> +        *(.init.data)
> +    }
> +    . = ALIGN((1 << 12));
> +    __init_end = .;
> +
> +    . = ALIGN((1 << 13));
> +    .data :
> +    {
> +        *(.data)
> +    }
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/modsub.c 
> b/tests/tcg/mips/mips64-dsp/modsub.c
> new file mode 100644
> index 0000000..2c91cb4
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/modsub.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0xFFFFFFFF;
> +    rt     = 0x000000FF;
> +    result = 0xFFFFFF00;
> +    __asm
> +        ("modsub %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("modsub wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs     = 0x00000000;
> +    rt     = 0x00CD1FFF;
> +    result = 0x0000CD1F;
> +    __asm
> +        ("modsub %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("modsub wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/msub.c 
> b/tests/tcg/mips/mips64-dsp/msub.c
> new file mode 100644
> index 0000000..75066b5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/msub.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long achi, acli, rs, rt;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    rs      = 0x00BBAACC;
> +    rt      = 0x0B1C3D2F;
> +    achi    = 0x00004433;
> +    acli    = 0xFFCC0011;
> +    resulth = 0xFFFFFFFFFFF81F29;
> +    resultl = 0xFFFFFFFFB355089D;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "msub $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((acho != resulth) || (aclo != resultl)) {
> +        printf("msub wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/msubu.c 
> b/tests/tcg/mips/mips64-dsp/msubu.c
> new file mode 100644
> index 0000000..55f8ae0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/msubu.c
> @@ -0,0 +1,32 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long achi, acli, rs, rt;
> +    long long acho, aclo;
> +    long long resulth, resultl;
> +
> +    rs      = 0x00BBAACC;
> +    rt      = 0x0B1C3D2F;
> +    achi    = 0x00004433;
> +    acli    = 0xFFCC0011;
> +    resulth = 0xFFFFFFFFFFF81F29;
> +    resultl = 0xFFFFFFFFB355089D;
> +
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "msubu $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    if ((acho != resulth) || (aclo != resultl)) {
> +        printf("msubu wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mthi.c 
> b/tests/tcg/mips/mips64-dsp/mthi.c
> new file mode 100644
> index 0000000..8570051
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mthi.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long achi, acho;
> +    long long result;
> +
> +    achi   = 0x004433;
> +    result = 0x004433;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         : "=r"(acho)
> +         : "r"(achi)
> +        );
> +    if (result != acho) {
> +        printf("mthi wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mthlip.c 
> b/tests/tcg/mips/mips64-dsp/mthlip.c
> new file mode 100644
> index 0000000..5373bd4
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mthlip.c
> @@ -0,0 +1,35 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, ach, acl, dsp;
> +    long long result, resulth, resultl;
> +
> +    dsp = 0x07;
> +    ach = 0x05;
> +    acl = 0xB4CB;
> +    rs  = 0x00FFBBAA;
> +    resulth = 0xB4CB;
> +    resultl = 0x00FFBBAA;
> +    result  = 0x27;
> +
> +    __asm
> +        ("wrdsp %0, 0x01\n\t"
> +         "mthi %1, $ac1\n\t"
> +         "mtlo %2, $ac1\n\t"
> +         "mthlip %3, $ac1\n\t"
> +         "mfhi %1, $ac1\n\t"
> +         "mflo %2, $ac1\n\t"
> +         "rddsp %0\n\t"
> +         : "+r"(dsp), "+r"(ach), "+r"(acl)
> +         : "r"(rs)
> +        );
> +    dsp = dsp & 0x3F;
> +    if ((dsp != result) || (ach != resulth) || (acl != resultl)) {
> +        printf("mthlip wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mtlo.c 
> b/tests/tcg/mips/mips64-dsp/mtlo.c
> new file mode 100644
> index 0000000..304fffb
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mtlo.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long acli, aclo;
> +    long long result;
> +
> +    acli   = 0x004433;
> +    result = 0x004433;
> +
> +    __asm
> +        ("mthi %1, $ac1\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         : "=r"(aclo)
> +         : "r"(acli)
> +        );
> +    if (result != aclo) {
> +        printf("mtlo wrong\n");
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhl.c 
> b/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhl.c
> new file mode 100644
> index 0000000..be38570
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhl.c
> @@ -0,0 +1,55 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +    rd = 0;
> +    rs = 0x45BCFFFF12345678;
> +    rt = 0x98529AD287654321;
> +    result = 0x52fbec7035a2ca5c;
> +
> +    __asm
> +        ("muleq_s.pw.qhl %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("muleq_s.pw.qhl error\n");
> +
> +        return -1;
> +    }
> +
> +    rd = 0;
> +    rs = 0x45BC800012345678;
> +    rt = 0x9852800087654321;
> +    result = 0x52fbec707FFFFFFF;
> +
> +    __asm
> +        ("muleq_s.pw.qhl %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("muleq_s.pw.qhl dspcontrol overflown flag error\n");
> +
> +        return -1;
> +    }
> +
> +    rd = 0;
> +    __asm
> +        ("rddsp %0\n\t"
> +         : "=r"(rd)
> +        );
> +    rd = rd >> 21;
> +    rd = rd & 0x1;
> +
> +    if (rd != 1) {
> +        printf("muleq_s.pw.qhl dspcontrol bit not set error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhr.c 
> b/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhr.c
> new file mode 100644
> index 0000000..d0a84d4
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/muleq_s_pw_qhr.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +    rd = 0;
> +    rs = 0x1234567845BCFFFF;
> +    rt = 0x8765432198529AD2;
> +    result = 0x52fbec7035a2ca5c;
> +
> +    __asm
> +        ("muleq_s.pw.qhr %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("muleq_s.pw.qhr error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/muleq_s_w_phl.c 
> b/tests/tcg/mips/mips64-dsp/muleq_s_w_phl.c
> new file mode 100644
> index 0000000..76c615b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/muleq_s_w_phl.c
> @@ -0,0 +1,46 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x80009988;
> +    rt = 0x80009988;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if ((rd  != result) || (dsp != resultdsp)) {
> +        printf("muleq_s.w.phr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs = 0x12343322;
> +    rt = 0x43213322;
> +    result = 0x98be968;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if ((rd  != result) || (dsp != resultdsp)) {
> +        printf("muleq_s.w.phr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/muleq_s_w_phr.c 
> b/tests/tcg/mips/mips64-dsp/muleq_s_w_phr.c
> new file mode 100644
> index 0000000..0e59479
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/muleq_s_w_phr.c
> @@ -0,0 +1,45 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x8000;
> +    rt = 0x8000;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phr %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if ((rd  != result) || (dsp != resultdsp)) {
> +        printf("muleq_s.w.phr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    rs = 0x1234;
> +    rt = 0x4321;
> +    result = 0x98be968;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phr %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if ((rd  != result) || (dsp != resultdsp)) {
> +        printf("muleq_s.w.phr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbl.c 
> b/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbl.c
> new file mode 100644
> index 0000000..2f444c9
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbl.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0xFFFFFFFFFFFF0000;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleu_s.ph.qbl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if ((rd  != result) || (dsp != resultdsp)) {
> +        printf("muleu_s.ph.qbl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbr.c 
> b/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbr.c
> new file mode 100644
> index 0000000..8bd0e99
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/muleu_s_ph_qbr.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x8000;
> +    rt = 0x80004321;
> +    result = 0xFFFFFFFFFFFF0000;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleu_s.ph.qbr %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if ((rd  != result) || (dsp != resultdsp)) {
> +        printf("muleu_s.ph.qbr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/muleu_s_qh_obl.c 
> b/tests/tcg/mips/mips64-dsp/muleu_s_qh_obl.c
> new file mode 100644
> index 0000000..63b3ad5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/muleu_s_qh_obl.c
> @@ -0,0 +1,25 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +
> +    rd = 0;
> +    rs = 0x1234567802020202;
> +    rt = 0x0034432112344321;
> +    result = 0x03A8FFFFFFFFFFFF;
> +
> +    __asm
> +        ("muleu_s.qh.obl %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("muleu_s.qh.obl error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/muleu_s_qh_obr.c 
> b/tests/tcg/mips/mips64-dsp/muleu_s_qh_obr.c
> new file mode 100644
> index 0000000..f6289ee
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/muleu_s_qh_obr.c
> @@ -0,0 +1,25 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +
> +    rd = 0;
> +    rs = 0x1234567802020204;
> +    rt = 0x0034432112344321;
> +    result = 0x006886422468FFFF;
> +
> +    __asm
> +        ("muleu_s.qh.obr %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("muleu_s.qh.obr error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mulq_rs_ph.c 
> b/tests/tcg/mips/mips64-dsp/mulq_rs_ph.c
> new file mode 100644
> index 0000000..fd6233d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mulq_rs_ph.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0x7FFF098C;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mulq_rs.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if ((rd  != result) || (dsp != resultdsp)) {
> +        printf("mulq_rs.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mulq_rs_qh.c 
> b/tests/tcg/mips/mips64-dsp/mulq_rs_qh.c
> new file mode 100644
> index 0000000..7863c05
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mulq_rs_qh.c
> @@ -0,0 +1,33 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dsp, dspresult;
> +    rt = 0x80003698CE8F9201;
> +    rs = 0x800034634BCDE321;
> +    result = 0x7fff16587a530313;
> +
> +    dspresult = 0x01;
> +
> +    __asm
> +        ("mulq_rs.qh %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    if (rd != result) {
> +        printf("mulq_rs.qh error\n");
> +
> +        return -1;
> +    }
> +
> +    dsp = (dsp >> 21) & 0x01;
> +    if (dsp != dspresult) {
> +        printf("mulq_rs.qh DSPControl Reg ouflag error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mulsaq_s_l_pw.c 
> b/tests/tcg/mips/mips64-dsp/mulsaq_s_l_pw.c
> new file mode 100644
> index 0000000..02548f8
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mulsaq_s_l_pw.c
> @@ -0,0 +1,59 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resl, resh;
> +
> +    achi = 0x4;
> +    acli = 0x4;
> +
> +    rs = 0x1234567887654321;
> +    rt = 0x8765432112345678;
> +
> +    resh = 0x4;
> +    resl = 0x4;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "mulsaq_s.l.pw $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 mulsaq_s.l.pw wrong\n");
> +
> +        return -1;
> +    }
> +
> +    achi = 0x4;
> +    acli = 0x4;
> +
> +    rs = 0x8000000087654321;
> +    rt = 0x8000000012345678;
> +
> +    resh = 0x4;
> +    resl = 0x1e8ee513;
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "mulsaq_s.l.pw $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (acho != resh) || (aclo != resl)) {
> +        printf("2 mulsaq_s.l.pw wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mulsaq_s_w_qh.c 
> b/tests/tcg/mips/mips64-dsp/mulsaq_s_w_qh.c
> new file mode 100644
> index 0000000..92d7a0b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mulsaq_s_w_qh.c
> @@ -0,0 +1,57 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resl, resh;
> +
> +    achi = 0x4;
> +    acli = 0x4;
> +
> +    rs = 0x5678123443218765;
> +    rt = 0x4321876556781234;
> +
> +    resh = 0x4;
> +    resl = 0x342fcbd4;
> +    __asm
> +        ("mthi %2, $ac1\n\t"
> +         "mtlo %3, $ac1\n\t"
> +         "mulsaq_s.w.qh $ac1, %4, %5\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 mulsaq_s.w.qh wrong\n");
> +        return -1;
> +    }
> +
> +    achi = 0x4;
> +    acli = 0x4;
> +
> +    rs = 0x8000800087654321;
> +    rt = 0x8000800012345678;
> +
> +    resh = 0x3;
> +    resl = 0xffffffffe5e81a1c;
> +    __asm
> +        ("mthi %3, $ac1\n\t"
> +         "mtlo %4, $ac1\n\t"
> +         "mulsaq_s.w.qh $ac1, %5, %6\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "=r"(acho), "=r"(aclo), "=r"(dsp)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x1;
> +    if ((dsp != 0x1) || (acho != resh) || (aclo != resl)) {
> +        printf("2 mulsaq_s.w.qh wrong\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/mult.c 
> b/tests/tcg/mips/mips64-dsp/mult.c
> new file mode 100644
> index 0000000..4a294d1
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/mult.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, ach, acl;
> +    long long result, resulth, resultl;
> +
> +    rs  = 0x00FFBBAA;
> +    rt  = 0x4B231000;
> +    resulth = 0x4b0f01;
> +    resultl = 0x71f8a000;
> +    __asm
> +        ("mult $ac1, %2, %3\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(ach), "=r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("mult wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/multu.c 
> b/tests/tcg/mips/mips64-dsp/multu.c
> new file mode 100644
> index 0000000..ea51cfa
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/multu.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, ach, acl;
> +    long long result, resulth, resultl;
> +
> +    rs  = 0x00FFBBAA;
> +    rt  = 0x4B231000;
> +    resulth = 0x4b0f01;
> +    resultl = 0x71f8a000;
> +    __asm
> +        ("mult $ac1, %2, %3\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "=r"(ach), "=r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("multu wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/packrl_ph.c 
> b/tests/tcg/mips/mips64-dsp/packrl_ph.c
> new file mode 100644
> index 0000000..3722b0a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/packrl_ph.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x56788765;
> +
> +    __asm
> +        ("packrl.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("packrl.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/packrl_pw.c 
> b/tests/tcg/mips/mips64-dsp/packrl_pw.c
> new file mode 100644
> index 0000000..7807418
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/packrl_pw.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long res;
> +
> +    rs = 0x1234567887654321;
> +    rt = 0xabcdef9812345678;
> +
> +    res = 0x87654321abcdef98;
> +
> +    __asm
> +        ("packrl.pw %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != res) {
> +        printf("packrl.pw error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/pick_ob.c 
> b/tests/tcg/mips/mips64-dsp/pick_ob.c
> new file mode 100644
> index 0000000..93bcc85
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/pick_ob.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long res;
> +    dsp = 0xff000000;
> +
> +    rs = 0x1234567812345678;
> +    rt = 0x8765432187654321;
> +
> +    res = 0x1234567812345678;
> +
> +    __asm
> +        ("wrdsp %1, 0x10\n\t"
> +         "pick.ob %0, %2, %3\n\t"
> +         : "=r"(rd)
> +         : "r"(dsp), "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("pick.ob error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/pick_ph.c 
> b/tests/tcg/mips/mips64-dsp/pick_ph.c
> new file mode 100644
> index 0000000..f7bde08
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/pick_ph.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    dsp = 0x0A000000;
> +    result = 0x12344321;
> +
> +    __asm
> +        ("wrdsp %3, 0x10\n\t"
> +         "pick.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt), "r"(dsp)
> +        );
> +    if (rd != result) {
> +        printf("pick.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/pick_pw.c 
> b/tests/tcg/mips/mips64-dsp/pick_pw.c
> new file mode 100644
> index 0000000..277606b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/pick_pw.c
> @@ -0,0 +1,28 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long res;
> +    dsp = 0xff000000;
> +
> +    rs = 0x1234567812345678;
> +    rt = 0x8765432187654321;
> +
> +    res = 0x1234567812345678;
> +
> +    __asm
> +        ("wrdsp %1, 0x10\n\t"
> +         "wrdsp %1\n\t"
> +         "pick.pw %0, %2, %3\n\t"
> +         : "=r"(rd), "+r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("pick.pw error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/pick_qb.c 
> b/tests/tcg/mips/mips64-dsp/pick_qb.c
> new file mode 100644
> index 0000000..b0c4a17
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/pick_qb.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    dsp = 0x0A000000;
> +    result = 0x12655621;
> +
> +    __asm
> +        ("wrdsp %3, 0x10\n\t"
> +         "pick.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt), "r"(dsp)
> +        );
> +    if (rd != result) {
> +        printf("pick.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/pick_qh.c 
> b/tests/tcg/mips/mips64-dsp/pick_qh.c
> new file mode 100644
> index 0000000..11391b5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/pick_qh.c
> @@ -0,0 +1,28 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long res;
> +    dsp = 0xff000000;
> +
> +    rs = 0x1234567812345678;
> +    rt = 0x8765432187654321;
> +
> +    res = 0x1234567812345678;
> +
> +    __asm
> +        ("wrdsp %1, 0x10\n\t"
> +         "wrdsp %1\n\t"
> +         "pick.qh %0, %2, %3\n\t"
> +         : "=r"(rd), "+r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("pick.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceq_l_pwl.c 
> b/tests/tcg/mips/mips64-dsp/preceq_l_pwl.c
> new file mode 100644
> index 0000000..6455100
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceq_l_pwl.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +    rt = 0xFFFFFFFF11111111;
> +    result = 0xFFFFFFFF00000000;
> +
> +    __asm
> +        ("preceq.l.pwl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("preceq.l.pwl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/preceq_l_pwr.c 
> b/tests/tcg/mips/mips64-dsp/preceq_l_pwr.c
> new file mode 100644
> index 0000000..1e05339
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceq_l_pwr.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +    rt = 0xFFFFFFFF11111111;
> +    result = 0x1111111100000000;
> +
> +    __asm
> +        ("preceq.l.pwl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("preceq.l.pwr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/preceq_pw_qhl.c 
> b/tests/tcg/mips/mips64-dsp/preceq_pw_qhl.c
> new file mode 100644
> index 0000000..f44b940
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceq_pw_qhl.c
> @@ -0,0 +1,21 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +    rt = 0x0123456789ABCDEF;
> +    result = 0x0123000045670000;
> +
> +    __asm
> +        ("preceq.pw.qhl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("preceq.pw.qhl error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceq_pw_qhla.c 
> b/tests/tcg/mips/mips64-dsp/preceq_pw_qhla.c
> new file mode 100644
> index 0000000..f0f78f4
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceq_pw_qhla.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x123400009ABC0000;
> +
> +    __asm
> +        ("preceq.pw.qhla %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("preceq.pw.qhla error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceq_pw_qhr.c 
> b/tests/tcg/mips/mips64-dsp/preceq_pw_qhr.c
> new file mode 100644
> index 0000000..709d4f9
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceq_pw_qhr.c
> @@ -0,0 +1,21 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +    rt = 0x0123456789ABCDEF;
> +    result = 0x89AB0000CDEF0000;
> +
> +    __asm
> +        ("preceq.pw.qhr %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("preceq.pw.qhr error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceq_pw_qhra.c 
> b/tests/tcg/mips/mips64-dsp/preceq_pw_qhra.c
> new file mode 100644
> index 0000000..4d071ec
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceq_pw_qhra.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x56780000DEF00000;
> +
> +    __asm
> +        ("preceq.pw.qhra %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("preceq.pw.qhra error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceq_w_phl.c 
> b/tests/tcg/mips/mips64-dsp/preceq_w_phl.c
> new file mode 100644
> index 0000000..4ed3fc0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceq_w_phl.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0xFFFFFFFF87650000;
> +
> +    __asm
> +        ("preceq.w.phl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("preceq.w.phl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceq_w_phr.c 
> b/tests/tcg/mips/mips64-dsp/preceq_w_phr.c
> new file mode 100644
> index 0000000..e2ea093
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceq_w_phr.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0x43210000;
> +
> +    __asm
> +        ("preceq.w.phr %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("preceq.w.phr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precequ_ph_qbl.c 
> b/tests/tcg/mips/mips64-dsp/precequ_ph_qbl.c
> new file mode 100644
> index 0000000..17b7331
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precequ_ph_qbl.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0x43803280;
> +
> +    __asm
> +        ("precequ.ph.qbl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("precequ.ph.qbl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precequ_ph_qbla.c 
> b/tests/tcg/mips/mips64-dsp/precequ_ph_qbla.c
> new file mode 100644
> index 0000000..15e9494
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precequ_ph_qbla.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0x43802180;
> +
> +    __asm
> +        ("precequ.ph.qbla %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("precequ.ph.qbla wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precequ_ph_qbr.c 
> b/tests/tcg/mips/mips64-dsp/precequ_ph_qbr.c
> new file mode 100644
> index 0000000..495368c
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precequ_ph_qbr.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0x21801080;
> +
> +    __asm
> +        ("precequ.ph.qbr %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("precequ.ph.qbr wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precequ_ph_qbra.c 
> b/tests/tcg/mips/mips64-dsp/precequ_ph_qbra.c
> new file mode 100644
> index 0000000..7c66369
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precequ_ph_qbra.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0x32801080;
> +
> +    __asm
> +        ("precequ.ph.qbra %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("precequ.ph.qbra wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precequ_qh_obl.c 
> b/tests/tcg/mips/mips64-dsp/precequ_qh_obl.c
> new file mode 100644
> index 0000000..176d236
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precequ_qh_obl.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x09001A002B003C00;
> +
> +    __asm
> +        ("precequ.qh.obla %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("precequ.qh.obla error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precequ_qh_obla.c 
> b/tests/tcg/mips/mips64-dsp/precequ_qh_obla.c
> new file mode 100644
> index 0000000..93a36a4
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precequ_qh_obla.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x09002B004D006F00;
> +
> +    __asm
> +        ("precequ.qh.obla %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("precequ.qh.obla error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precequ_qh_obr.c 
> b/tests/tcg/mips/mips64-dsp/precequ_qh_obr.c
> new file mode 100644
> index 0000000..1214730
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precequ_qh_obr.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x4D005E006F007000;
> +
> +    __asm
> +        ("precequ.qh.obr %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("precequ.qh.obr error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/precequ_qh_obra.c 
> b/tests/tcg/mips/mips64-dsp/precequ_qh_obra.c
> new file mode 100644
> index 0000000..3aa0e09
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precequ_qh_obra.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x1A003C005D007000;
> +
> +    __asm
> +        ("precequ.qh.obra %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("precequ.qh.obra error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/preceu_ph_qbl.c 
> b/tests/tcg/mips/mips64-dsp/preceu_ph_qbl.c
> new file mode 100644
> index 0000000..81f7917
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceu_ph_qbl.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0x00870065;
> +
> +    __asm
> +        ("preceu.ph.qbl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("preceu.ph.qbl wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceu_ph_qbla.c 
> b/tests/tcg/mips/mips64-dsp/preceu_ph_qbla.c
> new file mode 100644
> index 0000000..38cf6a6
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceu_ph_qbla.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0x00870043;
> +
> +    __asm
> +        ("preceu.ph.qbla %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("preceu.ph.qbla wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceu_ph_qbr.c 
> b/tests/tcg/mips/mips64-dsp/preceu_ph_qbr.c
> new file mode 100644
> index 0000000..70c32b6
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceu_ph_qbr.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0x00430021;
> +
> +    __asm
> +        ("preceu.ph.qbr %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("preceu.ph.qbr wrong");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceu_ph_qbra.c 
> b/tests/tcg/mips/mips64-dsp/preceu_ph_qbra.c
> new file mode 100644
> index 0000000..c6638aa
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceu_ph_qbra.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x87654321;
> +    result = 0x00650021;
> +
> +    __asm
> +        ("preceu.ph.qbra %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("preceu.ph.qbra wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceu_qh_obl.c 
> b/tests/tcg/mips/mips64-dsp/preceu_qh_obl.c
> new file mode 100644
> index 0000000..63f9373
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceu_qh_obl.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x0012003400560078;
> +
> +    __asm
> +        ("preceu.qh.obl %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("preceu.qh.obl error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceu_qh_obla.c 
> b/tests/tcg/mips/mips64-dsp/preceu_qh_obla.c
> new file mode 100644
> index 0000000..5fb65e4
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceu_qh_obla.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x00120056009A00DE;
> +
> +    __asm
> +        ("preceu.qh.obla %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("preceu.qh.obla error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceu_qh_obr.c 
> b/tests/tcg/mips/mips64-dsp/preceu_qh_obr.c
> new file mode 100644
> index 0000000..9af3b63
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceu_qh_obr.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x009A00BC00DE00F0;
> +
> +    __asm
> +        ("preceu.qh.obr %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("preceu.qh.obr error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/preceu_qh_obra.c 
> b/tests/tcg/mips/mips64-dsp/preceu_qh_obra.c
> new file mode 100644
> index 0000000..fd04083
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/preceu_qh_obra.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x0034007800BC00F0;
> +
> +    __asm
> +        ("preceu.qh.obra %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("preceu.qh.obra error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precr_ob_qh.c 
> b/tests/tcg/mips/mips64-dsp/precr_ob_qh.c
> new file mode 100644
> index 0000000..ce2da79
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precr_ob_qh.c
> @@ -0,0 +1,25 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long res;
> +
> +    rs = 0x1234567812345678;
> +    rt = 0x8765432187654321;
> +
> +    res = 0x3478347865216521;
> +
> +    __asm
> +        ("precr.ob.qh %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("precr.ob.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precr_sra_qh_pw.c 
> b/tests/tcg/mips/mips64-dsp/precr_sra_qh_pw.c
> new file mode 100644
> index 0000000..8bb16de
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precr_sra_qh_pw.c
> @@ -0,0 +1,40 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long res;
> +
> +    rt = 0x8765432187654321;
> +    rs = 0x1234567812345678;
> +
> +    res = 0x4321432156785678;
> +
> +    __asm
> +        ("precr_sra.qh.pw %0, %1, 0x0\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("precr_sra.qh.pw error\n");
> +        return -1;
> +    }
> +
> +    rt = 0x8765432187654321;
> +    rs = 0x1234567812345678;
> +
> +    res = 0x5432543245674567;
> +
> +    __asm
> +        ("precr_sra.qh.pw %0, %1, 0x4\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("precr_sra.qh.pw error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precr_sra_r_qh_pw.c 
> b/tests/tcg/mips/mips64-dsp/precr_sra_r_qh_pw.c
> new file mode 100644
> index 0000000..734ac32
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precr_sra_r_qh_pw.c
> @@ -0,0 +1,40 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long res;
> +
> +    rt = 0x8765432187654321;
> +    rs = 0x1234567812345678;
> +
> +    res = 0x4321432156785678;
> +
> +    __asm
> +        ("precr_sra_r.qh.pw %0, %1, 0x0\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("precr_sra_r.qh.pw error\n");
> +        return -1;
> +    }
> +
> +    rt = 0x8765432187654321;
> +    rs = 0x1234567812345678;
> +
> +    res = 0x5432543245684568;
> +
> +    __asm
> +        ("precr_sra_r.qh.pw %0, %1, 0x4\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("precr_sra_r.qh.pw error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precrq_ob_qh.c 
> b/tests/tcg/mips/mips64-dsp/precrq_ob_qh.c
> new file mode 100644
> index 0000000..4f61b17
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precrq_ob_qh.c
> @@ -0,0 +1,25 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long res;
> +
> +    rs = 0x1234567812345678;
> +    rt = 0x8765432187654321;
> +
> +    res = 0x1256125687438743;
> +
> +    __asm
> +        ("precrq.ob.qh %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("precrq.ob.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precrq_ph_w.c 
> b/tests/tcg/mips/mips64-dsp/precrq_ph_w.c
> new file mode 100644
> index 0000000..f0946ab
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precrq_ph_w.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x12348765;
> +
> +    __asm
> +        ("precrq.ph.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("precrq.ph.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precrq_pw_l.c 
> b/tests/tcg/mips/mips64-dsp/precrq_pw_l.c
> new file mode 100644
> index 0000000..da957c0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precrq_pw_l.c
> @@ -0,0 +1,25 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long res;
> +
> +    rs = 0x1234567812345678;
> +    rt = 0x8765432187654321;
> +
> +    res = 0x1234567887654321;
> +
> +    __asm
> +        ("precrq.pw.l %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("precrq.pw.l error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precrq_qb_ph.c 
> b/tests/tcg/mips/mips64-dsp/precrq_qb_ph.c
> new file mode 100644
> index 0000000..f417c9f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precrq_qb_ph.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x12568743;
> +
> +    __asm
> +        ("precrq.qb.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("precrq.qb.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precrq_qh_pw.c 
> b/tests/tcg/mips/mips64-dsp/precrq_qh_pw.c
> new file mode 100644
> index 0000000..4a4ffef
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precrq_qh_pw.c
> @@ -0,0 +1,25 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long res;
> +
> +    rs = 0x1234567812345678;
> +    rt = 0x8765432187654321;
> +
> +    res = 0x1234123487658765;
> +
> +    __asm
> +        ("precrq.qh.pw %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("precrq.qh.pw error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precrq_rs_ph_w.c 
> b/tests/tcg/mips/mips64-dsp/precrq_rs_ph_w.c
> new file mode 100644
> index 0000000..42e674b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precrq_rs_ph_w.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x12348765;
> +
> +    __asm
> +        ("precrq_rs.ph.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("precrq_rs.ph.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precrq_rs_qh_pw.c 
> b/tests/tcg/mips/mips64-dsp/precrq_rs_qh_pw.c
> new file mode 100644
> index 0000000..9826510
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precrq_rs_qh_pw.c
> @@ -0,0 +1,25 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long res;
> +
> +    rs = 0x1234567812345678;
> +    rt = 0x8765432187654321;
> +
> +    res = 0x1234123487658765;
> +
> +    __asm
> +        ("precrq_rs.qh.pw %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("precrq_rs.qh.pw error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precrqu_s_ob_qh.c 
> b/tests/tcg/mips/mips64-dsp/precrqu_s_ob_qh.c
> new file mode 100644
> index 0000000..dc8a643
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precrqu_s_ob_qh.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long res, resdsp;
> +
> +    rs = 0x1234567812345678;
> +    rt = 0x8765432187654321;
> +
> +    res = 0x24ac24ac00860086;
> +    resdsp = 0x1;
> +
> +    __asm
> +        ("precrqu_s.ob.qh %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 22) & 0x1;
> +    if ((rd != res) || (dsp != resdsp)) {
> +        printf("precrq_s.ob.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/precrqu_s_qb_ph.c 
> b/tests/tcg/mips/mips64-dsp/precrqu_s_qb_ph.c
> new file mode 100644
> index 0000000..a3ab898
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/precrqu_s_qb_ph.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x24AC0086;
> +
> +    __asm
> +        ("precrqu_s.qb.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("precrqu_s.qb.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/prependd.c 
> b/tests/tcg/mips/mips64-dsp/prependd.c
> new file mode 100644
> index 0000000..b4208c2
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/prependd.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long res;
> +    rt = 0x1234567887654321;
> +    rs = 0xabcd1234abcd8765;
> +
> +    res = 0x1234567887654321;
> +    __asm
> +        ("prependd %0, %1, 0x0\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("prependd error\n");
> +        return -1;
> +    }
> +
> +    rt = 0x1234567887654321;
> +    rs = 0xabcd1234abcd8765;
> +
> +    res = 0xd876512345678876;
> +    __asm
> +        ("prependd %0, %1, 0x4\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("prependd error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/prependw.c 
> b/tests/tcg/mips/mips64-dsp/prependw.c
> new file mode 100644
> index 0000000..d91bd20
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/prependw.c
> @@ -0,0 +1,37 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long res;
> +    rt = 0x1234567887654321;
> +    rs = 0xabcd1234abcd8765;
> +
> +    res = 0x1234567887654321;
> +    __asm
> +        ("prependw %0, %1, 0x0\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("prependw error\n");
> +        return -1;
> +    }
> +
> +    rt = 0x1234567887654321;
> +    rs = 0xabcd1234abcd8765;
> +
> +    res = 0x5123456788765432;
> +    __asm
> +        ("prependw %0, %1, 0x4\n\t"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("prependw error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/printf.c 
> b/tests/tcg/mips/mips64-dsp/printf.c
> new file mode 100644
> index 0000000..cf8676d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/printf.c
> @@ -0,0 +1,266 @@
> +
> +typedef unsigned long va_list;
> +
> +#define ACC    4
> +#define __read(source)                    \
> +({ va_list __res;                    \
> +    __asm__ __volatile__(                \
> +        "move\t%0, " #source "\n\t"        \
> +        : "=r" (__res));            \
> +    __res;                        \
> +})
> +
> +enum format_type {
> +    FORMAT_TYPE_NONE,
> +    FORMAT_TYPE_HEX,
> +    FORMAT_TYPE_ULONG,
> +    FORMAT_TYPE_FLOAT
> +};
> +
> +struct printf_spec {
> +    char    type;
> +};
> +
> +static int format_decode(char *fmt, struct printf_spec *spec)
> +{
> +    char *start = fmt;
> +
> +    for (; *fmt ; ++fmt) {
> +        if (*fmt == '%') {
> +            break;
> +        }
> +    }
> +
> +    switch (*++fmt) {
> +    case 'x':
> +        spec->type = FORMAT_TYPE_HEX;
> +        break;
> +
> +    case 'd':
> +        spec->type = FORMAT_TYPE_ULONG;
> +        break;
> +
> +    case 'f':
> +        spec->type = FORMAT_TYPE_FLOAT;
> +        break;
> +
> +    default:
> +        spec->type = FORMAT_TYPE_NONE;
> +    }
> +
> +    return ++fmt - start;
> +}
> +
> +void *memcpy(void *dest, void *src, int n)
> +{
> +    int i;
> +    char *s = src;
> +    char *d = dest;
> +
> +    for (i = 0; i < n; i++) {
> +        d[i] = s[i];
> +    }
> +    return dest;
> +}
> +
> +char *number(char *buf, va_list num)
> +{
> +    int i;
> +    char *str = buf;
> +    static char digits[16] = "0123456789abcdef";
> +    str = str + sizeof(num) * 2;
> +
> +    for (i = 0; i < sizeof(num) * 2; i++) {
> +        *--str = digits[num & 15];
> +        num >>= 4;
> +    }
> +
> +    return buf + sizeof(num) * 2;
> +}
> +
> +char *__number(char *buf, va_list num)
> +{
> +    int i;
> +    va_list mm = num;
> +    char *str = buf;
> +
> +    if (!num) {
> +        *str++ = '0';
> +        return str;
> +    }
> +
> +    for (i = 0; mm; mm = mm/10, i++) {
> +        /* Do nothing. */
> +    }
> +
> +    str = str + i;
> +
> +    while (num) {
> +        *--str = num % 10 + 48;
> +        num = num / 10;
> +    }
> +
> +    return str + i;
> +}
> +
> +va_list modf(va_list args, va_list *integer, va_list *num)
> +{
> +    int i;
> +    double dot_v = 0;
> +    va_list E, DOT, DOT_V;
> +
> +    if (!args) {
> +        return 0;
> +    }
> +
> +    for (i = 0, args = args << 1 >> 1; i < 52; i++) {
> +        if ((args >> i) & 0x1) {
> +            break;
> +        }
> +    }
> +
> +    *integer = 0;
> +
> +    if ((args >> 56 != 0x3f) || (args >> 52 == 0x3ff)) {
> +        E = (args >> 52) - 1023;
> +        DOT = 52 - E - i;
> +        DOT_V = args << (12 + E) >> (12 + E) >> i;
> +        *integer = ((args << 12 >> 12) >> (i + DOT)) | (1 << E);
> +    } else {
> +        E = ~((args >> 52) - 1023) + 1;
> +        DOT_V = args << 12 >> 12;
> +
> +        dot_v += 1.0 / (1 << E);
> +
> +        for (i = 1; i <= 16; i++) {
> +            if ((DOT_V >> (52 - i)) & 0x1) {
> +                dot_v += 1.0 / (1 << E + i);
> +            }
> +        }
> +
> +        for (i = 1, E = 0; i <= ACC; i++) {
> +            dot_v *= 10;
> +            if (!(va_list)dot_v) {
> +                E++;
> +            }
> +    }
> +
> +    *num = E;
> +
> +    return dot_v;
> +    }
> +
> +    if (args & 0xf) {
> +        for (i = 1; i <= 16; i++) {
> +            if ((DOT_V >> (DOT - i)) & 0x1) {
> +                dot_v += 1.0 / (1 << i);
> +            }
> +        }
> +
> +        for (i = 1, E = 0; i <= ACC; i++) {
> +            dot_v *= 10;
> +            if (!(va_list)dot_v) {
> +                E++;
> +            }
> +        }
> +
> +        *num = E;
> +
> +        return dot_v;
> +    } else if (DOT) {
> +        for (i = 1; i <= DOT; i++) {
> +            if ((DOT_V >> (DOT - i)) & 0x1) {
> +                dot_v += 1.0 / (1 << i);
> +            }
> +        }
> +
> +        for (i = 1; i <= ACC; i++) {
> +            dot_v = dot_v * 10;
> +        }
> +
> +    return dot_v;
> +    }
> +
> +    return 0;
> +}
> +
> +int vsnprintf(char *buf, int size, char *fmt, va_list args)
> +{
> +    char *str, *mm;
> +    struct printf_spec spec = {0};
> +
> +    str = mm = buf;
> +
> +    while (*fmt) {
> +        char *old_fmt = fmt;
> +        int read = format_decode(fmt, &spec);
> +
> +        fmt += read;
> +
> +        switch (spec.type) {
> +        case FORMAT_TYPE_NONE: {
> +            memcpy(str, old_fmt, read);
> +            str += read;
> +            break;
> +        }
> +        case FORMAT_TYPE_HEX: {
> +            memcpy(str, old_fmt, read);
> +            str = number(str + read, args);
> +            for (; *mm ; ++mm) {
> +                if (*mm == '%') {
> +                    *mm = '0';
> +                break;
> +                }
> +            }
> +        break;
> +        }
> +        case FORMAT_TYPE_ULONG: {
> +            memcpy(str, old_fmt, read - 2);
> +            str = __number(str + read - 2, args);
> +            break;
> +        }
> +        case FORMAT_TYPE_FLOAT: {
> +            va_list integer, dot_v, num;
> +            dot_v = modf(args, &integer, &num);
> +            memcpy(str, old_fmt, read - 2);
> +            str += read - 2;
> +            if ((args >> 63 & 0x1)) {
> +                *str++ = '-';
> +            }
> +            str = __number(str, integer);
> +            if (dot_v) {
> +                *str++ = '.';
> +                while (num--) {
> +                    *str++ = '0';
> +                }
> +                str = __number(str, dot_v);
> +            }
> +            break;
> +        }
> +        }
> +    }
> +    *str = '\0';
> +
> +    return str - buf;
> +}
> +
> +static void serial_out(char *str)
> +{
> +    while (*str) {
> +        *(char *)0xffffffffb80003f8 = *str++;
> +    }
> +}
> +
> +int vprintf(char *fmt, va_list args)
> +{
> +    int printed_len = 0;
> +    static char printf_buf[512];
> +    printed_len = vsnprintf(printf_buf, sizeof(printf_buf), fmt, args);
> +    serial_out(printf_buf);
> +    return printed_len;
> +}
> +
> +int printf(char *fmt, ...)
> +{
> +    return vprintf(fmt, __read($5));
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/raddu_l_ob.c 
> b/tests/tcg/mips/mips64-dsp/raddu_l_ob.c
> new file mode 100644
> index 0000000..76ddf25
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/raddu_l_ob.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, result;
> +    rs = 0x12345678ABCDEF0;
> +    result = 0x000000000001E258;
> +
> +    __asm
> +        ("raddu.l.ob %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs)
> +        );
> +
> +    if (rd != result) {
> +        printf("raddu.l.ob error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/raddu_w_qb.c 
> b/tests/tcg/mips/mips64-dsp/raddu_w_qb.c
> new file mode 100644
> index 0000000..c9d6535
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/raddu_w_qb.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    result = 0x114;
> +
> +    __asm
> +        ("raddu.w.qb %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("raddu.w.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/rddsp.c 
> b/tests/tcg/mips/mips64-dsp/rddsp.c
> new file mode 100644
> index 0000000..7165572
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/rddsp.c
> @@ -0,0 +1,53 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long dsp_i, dsp_o;
> +    long long ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i;
> +    long long ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o;
> +    long long ccond_r, outflag_r, efi_r, c_r, scount_r, pos_r;
> +
> +    ccond_i   = 0x000000BC;/* 4 */
> +    outflag_i = 0x0000001B;/* 3 */
> +    efi_i     = 0x00000001;/* 5 */
> +    c_i       = 0x00000001;/* 2 */
> +    scount_i  = 0x0000000F;/* 1 */
> +    pos_i     = 0x0000000C;/* 0 */
> +
> +    dsp_i = (ccond_i   << 24) | \
> +            (outflag_i << 16) | \
> +            (efi_i     << 14) | \
> +            (c_i       << 13) | \
> +            (scount_i  <<  7) | \
> +            pos_i;
> +
> +    ccond_r   = ccond_i;
> +    outflag_r = outflag_i;
> +    efi_r     = efi_i;
> +    c_r       = c_i;
> +    scount_r  = scount_i;
> +    pos_r     = pos_i;
> +
> +    __asm
> +        ("wrdsp %1, 0x3F\n\t"
> +         "rddsp %0, 0x3F\n\t"
> +         : "=r"(dsp_o)
> +         : "r"(dsp_i)
> +        );
> +
> +    ccond_o   = (dsp_o >> 24) & 0xFF;
> +    outflag_o = (dsp_o >> 16) & 0xFF;
> +    efi_o     = (dsp_o >> 14) & 0x01;
> +    c_o       = (dsp_o >> 14) & 0x01;
> +    scount_o  = (dsp_o >>  7) & 0x3F;
> +    pos_o     =  dsp_o & 0x1F;
> +
> +    if ((ccond_o != ccond_r) || (outflag_o != outflag_r) || (efi_o != efi_r) 
> \
> +            || (c_o != c_r) || (scount_o != scount_r) || (pos_o != pos_r)) {
> +        printf("rddsp wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/repl_ob.c 
> b/tests/tcg/mips/mips64-dsp/repl_ob.c
> new file mode 100644
> index 0000000..20cb780
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/repl_ob.c
> @@ -0,0 +1,21 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, result;
> +    rd = 0;
> +    result = 0xFFFFFFFFFFFFFFFF;
> +
> +    __asm
> +        ("repl.ob %0, 0xFF\n\t"
> +         : "=r"(rd)
> +        );
> +
> +    if (result != rd) {
> +        printf("repl.ob error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/repl_ph.c 
> b/tests/tcg/mips/mips64-dsp/repl_ph.c
> new file mode 100644
> index 0000000..11d29bd
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/repl_ph.c
> @@ -0,0 +1,30 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, result;
> +
> +    result = 0x01BF01BF;
> +    __asm
> +        ("repl.ph %0, 0x1BF\n\t"
> +         : "=r"(rd)
> +        );
> +    if (rd != result) {
> +        printf("repl.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    result = 0x01FF01FF;
> +    __asm
> +        ("repl.ph %0, 0x01FF\n\t"
> +         : "=r"(rd)
> +        );
> +    if (rd != result) {
> +        printf("repl.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/repl_pw.c 
> b/tests/tcg/mips/mips64-dsp/repl_pw.c
> new file mode 100644
> index 0000000..d35376a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/repl_pw.c
> @@ -0,0 +1,34 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, result;
> +    rd = 0;
> +    result = 0x000001FF000001FF;
> +
> +    __asm
> +        ("repl.pw %0, 0x1FF\n\t"
> +         : "=r"(rd)
> +        );
> +
> +    if (result != rd) {
> +        printf("repl.pw error1\n");
> +
> +        return -1;
> +    }
> +
> +    rd = 0;
> +    result = 0xFFFFFE00FFFFFE00;
> +    __asm
> +        ("repl.pw %0, 0xFFFFFFFFFFFFFE00\n\t"
> +         : "=r"(rd)
> +        );
> +
> +    if (result != rd) {
> +        printf("repl.pw error2\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/repl_qb.c 
> b/tests/tcg/mips/mips64-dsp/repl_qb.c
> new file mode 100644
> index 0000000..592feae
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/repl_qb.c
> @@ -0,0 +1,19 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, result;
> +
> +    result = 0xFFFFFFFFBFBFBFBF;
> +    __asm
> +        ("repl.qb %0, 0xBF\n\t"
> +         : "=r"(rd)
> +        );
> +    if (rd != result) {
> +        printf("repl.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/repl_qh.c 
> b/tests/tcg/mips/mips64-dsp/repl_qh.c
> new file mode 100644
> index 0000000..82afc37
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/repl_qh.c
> @@ -0,0 +1,34 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, result;
> +    rd = 0;
> +    result = 0x01FF01FF01FF01FF;
> +
> +    __asm
> +        ("repl.qh %0, 0x1FF\n\t"
> +         : "=r"(rd)
> +        );
> +
> +    if (result != rd) {
> +        printf("repl.qh error 1\n");
> +
> +        return -1;
> +    }
> +
> +    rd = 0;
> +    result = 0xFE00FE00FE00FE00;
> +    __asm
> +        ("repl.qh %0, 0xFFFFFFFFFFFFFE00\n\t"
> +         : "=r"(rd)
> +        );
> +
> +    if (result != rd) {
> +        printf("repl.qh error 2\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/replv_ob.c 
> b/tests/tcg/mips/mips64-dsp/replv_ob.c
> new file mode 100644
> index 0000000..31ff318
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/replv_ob.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +
> +    rt = 0xFF;
> +    result = 0xFFFFFFFFFFFFFFFF;
> +
> +    __asm
> +        ("replv.ob %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("replv.ob error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/replv_ph.c 
> b/tests/tcg/mips/mips64-dsp/replv_ph.c
> new file mode 100644
> index 0000000..0af7a36
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/replv_ph.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x12345678;
> +    result = 0x56785678;
> +    __asm
> +        ("replv.ph %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("replv.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/replv_pw.c 
> b/tests/tcg/mips/mips64-dsp/replv_pw.c
> new file mode 100644
> index 0000000..e1789af
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/replv_pw.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, result;
> +    rd = 0;
> +    rt = 0xFFFFFFFF;
> +    result = 0xFFFFFFFFFFFFFFFF;
> +
> +    __asm
> +        ("replv.pw %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (result != rd) {
> +        printf("replv.pw error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/replv_qb.c 
> b/tests/tcg/mips/mips64-dsp/replv_qb.c
> new file mode 100644
> index 0000000..d99298c
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/replv_qb.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt     = 0x12345678;
> +    result = 0x78787878;
> +    __asm
> +        ("replv.qb %0, %1\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("replv.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shilo.c 
> b/tests/tcg/mips/mips64-dsp/shilo.c
> new file mode 100644
> index 0000000..5f454f6
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shilo.c
> @@ -0,0 +1,29 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long ach, acl;
> +    long long resulth, resultl;
> +
> +    ach = 0xBBAACCFF;
> +    acl = 0x1C3B001D;
> +
> +    resulth = 0x17755;
> +    resultl = 0xFFFFFFFF99fe3876;
> +
> +    __asm
> +        ("mthi %0, $ac1\n\t"
> +         "mtlo %1, $ac1\n\t"
> +         "shilo $ac1, 0x0F\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +        );
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("shilo wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shilov.c 
> b/tests/tcg/mips/mips64-dsp/shilov.c
> new file mode 100644
> index 0000000..e82615a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shilov.c
> @@ -0,0 +1,31 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, ach, acl;
> +    long long resulth, resultl;
> +
> +    rs  = 0x0F;
> +    ach = 0xBBAACCFF;
> +    acl = 0x1C3B001D;
> +
> +    resulth = 0x17755;
> +    resultl = 0xFFFFFFFF99fe3876;
> +
> +    __asm
> +        ("mthi %0, $ac1\n\t"
> +         "mtlo %1, $ac1\n\t"
> +         "shilov $ac1, %2\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs)
> +        );
> +    if ((ach != resulth) || (acl != resultl)) {
> +        printf("shilov wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shll_ob.c 
> b/tests/tcg/mips/mips64-dsp/shll_ob.c
> new file mode 100644
> index 0000000..de9e6d0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shll_ob.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, dsp;
> +    long long res, resdsp;
> +
> +    rt = 0x9ba8765433456789;
> +    res = 0xd840b0a098283848;
> +    resdsp = 0x1;
> +    __asm
> +        ("shll.ob %0, %2, 0x3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x1;
> +
> +    if ((dsp != resdsp) || (rd != res)) {
> +        printf("shll.ob error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shll_ph.c 
> b/tests/tcg/mips/mips64-dsp/shll_ph.c
> new file mode 100644
> index 0000000..2a30c1a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shll_ph.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x12345678;
> +    result    = 0xFFFFFFFFA000C000;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shll.ph %0, %2, 0x0B\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shll.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shll_pw.c 
> b/tests/tcg/mips/mips64-dsp/shll_pw.c
> new file mode 100644
> index 0000000..63dbae5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shll_pw.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x8765432112345678;
> +    result    = 0x6543210034567800;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shll.pw %0, %2, 0x8\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shll.pw wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shll_qb.c 
> b/tests/tcg/mips/mips64-dsp/shll_qb.c
> new file mode 100644
> index 0000000..c21ab66
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shll_qb.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rt     = 0x87654321;
> +    result = 0x38281808;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shll.qb %0, %2, 0x03\n\t"
> +         "rddsp   %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    if (rd != result) {
> +        printf("shll.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shll_qh.c 
> b/tests/tcg/mips/mips64-dsp/shll_qh.c
> new file mode 100644
> index 0000000..067a6e5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shll_qh.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, dsp;
> +    long long res, resdsp;
> +
> +    rt = 0x9ba8765433456789;
> +    res = 0xdd40b2a09a283c48;
> +    resdsp = 0x1;
> +    __asm
> +        ("shll.qh %0, %2, 0x3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x1;
> +
> +    if ((dsp != resdsp) || (rd != res)) {
> +        printf("shll.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shll_s_ph.c 
> b/tests/tcg/mips/mips64-dsp/shll_s_ph.c
> new file mode 100644
> index 0000000..3d96f6e
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shll_s_ph.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x12345678;
> +    result    = 0x7FFF7FFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shll_s.ph %0, %2, 0x0B\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shll_s.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shll_s_pw.c 
> b/tests/tcg/mips/mips64-dsp/shll_s_pw.c
> new file mode 100644
> index 0000000..e5190ed
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shll_s_pw.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x8765432112345678;
> +    result    = 0x800000007fffffff;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shll_s.pw %0, %2, 0x8\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shll_s.pw wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shll_s_qh.c 
> b/tests/tcg/mips/mips64-dsp/shll_s_qh.c
> new file mode 100644
> index 0000000..eae0fd9
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shll_s_qh.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, dsp;
> +    long long res, resdsp;
> +
> +    rt = 0x9ba8765433456789;
> +    res = 0x80007fff7fff7fff;
> +    resdsp = 0x1;
> +    __asm
> +        ("shll_s.qh %0, %2, 0x3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x1;
> +
> +    if ((dsp != resdsp) || (rd != res)) {
> +        printf("shll_s.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shll_s_w.c 
> b/tests/tcg/mips/mips64-dsp/shll_s_w.c
> new file mode 100644
> index 0000000..5780061
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shll_s_w.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x12345678;
> +    result    = 0x7FFFFFFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shll_s.w %0, %2, 0x0B\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shll_s.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shllv_ob.c 
> b/tests/tcg/mips/mips64-dsp/shllv_ob.c
> new file mode 100644
> index 0000000..fe9bd4e
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shllv_ob.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x8765432112345678;
> +    rs = 0x4;
> +    result    = 0x7050301020406080;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shllv.ob %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shllv.ob wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shllv_ph.c 
> b/tests/tcg/mips/mips64-dsp/shllv_ph.c
> new file mode 100644
> index 0000000..532291f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shllv_ph.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs        = 0x0B;
> +    rt        = 0x12345678;
> +    result    = 0xFFFFFFFFA000C000;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shllv.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shllv.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shllv_pw.c 
> b/tests/tcg/mips/mips64-dsp/shllv_pw.c
> new file mode 100644
> index 0000000..59bf607
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shllv_pw.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x8765432112345678;
> +    rs = 0x8;
> +    result    = 0x6543210034567800;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shllv.pw %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shllv.pw wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shllv_qb.c 
> b/tests/tcg/mips/mips64-dsp/shllv_qb.c
> new file mode 100644
> index 0000000..e49356b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shllv_qb.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs     = 0x03;
> +    rt     = 0x87654321;
> +    result = 0x38281808;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shllv.qb %0, %2, %3\n\t"
> +         "rddsp   %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    if (rd != result) {
> +        printf("shllv.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shllv_qh.c 
> b/tests/tcg/mips/mips64-dsp/shllv_qh.c
> new file mode 100644
> index 0000000..2ba3ef1
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shllv_qh.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x8765432112345678;
> +    rs = 0x4;
> +    result    = 0x7650321023406780;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shllv.qh %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shllv.qh wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shllv_s_ph.c 
> b/tests/tcg/mips/mips64-dsp/shllv_s_ph.c
> new file mode 100644
> index 0000000..7e69f94
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shllv_s_ph.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs        = 0x0B;
> +    rt        = 0x12345678;
> +    result    = 0x7FFF7FFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shllv_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shllv_s.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shllv_s_pw.c 
> b/tests/tcg/mips/mips64-dsp/shllv_s_pw.c
> new file mode 100644
> index 0000000..215fc80
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shllv_s_pw.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x8765432112345678;
> +    rs = 0x8;
> +    result    = 0x800000007fffffff;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shllv_s.pw %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shllv_s.pw wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shllv_s_qh.c 
> b/tests/tcg/mips/mips64-dsp/shllv_s_qh.c
> new file mode 100644
> index 0000000..ff2c868
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shllv_s_qh.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs, dsp;
> +    long long result, resultdsp;
> +
> +    rt        = 0x8765432112345678;
> +    rs = 0x4;
> +    result    = 0x80007fff7fff7fff;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("shllv_s.qh %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shllv_s.qh wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shllv_s_w.c 
> b/tests/tcg/mips/mips64-dsp/shllv_s_w.c
> new file mode 100644
> index 0000000..5f6af8b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shllv_s_w.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs        = 0x0B;
> +    rt        = 0x12345678;
> +    result    = 0x7FFFFFFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("shllv_s.w %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rt), "r"(rs)
> +        );
> +    dsp = (dsp >> 22) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("shllv_s.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shra_ob.c 
> b/tests/tcg/mips/mips64-dsp/shra_ob.c
> new file mode 100644
> index 0000000..95f0724
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shra_ob.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main()
> +{
> +    long long rd, rt;
> +    long long res;
> +
> +    rt = 0xbc98756abc654389;
> +    res = 0xfbf9f7f6fb0604f8;
> +
> +    __asm
> +        ("shra.ob %0, %1, 0x4\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("shra.ob error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shra_ph.c 
> b/tests/tcg/mips/mips64-dsp/shra_ph.c
> new file mode 100644
> index 0000000..a2dc014
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shra_ph.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt     = 0x87654321;
> +    result = 0xFFFFFFFFF0EC0864;
> +
> +    __asm
> +        ("shra.ph %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("shra.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shra_pw.c 
> b/tests/tcg/mips/mips64-dsp/shra_pw.c
> new file mode 100644
> index 0000000..693b7d5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shra_pw.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long res;
> +
> +    rt = 0x1234567887654321;
> +    res = 0x01234567f8765432;
> +
> +    __asm
> +        ("shra.pw %0, %1, 0x4"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("shra.pw error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shra_qh.c 
> b/tests/tcg/mips/mips64-dsp/shra_qh.c
> new file mode 100644
> index 0000000..89dd370
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shra_qh.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long res;
> +
> +    rt = 0x8512345654323454;
> +
> +    res = 0xf851034505430345;
> +
> +    __asm
> +        ("shra.qh %0, %1, 0x4\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("shra.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shra_r_ob.c 
> b/tests/tcg/mips/mips64-dsp/shra_r_ob.c
> new file mode 100644
> index 0000000..1847094
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shra_r_ob.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main()
> +{
> +    long long rd, rt;
> +    long long res;
> +
> +    rt = 0xbc98756abc654389;
> +    res = 0xfcfaf8f7fc0705f9;
> +
> +    __asm
> +        ("shra_r.ob %0, %1, 0x4\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("shra_r.ob error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shra_r_ph.c 
> b/tests/tcg/mips/mips64-dsp/shra_r_ph.c
> new file mode 100644
> index 0000000..e0943ad
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shra_r_ph.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt     = 0x87654321;
> +    result = 0xFFFFFFFFF0ED0864;
> +
> +    __asm
> +        ("shra_r.ph %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("shra_r.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shra_r_pw.c 
> b/tests/tcg/mips/mips64-dsp/shra_r_pw.c
> new file mode 100644
> index 0000000..e87a1d3
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shra_r_pw.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long res;
> +
> +    rt = 0x1234567887654321;
> +    res = 0x01234568f8765432;
> +
> +    __asm
> +        ("shra_r.pw %0, %1, 0x4"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("shra_r.pw error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shra_r_qh.c 
> b/tests/tcg/mips/mips64-dsp/shra_r_qh.c
> new file mode 100644
> index 0000000..cc11dca
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shra_r_qh.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long res;
> +
> +    rt = 0x8512345654323454;
> +    res = 0xf0a2068b0a86068b;
> +
> +    __asm
> +        ("shra_r.qh %0, %1, 0x3\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("shra_r.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shra_r_w.c 
> b/tests/tcg/mips/mips64-dsp/shra_r_w.c
> new file mode 100644
> index 0000000..36d2c9c
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shra_r_w.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt     = 0x87654321;
> +    result = 0xFFFFFFFFF0ECA864;
> +
> +    __asm
> +        ("shra_r.w %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("shra_r.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrav_ph.c 
> b/tests/tcg/mips/mips64-dsp/shrav_ph.c
> new file mode 100644
> index 0000000..1b4e983
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrav_ph.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x03;
> +    rt     = 0x87654321;
> +    result = 0xFFFFFFFFF0EC0864;
> +
> +    __asm
> +        ("shrav.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("shrav.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrav_pw.c 
> b/tests/tcg/mips/mips64-dsp/shrav_pw.c
> new file mode 100644
> index 0000000..acec0bc
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrav_pw.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs;
> +    long long res;
> +
> +    rt = 0x1234567887654321;
> +    rs = 0x4;
> +    res = 0x01234567f8765432;
> +
> +    __asm
> +        ("shrav.pw %0, %1, %2"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    if (rd != res) {
> +        printf("shrav.pw error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrav_qh.c 
> b/tests/tcg/mips/mips64-dsp/shrav_qh.c
> new file mode 100644
> index 0000000..110891c
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrav_qh.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs;
> +    long long res;
> +
> +    rt = 0x8512345654323454;
> +    rs = 0x4;
> +    res = 0xf851034505430345;
> +
> +    __asm
> +        ("shrav.qh %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    if (rd != res) {
> +        printf("shrav.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrav_r_ph.c 
> b/tests/tcg/mips/mips64-dsp/shrav_r_ph.c
> new file mode 100644
> index 0000000..350d529
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrav_r_ph.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x03;
> +    rt     = 0x87654321;
> +    result = 0xFFFFFFFFF0ED0864;
> +
> +    __asm
> +        ("shrav_r.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("shrav_r.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrav_r_pw.c 
> b/tests/tcg/mips/mips64-dsp/shrav_r_pw.c
> new file mode 100644
> index 0000000..1dc3e36
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrav_r_pw.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs;
> +    long long res;
> +
> +    rt = 0x1234567887654321;
> +    rs = 0x4;
> +    res = 0x01234568f8765432;
> +
> +    __asm
> +        ("shrav_r.pw %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    if (rd != res) {
> +        printf("shrav_r.pw error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrav_r_qh.c 
> b/tests/tcg/mips/mips64-dsp/shrav_r_qh.c
> new file mode 100644
> index 0000000..65930ea
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrav_r_qh.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs;
> +    long long res;
> +
> +    rt = 0x8512345654323454;
> +    rs = 0x3;
> +    res = 0xf0a2068b0a86068b;
> +
> +    __asm
> +        ("shrav_r.qh %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    if (rd != res) {
> +        printf("shrav_r.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrav_r_w.c 
> b/tests/tcg/mips/mips64-dsp/shrav_r_w.c
> new file mode 100644
> index 0000000..3766c72
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrav_r_w.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x03;
> +    rt     = 0x87654321;
> +    result = 0xFFFFFFFFF0ECA864;
> +
> +    __asm
> +        ("shrav_r.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("shrav_r.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrl_ob.c 
> b/tests/tcg/mips/mips64-dsp/shrl_ob.c
> new file mode 100644
> index 0000000..4771a31
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrl_ob.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long res;
> +
> +    rt = 0xab76543212345678;
> +    res = 0x150e0a0602060a0f;
> +
> +    __asm
> +        ("shrl.ob %0, %1, 0x3\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("shrl.ob error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrl_qb.c 
> b/tests/tcg/mips/mips64-dsp/shrl_qb.c
> new file mode 100644
> index 0000000..c0e36db
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrl_qb.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt     = 0x12345678;
> +    result = 0x00010203;
> +
> +    __asm
> +        ("shrl.qb %0, %1, 0x05\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("shrl.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrl_qh.c 
> b/tests/tcg/mips/mips64-dsp/shrl_qh.c
> new file mode 100644
> index 0000000..c156246
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrl_qh.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long res;
> +
> +    rt = 0x8765679abc543786;
> +    res = 0x087606790bc50378;
> +
> +    __asm
> +        ("shrl.qh %0, %1, 0x4\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +
> +    if (rd != res) {
> +        printf("shrl.qh error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrlv_ob.c 
> b/tests/tcg/mips/mips64-dsp/shrlv_ob.c
> new file mode 100644
> index 0000000..5e7e468
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrlv_ob.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs;
> +    long long res;
> +
> +    rt = 0xab76543212345678;
> +    rs = 0x3;
> +    res = 0x150e0a0602060a0f;
> +
> +    __asm
> +        ("shrlv.ob %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    if (rd != res) {
> +        printf("shrlv.ob error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrlv_qb.c 
> b/tests/tcg/mips/mips64-dsp/shrlv_qb.c
> new file mode 100644
> index 0000000..5616aa9
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrlv_qb.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x05;
> +    rt     = 0x12345678;
> +    result = 0x00010203;
> +
> +    __asm
> +        ("shrlv.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("shrlv.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/shrlv_qh.c 
> b/tests/tcg/mips/mips64-dsp/shrlv_qh.c
> new file mode 100644
> index 0000000..05de2fd
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/shrlv_qh.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs;
> +    long long res;
> +
> +    rt = 0x8765679abc543786;
> +    rs = 0x4;
> +    res = 0x087606790bc50378;
> +
> +    __asm
> +        ("shrlv.qh %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +
> +    if (rd != res) {
> +        printf("shrlv.qh error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/subq_ph.c 
> b/tests/tcg/mips/mips64-dsp/subq_ph.c
> new file mode 100644
> index 0000000..6a1b186
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subq_ph.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0xFFFFFFFF8ACF1357;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subq.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("subq.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/subq_pw.c 
> b/tests/tcg/mips/mips64-dsp/subq_pw.c
> new file mode 100644
> index 0000000..32f96ba
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subq_pw.c
> @@ -0,0 +1,44 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rt = 0x123456789ABCDEF0;
> +    rs = 0x123456789ABCDEF0;
> +    result = 0x0;
> +    dspresult = 0x0;
> +
> +    __asm
> +        ("subq.pw %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +         );
> +    dspreg = (dspreg >> 20) & 0x1;
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subq.pw error1\n\t");
> +
> +        return -1;
> +    }
> +
> +    rt = 0x123456789ABCDEF1;
> +    rs = 0x123456789ABCDEF2;
> +    result =  0x0000000000000001;
> +    dspresult = 0x0;
> +
> +    __asm
> +        ("subq.pw %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dspreg = (dspreg >> 20) & 0x1;
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subq.pw error2\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/subq_qh.c 
> b/tests/tcg/mips/mips64-dsp/subq_qh.c
> new file mode 100644
> index 0000000..76d5f0a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subq_qh.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rt = 0x123456789ABCDEF0;
> +    rs = 0x123456789ABCDEF0;
> +    result = 0x0;
> +    dspresult = 0x0;
> +
> +    __asm
> +        ("subq.qh %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dspreg = (dspreg >> 20) & 0x1;
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subq.qh error\n\t");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/subq_s_ph.c 
> b/tests/tcg/mips/mips64-dsp/subq_s_ph.c
> new file mode 100644
> index 0000000..0b162f0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subq_s_ph.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0x7FFF1357;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subq_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("subq_s.ph wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/subq_s_pw.c 
> b/tests/tcg/mips/mips64-dsp/subq_s_pw.c
> new file mode 100644
> index 0000000..944d63f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subq_s_pw.c
> @@ -0,0 +1,45 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rt = 0x9FFFFFFD9FFFFFFD;
> +    rs = 0x4000000080000000;
> +    result = 0x7fffffffe0000003;
> +    dspresult = 0x1;
> +
> +    __asm
> +        ("subq_s.pw %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dspreg = (dspreg >> 20) & 0x1;
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subq_s.pw error1\n");
> +
> +        return -1;
> +    }
> +
> +    rt = 0x123456789ABCDEF1;
> +    rs = 0x123456789ABCDEF2;
> +    result =  0x0000000000000001;
> +    /* This time we do not set dspctrl, but it setted in pre-action. */
> +    dspresult = 0x1;
> +
> +    __asm
> +        ("subq_s.pw %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dspreg = (dspreg >> 20) & 0x1;
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subq_s.pw error2\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/subq_s_qh.c 
> b/tests/tcg/mips/mips64-dsp/subq_s_qh.c
> new file mode 100644
> index 0000000..d02a459
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subq_s_qh.c
> @@ -0,0 +1,44 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x0;
> +    dspresult = 0x0;
> +
> +    __asm
> +        ("subq_s.qh %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dspreg = (dspreg >> 20) & 0x1;
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subq_s.qh error1\n");
> +
> +        return -1;
> +    }
> +
> +    rs = 0x4000000080000000;
> +    rt = 0x9FFD00009FFC0000;
> +    result =  0x7FFF0000E0040000;
> +    dspresult = 0x1;
> +
> +    __asm
> +        ("subq_s.qh %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dspreg = (dspreg >> 20) & 0x1;
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subq_s.qh error2\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/subq_s_w.c 
> b/tests/tcg/mips/mips64-dsp/subq_s_w.c
> new file mode 100644
> index 0000000..91d32da
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subq_s_w.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0x7FFFFFFF;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subq_s.w %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("subq_s.w wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/subu_ob.c 
> b/tests/tcg/mips/mips64-dsp/subu_ob.c
> new file mode 100644
> index 0000000..f670967
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subu_ob.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rs = 0x6F6F6F6F6F6F6F6F;
> +    rt = 0x5E5E5E5E5E5E5E5E;
> +    result = 0x1111111111111111;
> +    dspresult = 0x0;
> +
> +    __asm
> +        ("subu.ob %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +         );
> +
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subu.ob error\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> +
> diff --git a/tests/tcg/mips/mips64-dsp/subu_qb.c 
> b/tests/tcg/mips/mips64-dsp/subu_qb.c
> new file mode 100644
> index 0000000..9eb80df
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subu_qb.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0xFFFFFFFF8BCF1357;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subu.qb %0, %2, %3\n\t"
> +         "rddsp   %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("subu.qb wrong\n");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/subu_s_ob.c 
> b/tests/tcg/mips/mips64-dsp/subu_s_ob.c
> new file mode 100644
> index 0000000..5df64e5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subu_s_ob.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dspreg, result, dspresult;
> +    rs = 0x12345678ABCDEF0;
> +    rt = 0x12345678ABCDEF1;
> +    result = 0x00000000000;
> +    dspresult = 0x01;
> +
> +    __asm
> +        ("subu_s.ob %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dspreg)
> +         : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subu_s.ob error\n\t");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/subu_s_qb.c 
> b/tests/tcg/mips/mips64-dsp/subu_s_qb.c
> new file mode 100644
> index 0000000..9de76f4
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/subu_s_qb.c
> @@ -0,0 +1,27 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result    = 0x00001357;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subu_s.qb %0, %2, %3\n\t"
> +         "rddsp   %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    if ((dsp != resultdsp) || (rd  != result)) {
> +        printf("subu_s_qb wrong");
> +
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dsp/wrdsp.c 
> b/tests/tcg/mips/mips64-dsp/wrdsp.c
> new file mode 100644
> index 0000000..3033fd8
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dsp/wrdsp.c
> @@ -0,0 +1,48 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long dsp_i, dsp_o;
> +    long long ccond_i, outflag_i, efi_i, c_i, scount_i, pos_i;
> +    long long ccond_o, outflag_o, efi_o, c_o, scount_o, pos_o;
> +    long long ccond_r, outflag_r, efi_r, c_r, scount_r, pos_r;
> +
> +    ccond_i = 0x000000BC;/* 4 */
> +    outflag_i = 0x0000001B;/* 3 */
> +    efi_i = 0x00000001;/* 5 */
> +    c_i = 0x00000001;/* 2 */
> +    scount_i = 0x0000000F;/* 1 */
> +    pos_i = 0x0000000C;/* 0 */
> +
> +    dsp_i = (ccond_i << 24) | (outflag_i << 16) | (efi_i << 14) | (c_i << 13)
> +            | (scount_i << 7) | pos_i;
> +
> +    ccond_r = ccond_i;
> +    outflag_r = outflag_i;
> +    efi_r = efi_i;
> +    c_r = c_i;
> +    scount_r = scount_i;
> +    pos_r = pos_i;
> +
> +    __asm
> +        ("wrdsp %1, 0x3F\n\t"
> +         "rddsp %0, 0x3F\n\t"
> +         : "=r"(dsp_o)
> +         : "r"(dsp_i)
> +        );
> +
> +    ccond_o = (dsp_o >> 24) & 0xFF;
> +    outflag_o = (dsp_o >> 16) & 0xFF;
> +    efi_o = (dsp_o >> 14) & 0x01;
> +    c_o = (dsp_o >> 14) & 0x01;
> +    scount_o = (dsp_o >> 7) & 0x3F;
> +    pos_o = dsp_o & 0x1F;
> +
> +    if ((ccond_o != ccond_r) || (outflag_o != outflag_r) || (efi_o != efi_r) 
> \
> +            || (c_o != c_r) || (scount_o != scount_r) || (pos_o != pos_r)) {
> +        printf("wrddsp wrong\n");
> +
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/.directory 
> b/tests/tcg/mips/mips64-dspr2/.directory
> new file mode 100644
> index 0000000..c75a914
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/.directory
> @@ -0,0 +1,2 @@
> +[Dolphin]
> +Timestamp=2012,8,3,16,41,52
> diff --git a/tests/tcg/mips/mips64-dspr2/Makefile 
> b/tests/tcg/mips/mips64-dspr2/Makefile
> new file mode 100644
> index 0000000..69f92be
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/Makefile
> @@ -0,0 +1,117 @@
> +CROSS_COMPILE        ?= mips64el-unknown-linux-gnu-
> +
> +SIM = qemu-system-mips64el
> +SIMFLAGS = -nographic -cpu mips64dspr2 -kernel
> +
> +AS      = $(CROSS_COMPILE)as
> +LD      = $(CROSS_COMPILE)ld
> +CC      = $(CROSS_COMPILE)gcc
> +AR      = $(CROSS_COMPILE)ar
> +NM      = $(CROSS_COMPILE)nm
> +STRIP       = $(CROSS_COMPILE)strip
> +RANLIB      = $(CROSS_COMPILE)ranlib
> +OBJCOPY     = $(CROSS_COMPILE)objcopy
> +OBJDUMP     = $(CROSS_COMPILE)objdump
> +
> +VECTORS_OBJ ?= ./head.o ./printf.o
> +
> +HEAD_FLAGS ?= -nostdinc -mabi=64 -G 0 -mno-abicalls -fno-pic -pipe \
> +              -msoft-float -march=mips64 -Wa,-mips64 -Wa,--trap \
> +              -msym32 -DKBUILD_64BIT_SYM32 -I./
> +
> +CFLAGS ?= -nostdinc -mabi=64 -G 0 -mno-abicalls -fno-pic -fno-builtin  \
> +          -pipe -march=mips64r2 -mgp64 -mdspr2 -static -Wa,--trap -msym32 \
> +          -DKBUILD_64BIT_SYM32 -I./
> +
> +LDFLAGS = -T./mips_boot.lds -L./
> +FLAGS = -nostdlib -mabi=64 -march=mips64r2 -mgp64 -mdspr2
> +
> +TESTCASES = absq_s_qb.tst
> +TESTCASES += addqh_ph.tst
> +TESTCASES += addqh_r_ph.tst
> +TESTCASES += addqh_r_w.tst
> +TESTCASES += addqh_w.tst
> +#TESTCASES += adduh_ob.tst
> +TESTCASES += adduh_qb.tst
> +#TESTCASES += adduh_r_ob.tst
> +TESTCASES += adduh_r_qb.tst
> +TESTCASES += addu_ph.tst
> +#TESTCASES += addu_qh.tst
> +TESTCASES += addu_s_ph.tst
> +#TESTCASES += addu_s_qh.tst
> +TESTCASES += append.tst
> +TESTCASES += balign.tst
> +#TESTCASES += cmpgdu_eq_ob.tst
> +TESTCASES += cmpgdu_eq_qb.tst
> +#TESTCASES += cmpgdu_le_ob.tst
> +TESTCASES += cmpgdu_le_qb.tst
> +#TESTCASES += cmpgdu_lt_ob.tst
> +TESTCASES += cmpgdu_lt_qb.tst
> +#TESTCASES += dbalign.tst
> +TESTCASES += dpaqx_sa_w_ph.tst
> +TESTCASES += dpaqx_s_w_ph.tst
> +TESTCASES += dpa_w_ph.tst
> +#TESTCASES += dpa_w_qh.tst
> +TESTCASES += dpax_w_ph.tst
> +TESTCASES += dpsqx_sa_w_ph.tst
> +TESTCASES += dpsqx_s_w_ph.tst
> +TESTCASES += dps_w_ph.tst
> +#TESTCASES += dps_w_qh.tst
> +TESTCASES += dpsx_w_ph.tst
> +TESTCASES += muleq_s_w_phl.tst
> +TESTCASES += mul_ph.tst
> +TESTCASES += mulq_rs_w.tst
> +TESTCASES += mulq_s_ph.tst
> +TESTCASES += mulq_s_w.tst
> +TESTCASES += mulsaq_s_w_ph.tst
> +TESTCASES += mulsa_w_ph.tst
> +TESTCASES += mul_s_ph.tst
> +TESTCASES += precr_qb_ph.tst
> +TESTCASES += precr_sra_ph_w.tst
> +TESTCASES += precr_sra_r_ph_w.tst
> +TESTCASES += prepend.tst
> +TESTCASES += shra_qb.tst
> +TESTCASES += shra_r_qb.tst
> +#TESTCASES += shrav_ob.tst
> +TESTCASES += shrav_qb.tst
> +#TESTCASES += shrav_r_ob.tst
> +TESTCASES += shrav_r_qb.tst
> +TESTCASES += shrl_ph.tst
> +TESTCASES += shrlv_ph.tst
> +TESTCASES += subqh_ph.tst
> +TESTCASES += subqh_r_ph.tst
> +TESTCASES += subqh_r_w.tst
> +TESTCASES += subqh_w.tst
> +#TESTCASES += subuh_ob.tst
> +TESTCASES += subuh_qb.tst
> +#TESTCASES += subuh_r_ob.tst
> +TESTCASES += subuh_r_qb.tst
> +TESTCASES += subu_ph.tst
> +#TESTCASES += subu_qh.tst
> +TESTCASES += subu_s_ph.tst
> +#TESTCASES += subu_s_qh.tst
> +
> +all: build
> +
> +head.o : head.S
> +     $(Q)$(CC) $(HEAD_FLAGS) -D"STACK_TOP=0xffffffff80200000" -c $< -o $@
> +
> +%.o  : %.S
> +     $(CC) $(CFLAGS) -c $< -o $@
> +
> +%.o  : %.c
> +     $(CC) $(CFLAGS) -c $< -o $@
> +
> +%.tst: %.o $(VECTORS_OBJ)
> +     $(CC) $(VECTORS_OBJ) $(FLAGS) $(LDFLAGS) $< -o $@
> +
> +build: $(VECTORS_OBJ) $(MIPSSOC_LIB) $(TESTCASES)
> +
> +check:  $(VECTORS_OBJ) $(MIPSSOC_LIB) $(TESTCASES)
> +     @for case in $(TESTCASES); do \
> +             echo $(SIM) $(SIMFLAGS) ./$$case; \
> +             $(SIM) $(SIMFLAGS) ./$$case & (sleep 1; killall $(SIM)); \
> +     done
> +
> +clean:
> +     $(Q)rm -f *.o *.tst *.a
> diff --git a/tests/tcg/mips/mips64-dspr2/absq_s_qb.c 
> b/tests/tcg/mips/mips64-dspr2/absq_s_qb.c
> new file mode 100644
> index 0000000..f7aec3e
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/absq_s_qb.c
> @@ -0,0 +1,42 @@
> +#include "io.h"
> +int main()
> +{
> +    long long input, result, dsp;
> +    long long hope;
> +
> +    input = 0x701BA35E;
> +    hope  = 0x701B5D5E;
> +
> +    __asm
> +        ("absq_s.qb %0, %1\n\t"
> +         : "=r"(result)
> +         : "r"(input)
> +        );
> +    if (result != hope) {
> +        printf("absq_s.qb error\n");
> +        return -1;
> +    }
> +
> +    input = 0x801BA35E;
> +    hope  = 0x7F1B5D5E;
> +
> +    __asm
> +        ("absq_s.qb %0, %2\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(result), "=r"(dsp)
> +         : "r"(input)
> +        );
> +    dsp = dsp >> 20;
> +    dsp &= 0x01;
> +    if (result != hope) {
> +        printf("absq_s.qb error\n");
> +        return -1;
> +    }
> +
> +    if (dsp != 1) {
> +        printf("absq_s.qb error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/addqh_ph.c 
> b/tests/tcg/mips/mips64-dspr2/addqh_ph.c
> new file mode 100644
> index 0000000..01d5333
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/addqh_ph.c
> @@ -0,0 +1,35 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x706A13FE;
> +    rt     = 0x13065174;
> +    result = 0x41B832B9;
> +    __asm
> +        ("addqh.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("addqh.ph error!\n");
> +        return -1;
> +    }
> +
> +    rs     = 0x01000100;
> +    rt     = 0x02000100;
> +    result = 0x01800100;
> +    __asm
> +        ("addqh.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("addqh.ph error!\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/addqh_r_ph.c 
> b/tests/tcg/mips/mips64-dspr2/addqh_r_ph.c
> new file mode 100644
> index 0000000..08112c3
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/addqh_r_ph.c
> @@ -0,0 +1,35 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x706A13FE;
> +    rt     = 0x13065174;
> +    result = 0x41B832B9;
> +    __asm
> +        ("addqh_r.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addqh_r.ph error\n");
> +        return -1;
> +    }
> +
> +    rs     = 0x01000100;
> +    rt     = 0x02000100;
> +    result = 0x01800100;
> +    __asm
> +        ("addqh_r.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addqh_r.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/addqh_r_w.c 
> b/tests/tcg/mips/mips64-dspr2/addqh_r_w.c
> new file mode 100644
> index 0000000..d324dec
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/addqh_r_w.c
> @@ -0,0 +1,38 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x00000010;
> +    rt     = 0x00000001;
> +    result = 0x00000009;
> +
> +    __asm
> +        ("addqh_r.w  %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("addqh_r.w error!\n");
> +        return -1;
> +    }
> +    rs     = 0xFFFFFFFE;
> +    rt     = 0x00000001;
> +    result = 0x00000000;
> +
> +    __asm
> +        ("addqh_r.w  %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("addqh_r.w error!\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/addqh_w.c 
> b/tests/tcg/mips/mips64-dspr2/addqh_w.c
> new file mode 100644
> index 0000000..78559e6
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/addqh_w.c
> @@ -0,0 +1,39 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x00000010;
> +    rt     = 0x00000001;
> +    result = 0x00000008;
> +
> +    __asm
> +        ("addqh.w  %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("addqh.w wrong\n");
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFFFFFE;
> +    rt     = 0x00000001;
> +    result = 0xFFFFFFFFFFFFFFFF;
> +
> +    __asm
> +        ("addqh.w  %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    if (rd != result) {
> +        printf("addqh.w wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/addu_ph.c 
> b/tests/tcg/mips/mips64-dspr2/addu_ph.c
> new file mode 100644
> index 0000000..c269178
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/addu_ph.c
> @@ -0,0 +1,35 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010001;
> +    result = 0x01000100;
> +    __asm
> +        ("addu.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addu.ph error\n");
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0x00011112;
> +    __asm
> +        ("addu.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addu.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/addu_qh.c 
> b/tests/tcg/mips/mips64-dspr2/addu_qh.c
> new file mode 100644
> index 0000000..858e314
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/addu_qh.c
> @@ -0,0 +1,41 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rs = 0x123456787FFF0000;
> +    rt = 0x1111111180000000;
> +    result = 0x23456789FFFF0000;
> +    dspresult = 0x0;
> +
> +    __asm("addu.qh %0, %2, %3\n\t"
> +          "rddsp %1\n\t"
> +          : "=r"(rd), "=r"(dspreg)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addu.qh error\n");
> +        return -1;
> +    }
> +
> +    rs = 0x123456787FFF0000;
> +    rt = 0x1111111180020000;
> +    result = 0x23456789FFFF0000;
> +    dspresult = 0x01;
> +
> +    __asm("addu.qh %0, %2, %3\n\t"
> +          "rddsp %1\n\t"
> +          : "=r"(rd), "=r"(dspreg)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addu.qh overflow error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/addu_s_ph.c 
> b/tests/tcg/mips/mips64-dspr2/addu_s_ph.c
> new file mode 100644
> index 0000000..d91d8aa
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/addu_s_ph.c
> @@ -0,0 +1,35 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x00FE00FE;
> +    rt     = 0x00020001;
> +    result = 0x010000FF;
> +    __asm
> +        ("addu_s.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addu_s.ph error\n");
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFF1111;
> +    rt     = 0x00020001;
> +    result = 0xFFFFFFFFFFFF1112;
> +    __asm
> +        ("addu_s.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("addu_s.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/addu_s_qh.c 
> b/tests/tcg/mips/mips64-dspr2/addu_s_qh.c
> new file mode 100644
> index 0000000..2999900
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/addu_s_qh.c
> @@ -0,0 +1,41 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +    rs = 0x123456787FFF0000;
> +    rt = 0x1111111180000000;
> +    result = 0x23456789FFFF0000;
> +    dspresult = 0x0;
> +
> +    __asm("addu_s.qh %0, %2, %3\n\t"
> +          "rddsp %1\n\t"
> +          : "=r"(rd), "=r"(dspreg)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addu_s.qh error\n");
> +        return -1;
> +    }
> +
> +    rs = 0x12345678FFFF0000;
> +    rt = 0x11111111000F0000;
> +    result = 0x23456789FFFF0000;
> +    dspresult = 0x01;
> +
> +    __asm("addu_s.qh %0, %2, %3\n\t"
> +          "rddsp %1\n\t"
> +          : "=r"(rd), "=r"(dspreg)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("addu_s.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/adduh_ob.c 
> b/tests/tcg/mips/mips64-dspr2/adduh_ob.c
> new file mode 100644
> index 0000000..a8d5a6d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/adduh_ob.c
> @@ -0,0 +1,21 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +    rs = 0xFF987CDEBCEF2356;
> +    rt = 0xFF987CDEBCEF2354;
> +    result = 0xFF987CDEBCEF2355;
> +
> +    __asm("adduh.ob %0, %1, %2\n\t"
> +          : "=r"(rd)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    if (rd != result) {
> +        printf("adduh.ob error\n\t");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/adduh_qb.c 
> b/tests/tcg/mips/mips64-dspr2/adduh_qb.c
> new file mode 100644
> index 0000000..796b409
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/adduh_qb.c
> @@ -0,0 +1,35 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0xFF0055AA;
> +    rt     = 0x0113421B;
> +    result = 0xffffffff80094B62;
> +    __asm
> +        ("adduh.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("adduh.qb error\n");
> +        return -1;
> +    }
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0x7F800888;
> +
> +    __asm
> +        ("adduh.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("adduh.qb error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/adduh_r_ob.c 
> b/tests/tcg/mips/mips64-dspr2/adduh_r_ob.c
> new file mode 100644
> index 0000000..57a9874
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/adduh_r_ob.c
> @@ -0,0 +1,21 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +    rs = 0xFF987CDEBCEF2356;
> +    rt = 0xFF987CDEBCEF2355;
> +    result = 0xFF987CDEBCEF2356;
> +
> +    __asm("adduh_r.ob %0, %1, %2\n\t"
> +          : "=r"(rd)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    if (rd != result) {
> +        printf("adduh_r.ob error\n\t");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/adduh_r_qb.c 
> b/tests/tcg/mips/mips64-dspr2/adduh_r_qb.c
> new file mode 100644
> index 0000000..ae65fa5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/adduh_r_qb.c
> @@ -0,0 +1,35 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0xFF0055AA;
> +    rt     = 0x01112211;
> +    result = 0xffffffff80093C5E;
> +    __asm
> +        ("adduh_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("adduh_r.qb error\n");
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0xffffffff80800888;
> +    __asm
> +        ("adduh_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("adduh_r.qb error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/append.c 
> b/tests/tcg/mips/mips64-dspr2/append.c
> new file mode 100644
> index 0000000..68a7cec
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/append.c
> @@ -0,0 +1,35 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long result;
> +
> +    rs     = 0xFF0055AA;
> +    rt     = 0x0113421B;
> +    result = 0x02268436;
> +    __asm
> +        ("append %0, %1, 0x01\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (rt != result) {
> +        printf("append error\n");
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0x0010111F;
> +    __asm
> +        ("append %0, %1, 0x04\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (rt != result) {
> +        printf("append error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/balign.c 
> b/tests/tcg/mips/mips64-dspr2/balign.c
> new file mode 100644
> index 0000000..7fbe815
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/balign.c
> @@ -0,0 +1,35 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long result;
> +
> +    rs     = 0xFF0055AA;
> +    rt     = 0x0113421B;
> +    result = 0x13421BFF;
> +    __asm
> +        ("balign %0, %1, 0x01\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (rt != result) {
> +        printf("balign error\n");
> +        return -1;
> +    }
> +
> +    rs     = 0xFFFF0FFF;
> +    rt     = 0x00010111;
> +    result = 0x11FFFF0F;
> +    __asm
> +        ("balign %0, %1, 0x03\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (rt != result) {
> +        printf("balign error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_ob.c 
> b/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_ob.c
> new file mode 100644
> index 0000000..135328a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_ob.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    result = 0xFE;
> +    dspresult = 0xFE;
> +
> +    __asm("cmpgdu.eq.ob %0, %2, %3\n\t"
> +          "rddsp %1"
> +          : "=r"(rd), "=r"(dspreg)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 24) & 0xFF);
> +
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("cmpgdu.eq.ob error\n");
> +        return -1;
> +    }
> +
> +   return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_qb.c 
> b/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_qb.c
> new file mode 100644
> index 0000000..c63f648
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/cmpgdu_eq_qb.c
> @@ -0,0 +1,41 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long dsp;
> +    long long result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x02;
> +    __asm
> +        ("cmpgdu.eq.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if ((rd != result) || (dsp != result)) {
> +        printf("cmpgdu.eq.qb error\n");
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x0F;
> +    __asm
> +        ("cmpgdu.eq.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +
> +    if ((rd != result) || (dsp != result)) {
> +        printf("cmpgdu.eq.qb error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_le_ob.c 
> b/tests/tcg/mips/mips64-dspr2/cmpgdu_le_ob.c
> new file mode 100644
> index 0000000..c1440b1
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/cmpgdu_le_ob.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    dspresult = 0xFF;
> +    result = 0xFF;
> +
> +    __asm("cmpgdu.le.ob %0, %2, %3\n\t"
> +          "rddsp %1"
> +          : "=r"(rd), "=r"(dspreg)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 24) & 0xFF);
> +
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("cmpgdu.le.ob error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_le_qb.c 
> b/tests/tcg/mips/mips64-dspr2/cmpgdu_le_qb.c
> new file mode 100644
> index 0000000..f0a60ea
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/cmpgdu_le_qb.c
> @@ -0,0 +1,48 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long dsp;
> +    long long result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x0F;
> +    __asm
> +        ("cmpgdu.le.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (rd  != result) {
> +        printf("cmpgdu.le.qb error\n");
> +        return -1;
> +    }
> +    if (dsp != result) {
> +        printf("cmpgdu.le.qb error\n");
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11707066;
> +    result = 0x0B;
> +    __asm
> +        ("cmpgdu.le.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (rd  != result) {
> +        printf("cmpgdu.le.qb error\n");
> +        return -1;
> +    }
> +    if (dsp != result) {
> +        printf("cmpgdu.le.qb error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_ob.c 
> b/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_ob.c
> new file mode 100644
> index 0000000..87e7028
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_ob.c
> @@ -0,0 +1,26 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result, dspreg, dspresult;
> +
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEFF;
> +    dspresult = 0x01;
> +    result = 0x01;
> +
> +    __asm("cmpgdu.lt.ob %0, %2, %3\n\t"
> +          "rddsp %1"
> +          : "=r"(rd), "=r"(dspreg)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 24) & 0xFF);
> +
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("cmpgdu.lt.ob error\n");
> +        return -1;
> +    }
> +
> +   return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_qb.c 
> b/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_qb.c
> new file mode 100644
> index 0000000..a71e4e3
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/cmpgdu_lt_qb.c
> @@ -0,0 +1,48 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long dsp;
> +    long long result;
> +
> +    rs         = 0x11777066;
> +    rt         = 0x55AA70FF;
> +    result     = 0x0D;
> +    __asm
> +        ("cmpgdu.lt.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (rd  != result) {
> +        printf("cmpgdu.lt.qb error\n");
> +        return -1;
> +    }
> +    if (dsp != result) {
> +        printf("cmpgdu.lt.qb error\n");
> +        return -1;
> +    }
> +
> +    rs     = 0x11777066;
> +    rt     = 0x11777066;
> +    result = 0x00;
> +    __asm
> +        ("cmpgdu.lt.qb %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 24) & 0x0F;
> +    if (rd  != result) {
> +        printf("cmpgdu.lt.qb error\n");
> +        return -1;
> +    }
> +    if (dsp != result) {
> +        printf("cmpgdu.lt.qb error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dbalign.c 
> b/tests/tcg/mips/mips64-dspr2/dbalign.c
> new file mode 100644
> index 0000000..dbc40d5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dbalign.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long res;
> +    rt = 0x1234567887654321;
> +    rs = 0xabcd1234abcd1234;
> +
> +    res = 0x34567887654321ab;
> +
> +    asm ("dbalign %0, %1, 0x1\n"
> +         : "=r"(rt)
> +         : "r"(rs)
> +        );
> +
> +    if (rt != res) {
> +        printf("dbalign error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dpa_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/dpa_w_ph.c
> new file mode 100644
> index 0000000..a634d10
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dpa_w_ph.c
> @@ -0,0 +1,32 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x05;
> +    resultl = 0x0302;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpa.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (ach != resulth) {
> +        printf("dpa.w.ph error\n");
> +        return -1;
> +    }
> +    if (acl != resultl) {
> +        printf("dpa.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dpa_w_qh.c 
> b/tests/tcg/mips/mips64-dspr2/dpa_w_qh.c
> new file mode 100644
> index 0000000..1411e44
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dpa_w_qh.c
> @@ -0,0 +1,56 @@
> +#include"io.h"
> +int main(void)
> +{
> +    long long rt, rs;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +
> +    achi = 0x1;
> +    acli = 0x1;
> +
> +    rs = 0x0001000100010001;
> +    rt = 0x0002000200020002;
> +
> +    resh = 0x1;
> +    resl = 0x9;
> +
> +    asm("mthi %2, $ac1\t\n"
> +        "mtlo %3, $ac1\t\n"
> +        "dpa.w.qh $ac1, %4, %5\t\n"
> +        "mfhi %0, $ac1\t\n"
> +        "mflo %1, $ac1\t\n"
> +        : "=r"(acho), "=r"(aclo)
> +        : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +       );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dpa.w.qh error\n");
> +        return -1;
> +    }
> +
> +
> +    achi = 0xffffffff;
> +    acli = 0xaaaaaaaa;
> +
> +    rs = 0xaaaabbbbccccdddd;
> +    rt = 0x7777888899996666;
> +
> +    resh = 0xffffffffffffffff;
> +    resl = 0x320cdf02;
> +
> +    asm("mthi %2, $ac1\t\n"
> +        "mtlo %3, $ac1\t\n"
> +        "dpa.w.qh $ac1, %4, %5\t\n"
> +        "mfhi %0, $ac1\t\n"
> +        "mflo %1, $ac1\t\n"
> +        : "=r"(acho), "=r"(aclo)
> +        : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +       );
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("2 dpa.w.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dpaqx_s_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/dpaqx_s_w_ph.c
> new file mode 100644
> index 0000000..5ed9988
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dpaqx_s_w_ph.c
> @@ -0,0 +1,74 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl, resultdsp;
> +
> +    rs     = 0x800000FF;
> +    rt     = 0x00018000;
> +    resulth = 0x05;
> +    resultl = 0xFFFFFFFF80000202;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpaqx_s.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    if (dsp != resultdsp) {
> +        printf("dpaqx_s.w.ph error\n");
> +        return -1;
> +    }
> +    if (ach != resulth) {
> +        printf("dpaqx_s.w.ph error\n");
> +        return -1;
> +    }
> +    if (acl != resultl) {
> +        printf("dpaqx_s.w.ph error\n");
> +        return -1;
> +    }
> +
> +    ach    = 5;
> +    acl    = 5;
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x05;
> +    resultl = 0x05FF;
> +    /***********************************************************
> +     * Because of we set outflag at last time, although this
> +     * time we set nothing, but it is stay the last time value.
> +     **********************************************************/
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpaqx_s.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    if (dsp != resultdsp) {
> +        printf("dpaqx_s.w.ph error\n");
> +        return -1;
> +    }
> +    if (ach != resulth) {
> +        printf("dpaqx_s.w.ph error\n");
> +        return -1;
> +    }
> +    if (acl != resultl) {
> +        printf("dpaqx_s.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dpaqx_sa_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/dpaqx_sa_w_ph.c
> new file mode 100644
> index 0000000..881ee91
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dpaqx_sa_w_ph.c
> @@ -0,0 +1,42 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl, resultdsp;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x00;
> +    resultl = 0x7fffffff;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpaqx_sa.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +
> +    dsp = (dsp >> 17) & 0x01;
> +    if (dsp != resultdsp) {
> +        printf("dpaqx_sa.w.ph error\n");
> +        return -1;
> +    }
> +
> +    if (ach != resulth) {
> +        printf("dpaqx_sa.w.ph error\n");
> +        return -1;
> +    }
> +
> +    if (acl != resultl) {
> +        printf("dpaqx_sa.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dpax_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/dpax_w_ph.c
> new file mode 100644
> index 0000000..9d595fc
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dpax_w_ph.c
> @@ -0,0 +1,32 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long rs, rt;
> +    long ach = 5, acl = 5;
> +    long resulth, resultl;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x05;
> +    resultl = 0x0302;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpax.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (ach != resulth) {
> +        printf("dpax.w.ph error\n");
> +        return -1;
> +    }
> +    if (acl != resultl) {
> +        printf("dpax.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dps_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/dps_w_ph.c
> new file mode 100644
> index 0000000..99f292e
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dps_w_ph.c
> @@ -0,0 +1,28 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl;
> +
> +    rs     = 0x00FF00FF;
> +    rt     = 0x00010002;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFFFFFFFFD08;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dps.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (ach != resulth || acl != resultl) {
> +        printf("dps.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dps_w_qh.c 
> b/tests/tcg/mips/mips64-dspr2/dps_w_qh.c
> new file mode 100644
> index 0000000..61277eb
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dps_w_qh.c
> @@ -0,0 +1,55 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long achi, acli;
> +    long long acho, aclo;
> +    long long resh, resl;
> +
> +    rs = 0x0000000100000001;
> +    rt = 0x0000000200000002;
> +    achi = 0x1;
> +    acli = 0x8;
> +
> +    resh = 0x1;
> +    resl = 0x4;
> +
> +    asm ("mthi %2, $ac1\t\n"
> +         "mtlo %3, $ac1\t\n"
> +         "dps.w.qh $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1\t\n"
> +         "mflo %1, $ac1\t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dps.w.qh error\n");
> +        return -1;
> +    }
> +
> +    rs = 0xaaaabbbbccccdddd;
> +    rt = 0xaaaabbbbccccdddd;
> +
> +    achi = 0x88888888;
> +    achi = 0x55555555;
> +
> +    resh = 0xfffffffff7777777;
> +    resl = 0x0a38b181;
> +
> +    asm ("mthi %2, $ac1\t\n"
> +         "mtlo %3, $ac1\t\n"
> +         "dps.w.qh $ac1, %4, %5\t\n"
> +         "mfhi %0, $ac1\t\n"
> +         "mflo %1, $ac1\t\n"
> +         : "=r"(acho), "=r"(aclo)
> +         : "r"(achi), "r"(acli), "r"(rs), "r"(rt)
> +        );
> +
> +    if ((acho != resh) || (aclo != resl)) {
> +        printf("1 dps.w.qh error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dpsqx_s_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/dpsqx_s_w_ph.c
> new file mode 100644
> index 0000000..44be535
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dpsqx_s_w_ph.c
> @@ -0,0 +1,31 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, dsp;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl, resultdsp;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFFAEA3E09B;
> +    resultdsp = 0x00;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsqx_s.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    if (dsp != resultdsp || ach != resulth || acl != resultl) {
> +        printf("dpsqx_s.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dpsqx_sa_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/dpsqx_sa_w_ph.c
> new file mode 100644
> index 0000000..6b2e6d1
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dpsqx_sa_w_ph.c
> @@ -0,0 +1,30 @@
> +#include"io.h"
> +int main()
> +{
> +    long long rs, rt, dsp;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl, resultdsp;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x00;
> +    resultl = 0x7FFFFFFF;
> +    resultdsp = 0x01;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsqx_sa.w.ph $ac1, %3, %4\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         "rddsp %2\n\t"
> +         : "+r"(ach), "+r"(acl), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 17) & 0x01;
> +    if (dsp != resultdsp || ach != resulth || acl != resultl) {
> +        printf("dpsqx_sa.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/dpsx_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/dpsx_w_ph.c
> new file mode 100644
> index 0000000..b6291b5
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/dpsx_w_ph.c
> @@ -0,0 +1,28 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long ach = 5, acl = 5;
> +    long long resulth, resultl;
> +
> +    rs      = 0xBC0123AD;
> +    rt      = 0x01643721;
> +    resulth = 0x04;
> +    resultl = 0xFFFFFFFFD751F050;
> +    __asm
> +        ("mthi  %0, $ac1\n\t"
> +         "mtlo  %1, $ac1\n\t"
> +         "dpsx.w.ph $ac1, %2, %3\n\t"
> +         "mfhi  %0, $ac1\n\t"
> +         "mflo  %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (ach != resulth || acl != resultl) {
> +        printf("dpsx.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/head.S 
> b/tests/tcg/mips/mips64-dspr2/head.S
> new file mode 100644
> index 0000000..9a099ae
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/head.S
> @@ -0,0 +1,16 @@
> +/*
> + *  Startup Code for MIPS64 CPU-core
> + *
> + */
> +.text
> +.globl _start
> +.align 4
> +_start:
> +    ori    $2, $2, 0xffff
> +    sll    $2, $2, 16
> +    ori    $2, $2, 0xffff
> +    mtc0   $2, $12, 0
> +    jal    main
> +
> +end:
> +    b end
> diff --git a/tests/tcg/mips/mips64-dspr2/io.h 
> b/tests/tcg/mips/mips64-dspr2/io.h
> new file mode 100644
> index 0000000..b7db61d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/io.h
> @@ -0,0 +1,22 @@
> +#ifndef _ASM_IO_H
> +#define _ASM_IO_H
> +extern int printf(const char *fmt, ...);
> +extern unsigned long get_ticks(void);
> +
> +#define _read(source)                \
> +({ unsigned long __res;                \
> +    __asm__ __volatile__(            \
> +        "mfc0\t%0, " #source "\n\t"    \
> +        : "=r" (__res));        \
> +    __res;                    \
> +})
> +
> +#define __read(source)                \
> +({ unsigned long __res;                \
> +    __asm__ __volatile__(            \
> +        "move\t%0, " #source "\n\t"    \
> +        : "=r" (__res));        \
> +    __res;                    \
> +})
> +
> +#endif
> diff --git a/tests/tcg/mips/mips64-dspr2/mips_boot.lds 
> b/tests/tcg/mips/mips64-dspr2/mips_boot.lds
> new file mode 100644
> index 0000000..bd7c0c0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/mips_boot.lds
> @@ -0,0 +1,31 @@
> +OUTPUT_ARCH(mips)
> +SECTIONS
> +{
> +    . = 0xffffffff80100000;
> +    . = ALIGN((1 << 13));
> +    .text :
> +    {
> +        *(.text)
> +        *(.rodata)
> +        *(.rodata.*)
> +    }
> +
> +    __init_begin = .;
> +    . = ALIGN((1 << 12));
> +    .init.text : AT(ADDR(.init.text) - 0)
> +    {
> +        *(.init.text)
> +    }
> +    .init.data : AT(ADDR(.init.data) - 0)
> +    {
> +        *(.init.data)
> +    }
> +    . = ALIGN((1 << 12));
> +    __init_end = .;
> +
> +    . = ALIGN((1 << 13));
> +    .data :
> +    {
> +        *(.data)
> +    }
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/mul_ph.c 
> b/tests/tcg/mips/mips64-dspr2/mul_ph.c
> new file mode 100644
> index 0000000..db609b2
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/mul_ph.c
> @@ -0,0 +1,26 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x03FB1234;
> +    rt = 0x0BCC4321;
> +    result = 0xFFFFFFFFF504F4B4;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mul.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if (rd  != result || dsp != resultdsp) {
> +        printf("mul.ph wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/mul_s_ph.c 
> b/tests/tcg/mips/mips64-dspr2/mul_s_ph.c
> new file mode 100644
> index 0000000..233c484
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/mul_s_ph.c
> @@ -0,0 +1,26 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x03FB1234;
> +    rt = 0x0BCC4321;
> +    result = 0x7fff7FFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mul_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if (rd != result || dsp != resultdsp) {
> +        printf("mul_s.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/muleq_s_w_phl.c 
> b/tests/tcg/mips/mips64-dspr2/muleq_s_w_phl.c
> new file mode 100644
> index 0000000..9623683
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/muleq_s_w_phl.c
> @@ -0,0 +1,42 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if (rd  != result || dsp != resultdsp) {
> +        printf("muleq_s.w.phl error\n");
> +        return -1;
> +    }
> +    rs = 0x12340000;
> +    rt = 0x43210000;
> +    result = 0x98be968;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("muleq_s.w.phl %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if (rd  != result || dsp != resultdsp) {
> +        printf("muleq_s.w.phl error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/mulq_rs_w.c 
> b/tests/tcg/mips/mips64-dspr2/mulq_rs_w.c
> new file mode 100644
> index 0000000..ffdc66d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/mulq_rs_w.c
> @@ -0,0 +1,40 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0xFFFFFFFF80005555;
> +
> +    __asm
> +        ("mulq_rs.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("mulq_rs.w error!\n");
> +        return -1;
> +    }
> +
> +    rs = 0x80000000;
> +    rt = 0x80000000;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mulq_rs.w %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if (rd != result || dsp != resultdsp) {
> +        printf("mulq_rs.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/mulq_s_ph.c 
> b/tests/tcg/mips/mips64-dspr2/mulq_s_ph.c
> new file mode 100644
> index 0000000..b8c20c6
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/mulq_s_ph.c
> @@ -0,0 +1,26 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0x7FFF098B;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mulq_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if (rd  != result || dsp != resultdsp) {
> +        printf("mulq_s.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/mulq_s_w.c 
> b/tests/tcg/mips/mips64-dspr2/mulq_s_w.c
> new file mode 100644
> index 0000000..db74b71
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/mulq_s_w.c
> @@ -0,0 +1,40 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    result = 0xFFFFFFFF80005555;
> +
> +    __asm
> +        ("mulq_s.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("mulq_s.w error\n");
> +        return -1;
> +    }
> +
> +    rs = 0x80000000;
> +    rt = 0x80000000;
> +    result = 0x7FFFFFFF;
> +    resultdsp = 1;
> +
> +    __asm
> +        ("mulq_s.w %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 21) & 0x01;
> +    if (rd != result || dsp != resultdsp) {
> +        printf("mulq_s.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/mulsa_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/mulsa_w_ph.c
> new file mode 100644
> index 0000000..5b22a60
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/mulsa_w_ph.c
> @@ -0,0 +1,30 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, ach, acl;
> +    long long resulth, resultl;
> +
> +    ach = 0x05;
> +    acl = 0x00BBDDCC;
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    resulth = 0x05;
> +    resultl = 0x3BF5E918;
> +
> +    __asm
> +        ("mthi %0, $ac1\n\t"
> +         "mtlo %1, $ac1\n\t"
> +         "mulsa.w.ph $ac1, %2, %3\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (ach != resulth || acl != resultl) {
> +        printf("mulsa.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/mulsaq_s_w_ph.c 
> b/tests/tcg/mips/mips64-dspr2/mulsaq_s_w_ph.c
> new file mode 100644
> index 0000000..835a73d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/mulsaq_s_w_ph.c
> @@ -0,0 +1,30 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt, ach, acl;
> +    long long resulth, resultl;
> +
> +    ach = 0x05;
> +    acl = 0x00BBDDCC;
> +    rs = 0x80001234;
> +    rt = 0x80004321;
> +    resulth = 0x05;
> +    resultl = 0x772ff463;
> +
> +    __asm
> +        ("mthi %0, $ac1\n\t"
> +         "mtlo %1, $ac1\n\t"
> +         "mulsaq_s.w.ph $ac1, %2, %3\n\t"
> +         "mfhi %0, $ac1\n\t"
> +         "mflo %1, $ac1\n\t"
> +         : "+r"(ach), "+r"(acl)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (ach != resulth || acl != resultl) {
> +        printf("mulsaq_s.w.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/precr_qb_ph.c 
> b/tests/tcg/mips/mips64-dspr2/precr_qb_ph.c
> new file mode 100644
> index 0000000..80d5e8d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/precr_qb_ph.c
> @@ -0,0 +1,23 @@
> +#include"io.h"
> +
> +int main()
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x34786521;
> +
> +    __asm
> +        ("precr.qb.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (result != rd) {
> +        printf("precr.qb.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/precr_sra_ph_w.c 
> b/tests/tcg/mips/mips64-dspr2/precr_sra_ph_w.c
> new file mode 100644
> index 0000000..b1d7bcd
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/precr_sra_ph_w.c
> @@ -0,0 +1,37 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x43215678;
> +
> +    __asm
> +        ("precr_sra.ph.w %0, %1, 0x00\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (result != rt) {
> +        printf("precr_sra.ph.w error\n");
> +        return -1;
> +    }
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xFFFFFFFFFFFF0000;
> +
> +    __asm
> +        ("precr_sra.ph.w %0, %1, 0x1F\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (result != rt) {
> +        printf("precr_sra.ph.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/precr_sra_r_ph_w.c 
> b/tests/tcg/mips/mips64-dspr2/precr_sra_r_ph_w.c
> new file mode 100644
> index 0000000..62d220d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/precr_sra_r_ph_w.c
> @@ -0,0 +1,37 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x43215678;
> +
> +    __asm
> +        ("precr_sra_r.ph.w %0, %1, 0x00\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (result != rt) {
> +        printf("precr_sra_r.ph.w error\n");
> +        return -1;
> +    }
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xFFFFFFFFFFFF0000;
> +
> +    __asm
> +        ("precr_sra_r.ph.w %0, %1, 0x1F\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (result != rt) {
> +        printf("precr_sra_r.ph.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/prepend.c 
> b/tests/tcg/mips/mips64-dspr2/prepend.c
> new file mode 100644
> index 0000000..4ab083e
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/prepend.c
> @@ -0,0 +1,35 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xFFFFFFFF87654321;
> +    __asm
> +        ("prepend %0, %1, 0x00\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (rt != result) {
> +        printf("prepend error\n");
> +        return -1;
> +    }
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xFFFFFFFFACF10ECA;
> +    __asm
> +        ("prepend %0, %1, 0x0F\n\t"
> +         : "+r"(rt)
> +         : "r"(rs)
> +        );
> +    if (rt != result) {
> +        printf("prepend error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/printf.c 
> b/tests/tcg/mips/mips64-dspr2/printf.c
> new file mode 100644
> index 0000000..cf8676d
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/printf.c
> @@ -0,0 +1,266 @@
> +
> +typedef unsigned long va_list;
> +
> +#define ACC    4
> +#define __read(source)                    \
> +({ va_list __res;                    \
> +    __asm__ __volatile__(                \
> +        "move\t%0, " #source "\n\t"        \
> +        : "=r" (__res));            \
> +    __res;                        \
> +})
> +
> +enum format_type {
> +    FORMAT_TYPE_NONE,
> +    FORMAT_TYPE_HEX,
> +    FORMAT_TYPE_ULONG,
> +    FORMAT_TYPE_FLOAT
> +};
> +
> +struct printf_spec {
> +    char    type;
> +};
> +
> +static int format_decode(char *fmt, struct printf_spec *spec)
> +{
> +    char *start = fmt;
> +
> +    for (; *fmt ; ++fmt) {
> +        if (*fmt == '%') {
> +            break;
> +        }
> +    }
> +
> +    switch (*++fmt) {
> +    case 'x':
> +        spec->type = FORMAT_TYPE_HEX;
> +        break;
> +
> +    case 'd':
> +        spec->type = FORMAT_TYPE_ULONG;
> +        break;
> +
> +    case 'f':
> +        spec->type = FORMAT_TYPE_FLOAT;
> +        break;
> +
> +    default:
> +        spec->type = FORMAT_TYPE_NONE;
> +    }
> +
> +    return ++fmt - start;
> +}
> +
> +void *memcpy(void *dest, void *src, int n)
> +{
> +    int i;
> +    char *s = src;
> +    char *d = dest;
> +
> +    for (i = 0; i < n; i++) {
> +        d[i] = s[i];
> +    }
> +    return dest;
> +}
> +
> +char *number(char *buf, va_list num)
> +{
> +    int i;
> +    char *str = buf;
> +    static char digits[16] = "0123456789abcdef";
> +    str = str + sizeof(num) * 2;
> +
> +    for (i = 0; i < sizeof(num) * 2; i++) {
> +        *--str = digits[num & 15];
> +        num >>= 4;
> +    }
> +
> +    return buf + sizeof(num) * 2;
> +}
> +
> +char *__number(char *buf, va_list num)
> +{
> +    int i;
> +    va_list mm = num;
> +    char *str = buf;
> +
> +    if (!num) {
> +        *str++ = '0';
> +        return str;
> +    }
> +
> +    for (i = 0; mm; mm = mm/10, i++) {
> +        /* Do nothing. */
> +    }
> +
> +    str = str + i;
> +
> +    while (num) {
> +        *--str = num % 10 + 48;
> +        num = num / 10;
> +    }
> +
> +    return str + i;
> +}
> +
> +va_list modf(va_list args, va_list *integer, va_list *num)
> +{
> +    int i;
> +    double dot_v = 0;
> +    va_list E, DOT, DOT_V;
> +
> +    if (!args) {
> +        return 0;
> +    }
> +
> +    for (i = 0, args = args << 1 >> 1; i < 52; i++) {
> +        if ((args >> i) & 0x1) {
> +            break;
> +        }
> +    }
> +
> +    *integer = 0;
> +
> +    if ((args >> 56 != 0x3f) || (args >> 52 == 0x3ff)) {
> +        E = (args >> 52) - 1023;
> +        DOT = 52 - E - i;
> +        DOT_V = args << (12 + E) >> (12 + E) >> i;
> +        *integer = ((args << 12 >> 12) >> (i + DOT)) | (1 << E);
> +    } else {
> +        E = ~((args >> 52) - 1023) + 1;
> +        DOT_V = args << 12 >> 12;
> +
> +        dot_v += 1.0 / (1 << E);
> +
> +        for (i = 1; i <= 16; i++) {
> +            if ((DOT_V >> (52 - i)) & 0x1) {
> +                dot_v += 1.0 / (1 << E + i);
> +            }
> +        }
> +
> +        for (i = 1, E = 0; i <= ACC; i++) {
> +            dot_v *= 10;
> +            if (!(va_list)dot_v) {
> +                E++;
> +            }
> +    }
> +
> +    *num = E;
> +
> +    return dot_v;
> +    }
> +
> +    if (args & 0xf) {
> +        for (i = 1; i <= 16; i++) {
> +            if ((DOT_V >> (DOT - i)) & 0x1) {
> +                dot_v += 1.0 / (1 << i);
> +            }
> +        }
> +
> +        for (i = 1, E = 0; i <= ACC; i++) {
> +            dot_v *= 10;
> +            if (!(va_list)dot_v) {
> +                E++;
> +            }
> +        }
> +
> +        *num = E;
> +
> +        return dot_v;
> +    } else if (DOT) {
> +        for (i = 1; i <= DOT; i++) {
> +            if ((DOT_V >> (DOT - i)) & 0x1) {
> +                dot_v += 1.0 / (1 << i);
> +            }
> +        }
> +
> +        for (i = 1; i <= ACC; i++) {
> +            dot_v = dot_v * 10;
> +        }
> +
> +    return dot_v;
> +    }
> +
> +    return 0;
> +}
> +
> +int vsnprintf(char *buf, int size, char *fmt, va_list args)
> +{
> +    char *str, *mm;
> +    struct printf_spec spec = {0};
> +
> +    str = mm = buf;
> +
> +    while (*fmt) {
> +        char *old_fmt = fmt;
> +        int read = format_decode(fmt, &spec);
> +
> +        fmt += read;
> +
> +        switch (spec.type) {
> +        case FORMAT_TYPE_NONE: {
> +            memcpy(str, old_fmt, read);
> +            str += read;
> +            break;
> +        }
> +        case FORMAT_TYPE_HEX: {
> +            memcpy(str, old_fmt, read);
> +            str = number(str + read, args);
> +            for (; *mm ; ++mm) {
> +                if (*mm == '%') {
> +                    *mm = '0';
> +                break;
> +                }
> +            }
> +        break;
> +        }
> +        case FORMAT_TYPE_ULONG: {
> +            memcpy(str, old_fmt, read - 2);
> +            str = __number(str + read - 2, args);
> +            break;
> +        }
> +        case FORMAT_TYPE_FLOAT: {
> +            va_list integer, dot_v, num;
> +            dot_v = modf(args, &integer, &num);
> +            memcpy(str, old_fmt, read - 2);
> +            str += read - 2;
> +            if ((args >> 63 & 0x1)) {
> +                *str++ = '-';
> +            }
> +            str = __number(str, integer);
> +            if (dot_v) {
> +                *str++ = '.';
> +                while (num--) {
> +                    *str++ = '0';
> +                }
> +                str = __number(str, dot_v);
> +            }
> +            break;
> +        }
> +        }
> +    }
> +    *str = '\0';
> +
> +    return str - buf;
> +}
> +
> +static void serial_out(char *str)
> +{
> +    while (*str) {
> +        *(char *)0xffffffffb80003f8 = *str++;
> +    }
> +}
> +
> +int vprintf(char *fmt, va_list args)
> +{
> +    int printed_len = 0;
> +    static char printf_buf[512];
> +    printed_len = vsnprintf(printf_buf, sizeof(printf_buf), fmt, args);
> +    serial_out(printf_buf);
> +    return printed_len;
> +}
> +
> +int printf(char *fmt, ...)
> +{
> +    return vprintf(fmt, __read($5));
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/shra_qb.c 
> b/tests/tcg/mips/mips64-dspr2/shra_qb.c
> new file mode 100644
> index 0000000..cac3102
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/shra_qb.c
> @@ -0,0 +1,35 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt = 0x12345678;
> +    result = 0x02060A0F;
> +
> +    __asm
> +        ("shra.qb %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("shra.qb error\n");
> +        return -1;
> +    }
> +
> +    rt = 0x87654321;
> +    result = 0xFFFFFFFFF00C0804;
> +
> +    __asm
> +        ("shra.qb %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("shra.qb error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/shra_r_qb.c 
> b/tests/tcg/mips/mips64-dspr2/shra_r_qb.c
> new file mode 100644
> index 0000000..9c64f75
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/shra_r_qb.c
> @@ -0,0 +1,35 @@
> +#include "io.h"
> +
> +int main()
> +{
> +    int rd, rt;
> +    int result;
> +
> +    rt = 0x12345678;
> +    result = 0x02070B0F;
> +
> +    __asm
> +        ("shra_r.qb %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("shra_r.qb wrong\n");
> +        return -1;
> +    }
> +
> +    rt = 0x87654321;
> +    result = 0xF10D0804;
> +
> +    __asm
> +        ("shra_r.qb %0, %1, 0x03\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("shra_r.qb wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/shrav_ob.c 
> b/tests/tcg/mips/mips64-dspr2/shrav_ob.c
> new file mode 100644
> index 0000000..fbdfbab
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/shrav_ob.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs;
> +    long long res;
> +
> +    rt = 0x1234567887654321;
> +    rs = 0x4;
> +    res = 0xf1f3f5f7f8060402;
> +
> +    asm ("shrav.ob %0, %1, %2"
> +        : "=r"(rd)
> +        : "r"(rt), "r"(rs)
> +        );
> +
> +    if (rd != res) {
> +        printf("shra.ob error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/shrav_qb.c 
> b/tests/tcg/mips/mips64-dspr2/shrav_qb.c
> new file mode 100644
> index 0000000..a716203
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/shrav_qb.c
> @@ -0,0 +1,37 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x03;
> +    rt = 0x12345678;
> +    result = 0x02060A0F;
> +
> +    __asm
> +        ("shrav.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("shrav.qb error\n");
> +        return -1;
> +    }
> +
> +    rs = 0x03;
> +    rt = 0x87654321;
> +    result = 0xFFFFFFFFF00C0804;
> +
> +    __asm
> +        ("shrav.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("shrav.qb error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/shrav_r_ob.c 
> b/tests/tcg/mips/mips64-dspr2/shrav_r_ob.c
> new file mode 100644
> index 0000000..b80100a
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/shrav_r_ob.c
> @@ -0,0 +1,22 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt, rs;
> +    long long res;
> +
> +    rt = 0x1234567887654321;
> +    rs = 0x4;
> +    res = 0xe3e7ebf0f1ede9e5;
> +
> +    asm ("shrav_r.ob %0, %1, %2"
> +        : "=r"(rd)
> +        : "r"(rt), "r"(rs)
> +        );
> +
> +    if (rd != res) {
> +        printf("shra_r.ob error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/shrav_r_qb.c 
> b/tests/tcg/mips/mips64-dspr2/shrav_r_qb.c
> new file mode 100644
> index 0000000..009080b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/shrav_r_qb.c
> @@ -0,0 +1,37 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x03;
> +    rt = 0x12345678;
> +    result = 0x02070B0F;
> +
> +    __asm
> +        ("shrav_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("shrav_r.qb error\n");
> +        return -1;
> +    }
> +
> +    rs = 0x03;
> +    rt = 0x87654321;
> +    result = 0xFFFFFFFFF10D0804;
> +
> +    __asm
> +        ("shrav_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("shrav_r.qb error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/shrl_ph.c 
> b/tests/tcg/mips/mips64-dspr2/shrl_ph.c
> new file mode 100644
> index 0000000..e32d976
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/shrl_ph.c
> @@ -0,0 +1,22 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rt;
> +    long long result;
> +
> +    rt     = 0x12345678;
> +    result = 0x009102B3;
> +
> +    __asm
> +        ("shrl.ph %0, %1, 0x05\n\t"
> +         : "=r"(rd)
> +         : "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("shrl.ph error!\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/shrlv_ph.c 
> b/tests/tcg/mips/mips64-dspr2/shrlv_ph.c
> new file mode 100644
> index 0000000..58c5488
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/shrlv_ph.c
> @@ -0,0 +1,23 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs     = 0x05;
> +    rt     = 0x12345678;
> +    result = 0x009102B3;
> +
> +    __asm
> +        ("shrlv.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rt), "r"(rs)
> +        );
> +    if (rd != result) {
> +        printf("shrlv.ph error!\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subqh_ph.c 
> b/tests/tcg/mips/mips64-dspr2/subqh_ph.c
> new file mode 100644
> index 0000000..9037401
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subqh_ph.c
> @@ -0,0 +1,23 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x456709AB;
> +
> +    __asm
> +        ("subqh.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("subqh.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subqh_r_ph.c 
> b/tests/tcg/mips/mips64-dspr2/subqh_r_ph.c
> new file mode 100644
> index 0000000..b8f9d2f
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subqh_r_ph.c
> @@ -0,0 +1,23 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x456809AC;
> +
> +    __asm
> +        ("subqh_r.ph %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("subqh_r.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subqh_r_w.c 
> b/tests/tcg/mips/mips64-dspr2/subqh_r_w.c
> new file mode 100644
> index 0000000..b025e40
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subqh_r_w.c
> @@ -0,0 +1,23 @@
> +#include"io.h"
> +
> +int main()
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x456789AC;
> +
> +    __asm
> +        ("subqh_r.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("subqh_r.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subqh_w.c 
> b/tests/tcg/mips/mips64-dspr2/subqh_w.c
> new file mode 100644
> index 0000000..65f1760
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subqh_w.c
> @@ -0,0 +1,23 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0x456789AB;
> +
> +    __asm
> +        ("subqh.w %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("subqh.w error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subu_ph.c 
> b/tests/tcg/mips/mips64-dspr2/subu_ph.c
> new file mode 100644
> index 0000000..60a6b1b
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subu_ph.c
> @@ -0,0 +1,26 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x87654321;
> +    rt = 0x12345678;
> +    result    = 0x7531ECA9;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subu.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    if (dsp != resultdsp || rd  != result) {
> +        printf("subu.ph error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subu_qh.c 
> b/tests/tcg/mips/mips64-dspr2/subu_qh.c
> new file mode 100644
> index 0000000..911cb34
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subu_qh.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dspreg, result, dspresult;
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEF1;
> +    result = 0x000000000000000F;
> +    dspresult = 0x01;
> +
> +    __asm("subu.qh %0, %2, %3\n\t"
> +          "rddsp %1\n\t"
> +          : "=r"(rd), "=r"(dspreg)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subu.qh error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subu_s_ph.c 
> b/tests/tcg/mips/mips64-dspr2/subu_s_ph.c
> new file mode 100644
> index 0000000..ae32cc0
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subu_s_ph.c
> @@ -0,0 +1,25 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dsp;
> +    long long result, resultdsp;
> +
> +    rs = 0x87654321;
> +    rt = 0x12345678;
> +    result    = 0x75310000;
> +    resultdsp = 0x01;
> +
> +    __asm
> +        ("subu_s.ph %0, %2, %3\n\t"
> +         "rddsp %1\n\t"
> +         : "=r"(rd), "=r"(dsp)
> +         : "r"(rs), "r"(rt)
> +        );
> +    dsp = (dsp >> 20) & 0x01;
> +    if (dsp != resultdsp || rd  != result) {
> +        printf("subu_s.ph error\n");
> +        return -1;
> +    }
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subu_s_qh.c 
> b/tests/tcg/mips/mips64-dspr2/subu_s_qh.c
> new file mode 100644
> index 0000000..78be739
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subu_s_qh.c
> @@ -0,0 +1,24 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, dspreg, result, dspresult;
> +    rs = 0x123456789ABCDEF0;
> +    rt = 0x123456789ABCDEF1;
> +    result = 0x0000000000000000;
> +    dspresult = 0x01;
> +
> +    __asm("subu_s.qh %0, %2, %3\n\t"
> +          "rddsp %1\n\t"
> +          : "=r"(rd), "=r"(dspreg)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    dspreg = ((dspreg >> 20) & 0x01);
> +    if ((rd != result) || (dspreg != dspresult)) {
> +        printf("subu_s.qh error\n\t");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subuh_ob.c 
> b/tests/tcg/mips/mips64-dspr2/subuh_ob.c
> new file mode 100644
> index 0000000..f74e8ef
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subuh_ob.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +
> +    rd = 0x0;
> +    rs = 0x246856789ABCDEF0;
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x091A000000000000;
> +
> +    __asm("subuh.ob %0, %1, %2\n\t"
> +          : "=r"(rd)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    if (rd != result) {
> +        printf("subuh.ob error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subuh_qb.c 
> b/tests/tcg/mips/mips64-dspr2/subuh_qb.c
> new file mode 100644
> index 0000000..aac7a83
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subuh_qb.c
> @@ -0,0 +1,23 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xC5E7092B;
> +
> +    __asm
> +        ("subuh.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("subuh.qb wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subuh_r_ob.c 
> b/tests/tcg/mips/mips64-dspr2/subuh_r_ob.c
> new file mode 100644
> index 0000000..fc20ffd
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subuh_r_ob.c
> @@ -0,0 +1,23 @@
> +#include "io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt, result;
> +
> +    rd = 0x0;
> +    rs = 0x246956789ABCDEF0;
> +    rt = 0x123456789ABCDEF0;
> +    result = 0x091B000000000000;
> +
> +    __asm("subuh.ob %0, %1, %2\n\t"
> +          : "=r"(rd)
> +          : "r"(rs), "r"(rt)
> +         );
> +
> +    if (rd != result) {
> +        printf("subuh.ob error\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}
> diff --git a/tests/tcg/mips/mips64-dspr2/subuh_r_qb.c 
> b/tests/tcg/mips/mips64-dspr2/subuh_r_qb.c
> new file mode 100644
> index 0000000..149d1aa
> --- /dev/null
> +++ b/tests/tcg/mips/mips64-dspr2/subuh_r_qb.c
> @@ -0,0 +1,23 @@
> +#include"io.h"
> +
> +int main(void)
> +{
> +    long long rd, rs, rt;
> +    long long result;
> +
> +    rs = 0x12345678;
> +    rt = 0x87654321;
> +    result = 0xC6E80A2C;
> +
> +    __asm
> +        ("subuh_r.qb %0, %1, %2\n\t"
> +         : "=r"(rd)
> +         : "r"(rs), "r"(rt)
> +        );
> +    if (rd != result) {
> +        printf("subuh_r.qb wrong\n");
> +        return -1;
> +    }
> +
> +    return 0;
> +}

This part seems fine, though given most instruction check is done with a
single value, I wonder if it is really useful.

-- 
Aurelien Jarno                          GPG: 1024D/F1BCDB73
address@hidden                 http://www.aurel32.net



reply via email to

[Prev in Thread] Current Thread [Next in Thread]