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 UNPCKLPS_XMM_XMM { 58 unpack xmmh, xmml, xmmlm, ext=1, size=4 59 unpack xmml, xmml, xmmlm, ext=0, size=4 60}; 61 62def macroop UNPCKLPS_XMM_M { 63 ldfp ufp1, seg, sib, disp, dataSize=8 64 unpack xmmh, xmml, ufp1, ext=1, size=4 65 unpack xmml, xmml, ufp1, ext=0, size=4 66}; 67 68def macroop UNPCKLPS_XMM_P { 69 rdip t7 70 ldfp ufp1, seg, riprel, disp, dataSize=8 71 unpack xmmh, xmml, ufp1, ext=1, size=4 72 unpack xmml, xmml, ufp1, ext=0, size=4 73}; 74 75def macroop UNPCKLPD_XMM_XMM { 76 movfp xmmh, xmmlm 77}; 78 79def macroop UNPCKLPD_XMM_M { 80 ldfp xmmh, seg, sib, disp, dataSize=8 81}; 82 83def macroop UNPCKLPD_XMM_P { 84 rdip t7 85 ldfp xmmh, seg, riprel, disp, dataSize=8 86}; 87 88def macroop UNPCKHPS_XMM_XMM { 89 unpack xmml, xmmh, xmmhm, ext=0, size=4 90 unpack xmmh, xmmh, xmmhm, ext=1, size=4 91}; 92 93def macroop UNPCKHPS_XMM_M { 94 lea t1, seg, sib, disp, dataSize=asz 95 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 96 unpack xmml, xmmh, ufp1, ext=0, size=4 97 unpack xmmh, xmmh, ufp1, ext=1, size=4 98}; 99 100def macroop UNPCKHPS_XMM_P { 101 rdip t7 102 lea t1, seg, riprel, disp, dataSize=asz 103 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 104 unpack xmml, xmmh, ufp1, ext=0, size=4 105 unpack xmmh, xmmh, ufp1, ext=1, size=4 106}; 107 108def macroop UNPCKHPD_XMM_XMM { 109 movfp xmml, xmmh 110 movfp xmmh, xmmhm 111}; 112 113def macroop UNPCKHPD_XMM_M { 114 lea t1, seg, sib, disp, dataSize=asz 115 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 116 movfp xmml, xmmh 117 movfp xmmh, ufp1 118}; 119 120def macroop UNPCKHPD_XMM_P { 121 rdip t7 122 lea t1, seg, riprel, disp, dataSize=asz 123 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 124 movfp xmml, xmmh 125 movfp xmmh, ufp1 126}; 127'''
| 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 UNPCKLPS_XMM_XMM { 40 unpack xmmh, xmml, xmmlm, ext=1, size=4 41 unpack xmml, xmml, xmmlm, ext=0, size=4 42}; 43 44def macroop UNPCKLPS_XMM_M { 45 ldfp ufp1, seg, sib, disp, dataSize=8 46 unpack xmmh, xmml, ufp1, ext=1, size=4 47 unpack xmml, xmml, ufp1, ext=0, size=4 48}; 49 50def macroop UNPCKLPS_XMM_P { 51 rdip t7 52 ldfp ufp1, seg, riprel, disp, dataSize=8 53 unpack xmmh, xmml, ufp1, ext=1, size=4 54 unpack xmml, xmml, ufp1, ext=0, size=4 55}; 56 57def macroop UNPCKLPD_XMM_XMM { 58 movfp xmmh, xmmlm 59}; 60 61def macroop UNPCKLPD_XMM_M { 62 ldfp xmmh, seg, sib, disp, dataSize=8 63}; 64 65def macroop UNPCKLPD_XMM_P { 66 rdip t7 67 ldfp xmmh, seg, riprel, disp, dataSize=8 68}; 69 70def macroop UNPCKHPS_XMM_XMM { 71 unpack xmml, xmmh, xmmhm, ext=0, size=4 72 unpack xmmh, xmmh, xmmhm, ext=1, size=4 73}; 74 75def macroop UNPCKHPS_XMM_M { 76 lea t1, seg, sib, disp, dataSize=asz 77 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 78 unpack xmml, xmmh, ufp1, ext=0, size=4 79 unpack xmmh, xmmh, ufp1, ext=1, size=4 80}; 81 82def macroop UNPCKHPS_XMM_P { 83 rdip t7 84 lea t1, seg, riprel, disp, dataSize=asz 85 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 86 unpack xmml, xmmh, ufp1, ext=0, size=4 87 unpack xmmh, xmmh, ufp1, ext=1, size=4 88}; 89 90def macroop UNPCKHPD_XMM_XMM { 91 movfp xmml, xmmh 92 movfp xmmh, xmmhm 93}; 94 95def macroop UNPCKHPD_XMM_M { 96 lea t1, seg, sib, disp, dataSize=asz 97 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 98 movfp xmml, xmmh 99 movfp xmmh, ufp1 100}; 101 102def macroop UNPCKHPD_XMM_P { 103 rdip t7 104 lea t1, seg, riprel, disp, dataSize=asz 105 ldfp ufp1, seg, [1, t0, t1], 8, dataSize=8 106 movfp xmml, xmmh 107 movfp xmmh, ufp1 108}; 109'''
|