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 PCMPEQB_MMX_MMX { 58 mcmpi2r mmx, mmx, mmxm, size=1, ext=0 59}; 60 61def macroop PCMPEQB_MMX_M { 62 ldfp ufp1, seg, sib, disp, dataSize=8 63 mcmpi2r mmx, mmx, ufp1, size=1, ext=0 64}; 65 66def macroop PCMPEQB_MMX_P { 67 rdip t7 68 ldfp ufp1, seg, riprel, disp, dataSize=8 69 mcmpi2r mmx, mmx, ufp1, size=1, ext=0 70}; 71 72def macroop PCMPEQW_MMX_MMX { 73 mcmpi2r mmx, mmx, mmxm, size=2, ext=0 74}; 75 76def macroop PCMPEQW_MMX_M { 77 ldfp ufp1, seg, sib, disp, dataSize=8 78 mcmpi2r mmx, mmx, ufp1, size=2, ext=0 79}; 80 81def macroop PCMPEQW_MMX_P { 82 rdip t7 83 ldfp ufp1, seg, riprel, disp, dataSize=8 84 mcmpi2r mmx, mmx, ufp1, size=2, ext=0 85}; 86 87def macroop PCMPEQD_MMX_MMX { 88 mcmpi2r mmx, mmx, mmxm, size=4, ext=0 89}; 90 91def macroop PCMPEQD_MMX_M { 92 ldfp ufp1, seg, sib, disp, dataSize=8 93 mcmpi2r mmx, mmx, ufp1, size=4, ext=0 94}; 95 96def macroop PCMPEQD_MMX_P { 97 rdip t7 98 ldfp ufp1, seg, riprel, disp, dataSize=8 99 mcmpi2r mmx, mmx, ufp1, size=4, ext=0 100}; 101 102def macroop PCMPGTB_MMX_MMX { 103 mcmpi2r mmx, mmx, mmxm, size=1, ext=2 104}; 105 106def macroop PCMPGTB_MMX_M { 107 ldfp ufp1, seg, sib, disp, dataSize=8 108 mcmpi2r mmx, mmx, ufp1, size=1, ext=2 109}; 110 111def macroop PCMPGTB_MMX_P { 112 rdip t7 113 ldfp ufp1, seg, riprel, disp, dataSize=8 114 mcmpi2r mmx, mmx, ufp1, size=1, ext=2 115}; 116 117def macroop PCMPGTW_MMX_MMX { 118 mcmpi2r mmx, mmx, mmxm, size=2, ext=2 119}; 120 121def macroop PCMPGTW_MMX_M { 122 ldfp ufp1, seg, sib, disp, dataSize=8 123 mcmpi2r mmx, mmx, ufp1, size=2, ext=2 124}; 125 126def macroop PCMPGTW_MMX_P { 127 rdip t7 128 ldfp ufp1, seg, riprel, disp, dataSize=8 129 mcmpi2r mmx, mmx, ufp1, size=2, ext=2 130}; 131 132def macroop PCMPGTD_MMX_MMX { 133 mcmpi2r mmx, mmx, mmxm, size=4, ext=2 134}; 135 136def macroop PCMPGTD_MMX_M { 137 ldfp ufp1, seg, sib, disp, dataSize=8 138 mcmpi2r mmx, mmx, ufp1, size=4, ext=2 139}; 140 141def macroop PCMPGTD_MMX_P { 142 rdip t7 143 ldfp ufp1, seg, riprel, disp, dataSize=8 144 mcmpi2r mmx, mmx, ufp1, size=4, ext=2 145}; 146'''
| 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 PCMPEQB_MMX_MMX { 40 mcmpi2r mmx, mmx, mmxm, size=1, ext=0 41}; 42 43def macroop PCMPEQB_MMX_M { 44 ldfp ufp1, seg, sib, disp, dataSize=8 45 mcmpi2r mmx, mmx, ufp1, size=1, ext=0 46}; 47 48def macroop PCMPEQB_MMX_P { 49 rdip t7 50 ldfp ufp1, seg, riprel, disp, dataSize=8 51 mcmpi2r mmx, mmx, ufp1, size=1, ext=0 52}; 53 54def macroop PCMPEQW_MMX_MMX { 55 mcmpi2r mmx, mmx, mmxm, size=2, ext=0 56}; 57 58def macroop PCMPEQW_MMX_M { 59 ldfp ufp1, seg, sib, disp, dataSize=8 60 mcmpi2r mmx, mmx, ufp1, size=2, ext=0 61}; 62 63def macroop PCMPEQW_MMX_P { 64 rdip t7 65 ldfp ufp1, seg, riprel, disp, dataSize=8 66 mcmpi2r mmx, mmx, ufp1, size=2, ext=0 67}; 68 69def macroop PCMPEQD_MMX_MMX { 70 mcmpi2r mmx, mmx, mmxm, size=4, ext=0 71}; 72 73def macroop PCMPEQD_MMX_M { 74 ldfp ufp1, seg, sib, disp, dataSize=8 75 mcmpi2r mmx, mmx, ufp1, size=4, ext=0 76}; 77 78def macroop PCMPEQD_MMX_P { 79 rdip t7 80 ldfp ufp1, seg, riprel, disp, dataSize=8 81 mcmpi2r mmx, mmx, ufp1, size=4, ext=0 82}; 83 84def macroop PCMPGTB_MMX_MMX { 85 mcmpi2r mmx, mmx, mmxm, size=1, ext=2 86}; 87 88def macroop PCMPGTB_MMX_M { 89 ldfp ufp1, seg, sib, disp, dataSize=8 90 mcmpi2r mmx, mmx, ufp1, size=1, ext=2 91}; 92 93def macroop PCMPGTB_MMX_P { 94 rdip t7 95 ldfp ufp1, seg, riprel, disp, dataSize=8 96 mcmpi2r mmx, mmx, ufp1, size=1, ext=2 97}; 98 99def macroop PCMPGTW_MMX_MMX { 100 mcmpi2r mmx, mmx, mmxm, size=2, ext=2 101}; 102 103def macroop PCMPGTW_MMX_M { 104 ldfp ufp1, seg, sib, disp, dataSize=8 105 mcmpi2r mmx, mmx, ufp1, size=2, ext=2 106}; 107 108def macroop PCMPGTW_MMX_P { 109 rdip t7 110 ldfp ufp1, seg, riprel, disp, dataSize=8 111 mcmpi2r mmx, mmx, ufp1, size=2, ext=2 112}; 113 114def macroop PCMPGTD_MMX_MMX { 115 mcmpi2r mmx, mmx, mmxm, size=4, ext=2 116}; 117 118def macroop PCMPGTD_MMX_M { 119 ldfp ufp1, seg, sib, disp, dataSize=8 120 mcmpi2r mmx, mmx, ufp1, size=4, ext=2 121}; 122 123def macroop PCMPGTD_MMX_P { 124 rdip t7 125 ldfp ufp1, seg, riprel, disp, dataSize=8 126 mcmpi2r mmx, mmx, ufp1, size=4, ext=2 127}; 128'''
|