unpack_and_interleave.py revision 7087:fb8d5786ff30
1# Copyright (c) 2007 The Hewlett-Packard Development Company 2# All rights reserved. 3# 4# The license below extends only to copyright in the software and shall 5# not be construed as granting a license to any other intellectual 6# property including but not limited to intellectual property relating 7# to a hardware implementation of the functionality of the software 8# licensed hereunder. You may use the software subject to the license 9# terms below provided that you ensure that this notice is replicated 10# unmodified and in its entirety in all distributions of the software, 11# modified or unmodified, in source code or in binary form. 12# 13# Redistribution and use in source and binary forms, with or without 14# modification, are permitted provided that the following conditions are 15# met: redistributions of source code must retain the above copyright 16# notice, this list of conditions and the following disclaimer; 17# redistributions in binary form must reproduce the above copyright 18# notice, this list of conditions and the following disclaimer in the 19# documentation and/or other materials provided with the distribution; 20# neither the name of the copyright holders nor the names of its 21# contributors may be used to endorse or promote products derived from 22# this software without specific prior written permission. 23# 24# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 25# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 26# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 27# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 28# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 29# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 30# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 31# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 32# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 33# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 34# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 35# 36# Authors: Gabe Black 37 38microcode = ''' 39def macroop PUNPCKLBW_XMM_XMM { 40 unpack xmmh, xmml, xmmlm, ext=1, size=1 41 unpack xmml, xmml, xmmlm, ext=0, size=1 42}; 43 44def macroop PUNPCKLBW_XMM_M { 45 ldfp ufp1, seg, sib, disp, dataSize=8 46 unpack xmmh, xmml, ufp1, ext=1, size=1 47 unpack xmml, xmml, ufp1, ext=0, size=1 48}; 49 50def macroop PUNPCKLBW_XMM_P { 51 rdip t7 52 ldfp ufp1, seg, riprel, disp, dataSize=8 53 unpack xmmh, xmml, ufp1, ext=1, size=1 54 unpack xmml, xmml, ufp1, ext=0, size=1 55}; 56 57def macroop PUNPCKLWD_XMM_XMM { 58 unpack xmmh, xmml, xmmlm, ext=1, size=2 59 unpack xmml, xmml, xmmlm, ext=0, size=2 60}; 61 62def macroop PUNPCKLWD_XMM_M { 63 ldfp ufp1, seg, sib, disp, dataSize=8 64 unpack xmmh, xmml, ufp1, ext=1, size=2 65 unpack xmml, xmml, ufp1, ext=0, size=2 66}; 67 68def macroop PUNPCKLWD_XMM_P { 69 rdip t7 70 ldfp ufp1, seg, riprel, disp, dataSize=8 71 unpack xmmh, xmml, ufp1, ext=1, size=2 72 unpack xmml, xmml, ufp1, ext=0, size=2 73}; 74 75def macroop PUNPCKLDQ_XMM_XMM { 76 unpack xmmh, xmml, xmmlm, ext=1, size=4 77 unpack xmml, xmml, xmmlm, ext=0, size=4 78}; 79 80def macroop PUNPCKLDQ_XMM_M { 81 ldfp ufp1, seg, sib, disp, dataSize=8 82 unpack xmmh, xmml, ufp1, ext=1, size=4 83 unpack xmml, xmml, ufp1, ext=0, size=4 84}; 85 86def macroop PUNPCKLDQ_XMM_P { 87 rdip t7 88 ldfp ufp1, seg, riprel, disp, dataSize=8 89 unpack xmmh, xmml, ufp1, ext=1, size=4 90 unpack xmml, xmml, ufp1, ext=0, size=4 91}; 92 93def macroop PUNPCKHBW_XMM_XMM { 94 unpack xmml, xmmh, xmmhm, ext=0, size=1 95 unpack xmmh, xmmh, xmmhm, ext=1, size=1 96}; 97 98def macroop PUNPCKHBW_XMM_M { 99 lea t1, seg, sib, disp, dataSize=asz 100 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 101 unpack xmml, xmmh, ufp1, ext=0, size=1 102 unpack xmmh, xmmh, ufp1, ext=1, size=1 103}; 104 105def macroop PUNPCKHBW_XMM_P { 106 rdip t7 107 lea t1, seg, riprel, disp, dataSize=asz 108 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 109 unpack xmml, xmmh, ufp1, ext=0, size=1 110 unpack xmmh, xmmh, ufp1, ext=1, size=1 111}; 112 113def macroop PUNPCKHWD_XMM_XMM { 114 unpack xmml, xmmh, xmmhm, ext=0, size=2 115 unpack xmmh, xmmh, xmmhm, ext=1, size=2 116}; 117 118def macroop PUNPCKHWD_XMM_M { 119 lea t1, seg, sib, disp, dataSize=asz 120 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 121 unpack xmml, xmmh, ufp1, ext=0, size=2 122 unpack xmmh, xmmh, ufp1, ext=1, size=2 123}; 124 125def macroop PUNPCKHWD_XMM_P { 126 rdip t7 127 lea t1, seg, riprel, disp, dataSize=asz 128 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 129 unpack xmml, xmmh, ufp1, ext=0, size=2 130 unpack xmmh, xmmh, ufp1, ext=1, size=2 131}; 132 133def macroop PUNPCKHDQ_XMM_XMM { 134 unpack xmml, xmmh, xmmhm, ext=0, size=4 135 unpack xmmh, xmmh, xmmhm, ext=1, size=4 136}; 137 138def macroop PUNPCKHDQ_XMM_M { 139 lea t1, seg, sib, disp, dataSize=asz 140 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 141 unpack xmml, xmmh, ufp1, ext=0, size=4 142 unpack xmmh, xmmh, ufp1, ext=1, size=4 143}; 144 145def macroop PUNPCKHDQ_XMM_P { 146 rdip t7 147 lea t1, seg, riprel, disp, dataSize=asz 148 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 149 unpack xmml, xmmh, ufp1, ext=0, size=4 150 unpack xmmh, xmmh, ufp1, ext=1, size=4 151}; 152 153def macroop PUNPCKHQDQ_XMM_XMM { 154 movfp xmml, xmmh 155 movfp xmmh, xmmhm 156}; 157 158def macroop PUNPCKHQDQ_XMM_M { 159 lea t1, seg, sib, disp, dataSize=asz 160 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 161 movfp xmml, xmmh 162 movfp xmmh, ufp1 163}; 164 165def macroop PUNPCKHQDQ_XMM_P { 166 rdip t7 167 lea t1, seg, riprel, disp, dataSize=asz 168 ldfp ufp1, seg, riprel, 8, dataSize=8 169 movfp xmml, xmmh 170 movfp xmmh, ufp1 171}; 172 173def macroop PUNPCKLQDQ_XMM_XMM { 174 movfp xmmh, xmmlm 175}; 176 177def macroop PUNPCKLQDQ_XMM_M { 178 ldfp xmmh, seg, sib, disp, dataSize=8 179}; 180 181def macroop PUNPCKLQDQ_XMM_P { 182 rdip t7 183 ldfp xmmh, seg, riprel, disp, dataSize=8 184}; 185''' 186