1// Copyright (c) 2008 The Regents of The University of Michigan
2// All rights reserved.
3//
4// Redistribution and use in source and binary forms, with or without
5// modification, are permitted provided that the following conditions are
6// met: redistributions of source code must retain the above copyright
7// notice, this list of conditions and the following disclaimer;
8// redistributions in binary form must reproduce the above copyright
9// notice, this list of conditions and the following disclaimer in the
10// documentation and/or other materials provided with the distribution;
11// neither the name of the copyright holders nor the names of its
12// contributors may be used to endorse or promote products derived from
13// this software without specific prior written permission.
14//
15// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26//
27// Authors: Gabe Black
28
29////////////////////////////////////////////////////////////////////
30//
31// Decode the three byte opcodes with the 0f3a prefix.
32//
33format WarnUnimpl {
34    'X86ISA::ThreeByte0F3AOpcode': decode LEGACY_OP {
35        1: decode OPCODE_OP {
36            0x08: roundps_Vdq_Wdq_Ib();
37            0x09: roundpd_Vdq_Wdq_Ib();
38            0x0A: roundss_Vss_Wss_Ib();
39            0x0B: roundsd_Vsd_Wsd_Ib();
40            0x0C: blendps_Vdq_Wdq_Ib();
41            0x0D: blendpd_Vdq_Wdq_Ib();
42            0x0E: pblendw_Vdq_Wdq_Ib();
43            0x0F: palignr_Vdq_Wdq_Ib();
44            0x14: pextrb_Rd_or_Mb_Vdq_Ib();
45            0x15: decode MODRM_MOD {
46                0x3: Inst::PEXTRW(Rd,Vdq,Ib);
47                default: pextrw_Mw_Vdq_Ib();
48            }
49            0x16: pextrd_pextrq_Ed_or_Eq_Vdq_Ib();
50            0x17: extractps_Ed_Vdq_Ib();
51            0x20: pinsrb_Vdq_Rd_or_Rq_or_Mb_Ib();
52            0x21: insertps_Vdq_Udq_or_Md_Ib();
53            0x22: pinsrd_pinsrq_Vdq_Ed_or_Eq_Ib();
54            0x40: dpps_Vdq_Wdq_Ib();
55            0x41: dppd_Vdq_Wdq_Ib();
56            0x42: pcmpistrm_Vdq_Wdq_Ib();
57            0x43: pcmpistri_Vdq_Wdq_Ib();
58            default: Inst::UD2();
59        }
60        default: decode OPCODE_OP {
61            0x0F: palignr_Pq_Qq_Ib();
62            default: Inst::UD2();
63        }
64    }
65}
66