unpack_and_interleave.py (5081:2ccce8600a9d) | unpack_and_interleave.py (6543:a9a5dd560925) |
---|---|
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 --- 40 unchanged lines hidden (view full) --- 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 = ''' | 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 --- 40 unchanged lines hidden (view full) --- 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 = ''' |
57# UNPCKHPS 58# UNPCKHPD 59# UNPCKLPS 60# UNPCKLPD | 57def macroop UNPCKLPS_XMM_XMM { 58 unpack xmmh, xmml, xmmlm, sel=1, size=4 59 unpack xmml, xmml, xmmlm, sel=0, size=4 60}; 61 62def macroop UNPCKLPS_XMM_M { 63 ldfp ufp1, seg, sib, disp, dataSize=8 64 unpack xmmh, xmml, ufp1, sel=1, size=4 65 unpack xmml, xmml, ufp1, sel=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, sel=1, size=4 72 unpack xmml, xmml, ufp1, sel=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, sel=0, size=4 90 unpack xmmh, xmmh, xmmhm, sel=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, sel=0, size=4 97 unpack xmmh, xmmh, ufp1, sel=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, sel=0, size=4 105 unpack xmmh, xmmh, ufp1, sel=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}; |
61''' | 127''' |