unpack_and_interleave.py revision 6533:2977e2e2dc27
1# Copyright (c) 2007 The Hewlett-Packard Development Company 2# All rights reserved. 3# 4# Redistribution and use of this software in source and binary forms, 5# with or without modification, are permitted provided that the 6# following conditions are met: 7# 8# The software must be used only for Non-Commercial Use which means any 9# use which is NOT directed to receiving any direct monetary 10# compensation for, or commercial advantage from such use. Illustrative 11# examples of non-commercial use are academic research, personal study, 12# teaching, education and corporate research & development. 13# Illustrative examples of commercial use are distributing products for 14# commercial advantage and providing services using the software for 15# commercial advantage. 16# 17# If you wish to use this software or functionality therein that may be 18# covered by patents for commercial use, please contact: 19# Director of Intellectual Property Licensing 20# Office of Strategy and Technology 21# Hewlett-Packard Company 22# 1501 Page Mill Road 23# Palo Alto, California 94304 24# 25# Redistributions of source code must retain the above copyright notice, 26# this list of conditions and the following disclaimer. Redistributions 27# in binary form must reproduce the above copyright notice, this list of 28# conditions and the following disclaimer in the documentation and/or 29# other materials provided with the distribution. Neither the name of 30# the COPYRIGHT HOLDER(s), HEWLETT-PACKARD COMPANY, nor the names of its 31# contributors may be used to endorse or promote products derived from 32# this software without specific prior written permission. No right of 33# sublicense is granted herewith. Derivatives of the software and 34# output created using the software may be prepared, but only for 35# Non-Commercial Uses. Derivatives of the software may be shared with 36# others provided: (i) the others agree to abide by the list of 37# conditions herein which includes the Non-Commercial Use restrictions; 38# and (ii) such Derivatives of the software include the above copyright 39# notice to acknowledge the contribution from this software where 40# applicable, this list of conditions and the disclaimer below. 41# 42# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 43# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 44# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 45# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 46# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 47# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 48# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 49# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 50# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 51# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 52# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 53# 54# Authors: Gabe Black 55 56microcode = ''' 57def macroop PUNPCKLBW_XMM_XMM { 58 unpack xmmh, xmml, xmmlm, sel=1, size=1 59 unpack xmml, xmml, xmmlm, sel=0, size=1 60}; 61 62def macroop PUNPCKLBW_XMM_M { 63 ldfp ufp1, seg, sib, disp, dataSize=8 64 unpack xmmh, xmml, ufp1, sel=1, size=1 65 unpack xmml, xmml, ufp1, sel=0, size=1 66}; 67 68def macroop PUNPCKLBW_XMM_P { 69 rdip t7 70 ldfp ufp1, seg, riprel, disp, dataSize=8 71 unpack xmmh, xmml, ufp1, sel=1, size=1 72 unpack xmml, xmml, ufp1, sel=0, size=1 73}; 74 75def macroop PUNPCKLWD_XMM_XMM { 76 unpack xmmh, xmml, xmmlm, sel=1, size=2 77 unpack xmml, xmml, xmmlm, sel=0, size=2 78}; 79 80def macroop PUNPCKLWD_XMM_M { 81 ldfp ufp1, seg, sib, disp, dataSize=8 82 unpack xmmh, xmml, ufp1, sel=1, size=2 83 unpack xmml, xmml, ufp1, sel=0, size=2 84}; 85 86def macroop PUNPCKLWD_XMM_P { 87 rdip t7 88 ldfp ufp1, seg, riprel, disp, dataSize=8 89 unpack xmmh, xmml, ufp1, sel=1, size=2 90 unpack xmml, xmml, ufp1, sel=0, size=2 91}; 92 93def macroop PUNPCKLDQ_XMM_XMM { 94 unpack xmmh, xmml, xmmlm, sel=1, size=4 95 unpack xmml, xmml, xmmlm, sel=0, size=4 96}; 97 98def macroop PUNPCKLDQ_XMM_M { 99 ldfp ufp1, seg, sib, disp, dataSize=8 100 unpack xmmh, xmml, ufp1, sel=1, size=4 101 unpack xmml, xmml, ufp1, sel=0, size=4 102}; 103 104def macroop PUNPCKLDQ_XMM_P { 105 rdip t7 106 ldfp ufp1, seg, riprel, disp, dataSize=8 107 unpack xmmh, xmml, ufp1, sel=1, size=4 108 unpack xmml, xmml, ufp1, sel=0, size=4 109}; 110 111def macroop PUNPCKHBW_XMM_XMM { 112 unpack xmml, xmmh, xmmhm, sel=0, size=1 113 unpack xmmh, xmmh, xmmhm, sel=1, size=1 114}; 115 116def macroop PUNPCKHBW_XMM_M { 117 lea t1, seg, sib, disp, dataSize=asz 118 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 119 unpack xmml, xmmh, ufp1, sel=0, size=1 120 unpack xmmh, xmmh, ufp1, sel=1, size=1 121}; 122 123def macroop PUNPCKHBW_XMM_P { 124 rdip t7 125 lea t1, seg, riprel, disp, dataSize=asz 126 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 127 unpack xmml, xmmh, ufp1, sel=0, size=1 128 unpack xmmh, xmmh, ufp1, sel=1, size=1 129}; 130 131def macroop PUNPCKHWD_XMM_XMM { 132 unpack xmml, xmmh, xmmhm, sel=0, size=2 133 unpack xmmh, xmmh, xmmhm, sel=1, size=2 134}; 135 136def macroop PUNPCKHWD_XMM_M { 137 lea t1, seg, sib, disp, dataSize=asz 138 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 139 unpack xmml, xmmh, ufp1, sel=0, size=2 140 unpack xmmh, xmmh, ufp1, sel=1, size=2 141}; 142 143def macroop PUNPCKHWD_XMM_P { 144 rdip t7 145 lea t1, seg, riprel, disp, dataSize=asz 146 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 147 unpack xmml, xmmh, ufp1, sel=0, size=2 148 unpack xmmh, xmmh, ufp1, sel=1, size=2 149}; 150 151def macroop PUNPCKHDQ_XMM_XMM { 152 unpack xmml, xmmh, xmmhm, sel=0, size=4 153 unpack xmmh, xmmh, xmmhm, sel=1, size=4 154}; 155 156def macroop PUNPCKHDQ_XMM_M { 157 lea t1, seg, sib, disp, dataSize=asz 158 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 159 unpack xmml, xmmh, ufp1, sel=0, size=4 160 unpack xmmh, xmmh, ufp1, sel=1, size=4 161}; 162 163def macroop PUNPCKHDQ_XMM_P { 164 rdip t7 165 lea t1, seg, riprel, disp, dataSize=asz 166 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 167 unpack xmml, xmmh, ufp1, sel=0, size=4 168 unpack xmmh, xmmh, ufp1, sel=1, size=4 169}; 170 171def macroop PUNPCKHQDQ_XMM_XMM { 172 movfp xmml, xmmh 173 movfp xmmh, xmmhm 174}; 175 176def macroop PUNPCKHQDQ_XMM_M { 177 lea t1, seg, sib, disp, dataSize=asz 178 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 179 movfp xmml, xmmh 180 movfp xmmh, ufp1 181}; 182 183def macroop PUNPCKHQDQ_XMM_P { 184 rdip t7 185 lea t1, seg, riprel, disp, dataSize=asz 186 ldfp ufp1, seg, riprel, 8, dataSize=8 187 movfp xmml, xmmh 188 movfp xmmh, ufp1 189}; 190 191def macroop PUNPCKLQDQ_XMM_XMM { 192 movfp xmmh, xmmlm 193}; 194 195def macroop PUNPCKLQDQ_XMM_M { 196 ldfp xmmh, seg, sib, disp, dataSize=8 197}; 198 199def macroop PUNPCKLQDQ_XMM_P { 200 rdip t7 201 ldfp xmmh, seg, riprel, disp, dataSize=8 202}; 203''' 204