right_logical_shift.py revision 6707
15081Sgblack@eecs.umich.edu# Copyright (c) 2007 The Hewlett-Packard Development Company 25081Sgblack@eecs.umich.edu# All rights reserved. 35081Sgblack@eecs.umich.edu# 45081Sgblack@eecs.umich.edu# Redistribution and use of this software in source and binary forms, 55081Sgblack@eecs.umich.edu# with or without modification, are permitted provided that the 65081Sgblack@eecs.umich.edu# following conditions are met: 75081Sgblack@eecs.umich.edu# 85081Sgblack@eecs.umich.edu# The software must be used only for Non-Commercial Use which means any 95081Sgblack@eecs.umich.edu# use which is NOT directed to receiving any direct monetary 105081Sgblack@eecs.umich.edu# compensation for, or commercial advantage from such use. Illustrative 115081Sgblack@eecs.umich.edu# examples of non-commercial use are academic research, personal study, 125081Sgblack@eecs.umich.edu# teaching, education and corporate research & development. 135081Sgblack@eecs.umich.edu# Illustrative examples of commercial use are distributing products for 145081Sgblack@eecs.umich.edu# commercial advantage and providing services using the software for 155081Sgblack@eecs.umich.edu# commercial advantage. 165081Sgblack@eecs.umich.edu# 175081Sgblack@eecs.umich.edu# If you wish to use this software or functionality therein that may be 185081Sgblack@eecs.umich.edu# covered by patents for commercial use, please contact: 195081Sgblack@eecs.umich.edu# Director of Intellectual Property Licensing 205081Sgblack@eecs.umich.edu# Office of Strategy and Technology 215081Sgblack@eecs.umich.edu# Hewlett-Packard Company 225081Sgblack@eecs.umich.edu# 1501 Page Mill Road 235081Sgblack@eecs.umich.edu# Palo Alto, California 94304 245081Sgblack@eecs.umich.edu# 255081Sgblack@eecs.umich.edu# Redistributions of source code must retain the above copyright notice, 265081Sgblack@eecs.umich.edu# this list of conditions and the following disclaimer. Redistributions 275081Sgblack@eecs.umich.edu# in binary form must reproduce the above copyright notice, this list of 285081Sgblack@eecs.umich.edu# conditions and the following disclaimer in the documentation and/or 295081Sgblack@eecs.umich.edu# other materials provided with the distribution. Neither the name of 305081Sgblack@eecs.umich.edu# the COPYRIGHT HOLDER(s), HEWLETT-PACKARD COMPANY, nor the names of its 315081Sgblack@eecs.umich.edu# contributors may be used to endorse or promote products derived from 325081Sgblack@eecs.umich.edu# this software without specific prior written permission. No right of 335081Sgblack@eecs.umich.edu# sublicense is granted herewith. Derivatives of the software and 345081Sgblack@eecs.umich.edu# output created using the software may be prepared, but only for 355081Sgblack@eecs.umich.edu# Non-Commercial Uses. Derivatives of the software may be shared with 365081Sgblack@eecs.umich.edu# others provided: (i) the others agree to abide by the list of 375081Sgblack@eecs.umich.edu# conditions herein which includes the Non-Commercial Use restrictions; 385081Sgblack@eecs.umich.edu# and (ii) such Derivatives of the software include the above copyright 395081Sgblack@eecs.umich.edu# notice to acknowledge the contribution from this software where 405081Sgblack@eecs.umich.edu# applicable, this list of conditions and the disclaimer below. 415081Sgblack@eecs.umich.edu# 425081Sgblack@eecs.umich.edu# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 435081Sgblack@eecs.umich.edu# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 445081Sgblack@eecs.umich.edu# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 455081Sgblack@eecs.umich.edu# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 465081Sgblack@eecs.umich.edu# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 475081Sgblack@eecs.umich.edu# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 485081Sgblack@eecs.umich.edu# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 495081Sgblack@eecs.umich.edu# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 505081Sgblack@eecs.umich.edu# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 515081Sgblack@eecs.umich.edu# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 525081Sgblack@eecs.umich.edu# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 535081Sgblack@eecs.umich.edu# 545081Sgblack@eecs.umich.edu# Authors: Gabe Black 555081Sgblack@eecs.umich.edu 565081Sgblack@eecs.umich.edumicrocode = ''' 576584Sgblack@eecs.umich.edudef macroop PSRLW_XMM_XMM { 586584Sgblack@eecs.umich.edu msrl xmmh, xmmh, xmmlm, size=2, ext=0 596584Sgblack@eecs.umich.edu msrl xmml, xmml, xmmlm, size=2, ext=0 606584Sgblack@eecs.umich.edu}; 616584Sgblack@eecs.umich.edu 626584Sgblack@eecs.umich.edudef macroop PSRLW_XMM_M { 636584Sgblack@eecs.umich.edu ldfp ufp1, seg, sib, disp, dataSize=8 646584Sgblack@eecs.umich.edu msrl xmml, xmml, ufp1, size=2, ext=0 656584Sgblack@eecs.umich.edu msrl xmmh, xmmh, ufp1, size=2, ext=0 666584Sgblack@eecs.umich.edu}; 676584Sgblack@eecs.umich.edu 686584Sgblack@eecs.umich.edudef macroop PSRLW_XMM_P { 696584Sgblack@eecs.umich.edu rdip t7 706584Sgblack@eecs.umich.edu ldfp ufp1, seg, riprel, disp, dataSize=8 716584Sgblack@eecs.umich.edu msrl xmml, xmml, ufp1, size=2, ext=0 726584Sgblack@eecs.umich.edu msrl xmmh, xmmh, ufp1, size=2, ext=0 736584Sgblack@eecs.umich.edu}; 746584Sgblack@eecs.umich.edu 756584Sgblack@eecs.umich.edudef macroop PSRLW_XMM_I { 766584Sgblack@eecs.umich.edu msrli xmml, xmml, imm, size=2, ext=0 776584Sgblack@eecs.umich.edu msrli xmmh, xmmh, imm, size=2, ext=0 786584Sgblack@eecs.umich.edu}; 796584Sgblack@eecs.umich.edu 806584Sgblack@eecs.umich.edudef macroop PSRLD_XMM_XMM { 816584Sgblack@eecs.umich.edu msrl xmmh, xmmh, xmmlm, size=4, ext=0 826584Sgblack@eecs.umich.edu msrl xmml, xmml, xmmlm, size=4, ext=0 836584Sgblack@eecs.umich.edu}; 846584Sgblack@eecs.umich.edu 856584Sgblack@eecs.umich.edudef macroop PSRLD_XMM_M { 866584Sgblack@eecs.umich.edu ldfp ufp1, seg, sib, disp, dataSize=8 876584Sgblack@eecs.umich.edu msrl xmml, xmml, ufp1, size=4, ext=0 886584Sgblack@eecs.umich.edu msrl xmmh, xmmh, ufp1, size=4, ext=0 896584Sgblack@eecs.umich.edu}; 906584Sgblack@eecs.umich.edu 916584Sgblack@eecs.umich.edudef macroop PSRLD_XMM_P { 926584Sgblack@eecs.umich.edu rdip t7 936584Sgblack@eecs.umich.edu ldfp ufp1, seg, riprel, disp, dataSize=8 946584Sgblack@eecs.umich.edu msrl xmml, xmml, ufp1, size=4, ext=0 956584Sgblack@eecs.umich.edu msrl xmmh, xmmh, ufp1, size=4, ext=0 966584Sgblack@eecs.umich.edu}; 976584Sgblack@eecs.umich.edu 986584Sgblack@eecs.umich.edudef macroop PSRLD_XMM_I { 996584Sgblack@eecs.umich.edu msrli xmml, xmml, imm, size=4, ext=0 1006584Sgblack@eecs.umich.edu msrli xmmh, xmmh, imm, size=4, ext=0 1016584Sgblack@eecs.umich.edu}; 1026584Sgblack@eecs.umich.edu 1036584Sgblack@eecs.umich.edudef macroop PSRLQ_XMM_XMM { 1046584Sgblack@eecs.umich.edu msrl xmmh, xmmh, xmmlm, size=8, ext=0 1056584Sgblack@eecs.umich.edu msrl xmml, xmml, xmmlm, size=8, ext=0 1066584Sgblack@eecs.umich.edu}; 1076584Sgblack@eecs.umich.edu 1086584Sgblack@eecs.umich.edudef macroop PSRLQ_XMM_M { 1096584Sgblack@eecs.umich.edu ldfp ufp1, seg, sib, disp, dataSize=8 1106584Sgblack@eecs.umich.edu msrl xmml, xmml, ufp1, size=8, ext=0 1116584Sgblack@eecs.umich.edu msrl xmmh, xmmh, ufp1, size=8, ext=0 1126584Sgblack@eecs.umich.edu}; 1136584Sgblack@eecs.umich.edu 1146584Sgblack@eecs.umich.edudef macroop PSRLQ_XMM_P { 1156584Sgblack@eecs.umich.edu rdip t7 1166584Sgblack@eecs.umich.edu ldfp ufp1, seg, riprel, disp, dataSize=8 1176584Sgblack@eecs.umich.edu msrl xmml, xmml, ufp1, size=8, ext=0 1186584Sgblack@eecs.umich.edu msrl xmmh, xmmh, ufp1, size=8, ext=0 1196584Sgblack@eecs.umich.edu}; 1206584Sgblack@eecs.umich.edu 1216584Sgblack@eecs.umich.edudef macroop PSRLQ_XMM_I { 1226584Sgblack@eecs.umich.edu msrli xmml, xmml, imm, size=8, ext=0 1236584Sgblack@eecs.umich.edu msrli xmmh, xmmh, imm, size=8, ext=0 1246584Sgblack@eecs.umich.edu}; 1256707Svince@csl.cornell.edu 1266707Svince@csl.cornell.edudef macroop PSRLDQ_XMM_I { 1276707Svince@csl.cornell.edu limm t2, 8 1286707Svince@csl.cornell.edu subi t1, t2, imm, flags=(ECF,), dataSize=1 1296707Svince@csl.cornell.edu br label("psrldq_less_8"), flags=(nCECF,) 1306707Svince@csl.cornell.edu # Greater than 8 1316707Svince@csl.cornell.edu 1326707Svince@csl.cornell.edu limm t2, 16 1336707Svince@csl.cornell.edu subi t1, t2, imm, flags=(ECF,), dataSize=1 1346707Svince@csl.cornell.edu br label("psrldq_less_16"), flags=(nCECF,) 1356707Svince@csl.cornell.edu 1366707Svince@csl.cornell.edu # Greater than 16 1376707Svince@csl.cornell.edu 1386707Svince@csl.cornell.edu lfpimm xmml, 0 1396707Svince@csl.cornell.edu lfpimm xmmh, 0 1406707Svince@csl.cornell.edu br label("psrldq_end") 1416707Svince@csl.cornell.edu 1426707Svince@csl.cornell.edupsrldq_less_16: 1436707Svince@csl.cornell.edu 1446707Svince@csl.cornell.edu # Between 8 and 16 1456707Svince@csl.cornell.edu 1466707Svince@csl.cornell.edu msrli xmml, xmmh, "(IMMEDIATE-8)<<3", size=8, ext=0 1476707Svince@csl.cornell.edu lfpimm xmmh, 0 1486707Svince@csl.cornell.edu br label("psrldq_end") 1496707Svince@csl.cornell.edu 1506707Svince@csl.cornell.edupsrldq_less_8: 1516707Svince@csl.cornell.edu 1526707Svince@csl.cornell.edu # Less than 8 1536707Svince@csl.cornell.edu 1546707Svince@csl.cornell.edu mslli ufp1, xmmh, "(8-IMMEDIATE) << 3", size=8, ext=0 1556707Svince@csl.cornell.edu msrli xmml, xmml, "IMMEDIATE << 3", size=8, ext=0 1566707Svince@csl.cornell.edu msrli xmmh, xmmh, "IMMEDIATE << 3", size=8, ext=0 1576707Svince@csl.cornell.edu mor xmml, xmml, ufp1 1586707Svince@csl.cornell.edu 1596707Svince@csl.cornell.edupsrldq_end: 1606707Svince@csl.cornell.edu fault "NoFault" 1616707Svince@csl.cornell.edu}; 1626584Sgblack@eecs.umich.edu''' 163