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 PMULHW_MMX_MMX { 58 mmuli mmx, mmx, mmxm, size=2, ext = Signed + "|" + MultHi 59}; 60 61def macroop PMULHW_MMX_M { 62 ldfp ufp1, seg, sib, disp, dataSize=8 63 mmuli mmx, mmx, ufp1, size=2, ext = Signed + "|" + MultHi 64}; 65 66def macroop PMULHW_MMX_P { 67 rdip t7 68 ldfp ufp1, seg, riprel, disp, dataSize=8 69 mmuli mmx, mmx, ufp1, size=2, ext = Signed + "|" + MultHi 70}; 71 72def macroop PMULLW_MMX_MMX { 73 mmuli mmx, mmx, mmxm, size=2, ext = Signed 74}; 75 76def macroop PMULLW_MMX_M { 77 ldfp ufp1, seg, sib, disp, dataSize=8 78 mmuli mmx, mmx, ufp1, size=2, ext = Signed 79}; 80 81def macroop PMULLW_MMX_P { 82 rdip t7 83 ldfp ufp1, seg, riprel, disp, dataSize=8 84 mmuli mmx, mmx, ufp1, size=2, ext = Signed 85}; 86 87def macroop PMULHRW_MMX_MMX { 88 mmuli mmx, mmx, mmxm, size=2, ext = Signed + "| 0x4 |" + MultHi 89}; 90 91def macroop PMULHRW_MMX_M { 92 ldfp ufp1, seg, sib, disp, dataSize=8 93 mmuli mmx, mmx, ufp1, size=2, ext = Signed + "| 0x4 |" + MultHi 94}; 95 96def macroop PMULHRW_MMX_P { 97 rdip t7 98 ldfp ufp1, seg, riprel, disp, dataSize=8 99 mmuli mmx, mmx, ufp1, size=2, ext = Signed + "| 0x4 |" + MultHi 100}; 101 102def macroop PMULHUW_MMX_MMX { 103 mmuli mmx, mmx, mmxm, size=2, ext = MultHi 104}; 105 106def macroop PMULHUW_MMX_M { 107 ldfp ufp1, seg, sib, disp, dataSize=8 108 mmuli mmx, mmx, ufp1, size=2, ext = MultHi 109}; 110 111def macroop PMULHUW_MMX_P { 112 rdip t7 113 ldfp ufp1, seg, riprel, disp, dataSize=8 114 mmuli mmx, mmx, ufp1, size=2, ext = MultHi 115}; 116 117def macroop PMULUDQ_MMX_MMX { 118 mmuli mmx, mmx, mmxm, srcSize=4, destSize=8, ext=Scalar 119}; 120 121def macroop PMULUDQ_MMX_M { 122 ldfp ufp1, seg, sib, disp, dataSize=8 123 mmuli mmx, mmx, ufp1, srcSize=4, destSize=8, ext=Scalar 124}; 125 126def macroop PMULUDQ_MMX_P { 127 rdip t7 128 ldfp ufp1, seg, riprel, disp, dataSize=8 129 mmuli mmx, mmx, ufp1, srcSize=4, destSize=8, ext=Scalar 130}; 131'''
| 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 PMULHW_MMX_MMX { 40 mmuli mmx, mmx, mmxm, size=2, ext = Signed + "|" + MultHi 41}; 42 43def macroop PMULHW_MMX_M { 44 ldfp ufp1, seg, sib, disp, dataSize=8 45 mmuli mmx, mmx, ufp1, size=2, ext = Signed + "|" + MultHi 46}; 47 48def macroop PMULHW_MMX_P { 49 rdip t7 50 ldfp ufp1, seg, riprel, disp, dataSize=8 51 mmuli mmx, mmx, ufp1, size=2, ext = Signed + "|" + MultHi 52}; 53 54def macroop PMULLW_MMX_MMX { 55 mmuli mmx, mmx, mmxm, size=2, ext = Signed 56}; 57 58def macroop PMULLW_MMX_M { 59 ldfp ufp1, seg, sib, disp, dataSize=8 60 mmuli mmx, mmx, ufp1, size=2, ext = Signed 61}; 62 63def macroop PMULLW_MMX_P { 64 rdip t7 65 ldfp ufp1, seg, riprel, disp, dataSize=8 66 mmuli mmx, mmx, ufp1, size=2, ext = Signed 67}; 68 69def macroop PMULHRW_MMX_MMX { 70 mmuli mmx, mmx, mmxm, size=2, ext = Signed + "| 0x4 |" + MultHi 71}; 72 73def macroop PMULHRW_MMX_M { 74 ldfp ufp1, seg, sib, disp, dataSize=8 75 mmuli mmx, mmx, ufp1, size=2, ext = Signed + "| 0x4 |" + MultHi 76}; 77 78def macroop PMULHRW_MMX_P { 79 rdip t7 80 ldfp ufp1, seg, riprel, disp, dataSize=8 81 mmuli mmx, mmx, ufp1, size=2, ext = Signed + "| 0x4 |" + MultHi 82}; 83 84def macroop PMULHUW_MMX_MMX { 85 mmuli mmx, mmx, mmxm, size=2, ext = MultHi 86}; 87 88def macroop PMULHUW_MMX_M { 89 ldfp ufp1, seg, sib, disp, dataSize=8 90 mmuli mmx, mmx, ufp1, size=2, ext = MultHi 91}; 92 93def macroop PMULHUW_MMX_P { 94 rdip t7 95 ldfp ufp1, seg, riprel, disp, dataSize=8 96 mmuli mmx, mmx, ufp1, size=2, ext = MultHi 97}; 98 99def macroop PMULUDQ_MMX_MMX { 100 mmuli mmx, mmx, mmxm, srcSize=4, destSize=8, ext=Scalar 101}; 102 103def macroop PMULUDQ_MMX_M { 104 ldfp ufp1, seg, sib, disp, dataSize=8 105 mmuli mmx, mmx, ufp1, srcSize=4, destSize=8, ext=Scalar 106}; 107 108def macroop PMULUDQ_MMX_P { 109 rdip t7 110 ldfp ufp1, seg, riprel, disp, dataSize=8 111 mmuli mmx, mmx, ufp1, srcSize=4, destSize=8, ext=Scalar 112}; 113'''
|