15081Sgblack@eecs.umich.edu# Copyright (c) 2007 The Hewlett-Packard Development Company 25081Sgblack@eecs.umich.edu# All rights reserved. 35081Sgblack@eecs.umich.edu# 47087Snate@binkert.org# The license below extends only to copyright in the software and shall 57087Snate@binkert.org# not be construed as granting a license to any other intellectual 67087Snate@binkert.org# property including but not limited to intellectual property relating 77087Snate@binkert.org# to a hardware implementation of the functionality of the software 87087Snate@binkert.org# licensed hereunder. You may use the software subject to the license 97087Snate@binkert.org# terms below provided that you ensure that this notice is replicated 107087Snate@binkert.org# unmodified and in its entirety in all distributions of the software, 117087Snate@binkert.org# modified or unmodified, in source code or in binary form. 125081Sgblack@eecs.umich.edu# 137087Snate@binkert.org# Redistribution and use in source and binary forms, with or without 147087Snate@binkert.org# modification, are permitted provided that the following conditions are 157087Snate@binkert.org# met: redistributions of source code must retain the above copyright 167087Snate@binkert.org# notice, this list of conditions and the following disclaimer; 177087Snate@binkert.org# redistributions in binary form must reproduce the above copyright 187087Snate@binkert.org# notice, this list of conditions and the following disclaimer in the 197087Snate@binkert.org# documentation and/or other materials provided with the distribution; 207087Snate@binkert.org# neither the name of the copyright holders nor the names of its 215081Sgblack@eecs.umich.edu# contributors may be used to endorse or promote products derived from 227087Snate@binkert.org# this software without specific prior written permission. 235081Sgblack@eecs.umich.edu# 245081Sgblack@eecs.umich.edu# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 255081Sgblack@eecs.umich.edu# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 265081Sgblack@eecs.umich.edu# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 275081Sgblack@eecs.umich.edu# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 285081Sgblack@eecs.umich.edu# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 295081Sgblack@eecs.umich.edu# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 305081Sgblack@eecs.umich.edu# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 315081Sgblack@eecs.umich.edu# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 325081Sgblack@eecs.umich.edu# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 335081Sgblack@eecs.umich.edu# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 345081Sgblack@eecs.umich.edu# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 355081Sgblack@eecs.umich.edu# 365081Sgblack@eecs.umich.edu# Authors: Gabe Black 375081Sgblack@eecs.umich.edu 385081Sgblack@eecs.umich.edumicrocode = ''' 399009Smarc.orr@gmail.comdef macroop HADDPS_XMM_XMM { 409009Smarc.orr@gmail.com shuffle ufp1, xmml, xmmh, ext=((0 << 0) | (2 << 2)), size=4 419009Smarc.orr@gmail.com shuffle ufp2, xmml, xmmh, ext=((1 << 0) | (3 << 2)), size=4 429009Smarc.orr@gmail.com shuffle ufp3, xmmlm, xmmhm, ext=((0 << 0) | (2 << 2)), size=4 439009Smarc.orr@gmail.com shuffle ufp4, xmmlm, xmmhm, ext=((1 << 0) | (3 << 2)), size=4 449009Smarc.orr@gmail.com 459009Smarc.orr@gmail.com maddf xmml, ufp1, ufp2, size=4 469009Smarc.orr@gmail.com maddf xmmh, ufp3, ufp4, size=4 479009Smarc.orr@gmail.com}; 489009Smarc.orr@gmail.com 499009Smarc.orr@gmail.comdef macroop HADDPS_XMM_M { 509009Smarc.orr@gmail.com ldfp ufp1, seg, sib, disp, dataSize=8 519009Smarc.orr@gmail.com ldfp ufp2, seg, sib, "DISPLACEMENT+8", dataSize=8 529009Smarc.orr@gmail.com 539009Smarc.orr@gmail.com shuffle ufp3, xmml, xmmh, ext=((0 << 0) | (2 << 2)), size=4 549009Smarc.orr@gmail.com shuffle ufp4, xmml, xmmh, ext=((1 << 0) | (3 << 2)), size=4 559009Smarc.orr@gmail.com shuffle ufp5, ufp1, ufp2, ext=((0 << 0) | (2 << 2)), size=4 569009Smarc.orr@gmail.com shuffle ufp6, ufp1, ufp2, ext=((1 << 0) | (3 << 2)), size=4 579009Smarc.orr@gmail.com 589009Smarc.orr@gmail.com maddf xmml, ufp3, ufp4, size=4 599009Smarc.orr@gmail.com maddf xmmh, ufp5, ufp6, size=4 609009Smarc.orr@gmail.com}; 619009Smarc.orr@gmail.com 629009Smarc.orr@gmail.comdef macroop HADDPS_XMM_P { 639009Smarc.orr@gmail.com rdip t7 649009Smarc.orr@gmail.com ldfp ufp1, seg, riprel, disp, dataSize=8 659009Smarc.orr@gmail.com ldfp ufp2, seg, riprel, "DISPLACEMENT+8", dataSize=8 669009Smarc.orr@gmail.com 679009Smarc.orr@gmail.com shuffle ufp3, xmml, xmmh, ext=((0 << 0) | (2 << 2)), size=4 689009Smarc.orr@gmail.com shuffle ufp4, xmml, xmmh, ext=((1 << 0) | (3 << 2)), size=4 699009Smarc.orr@gmail.com shuffle ufp5, ufp1, ufp2, ext=((0 << 0) | (2 << 2)), size=4 709009Smarc.orr@gmail.com shuffle ufp6, ufp1, ufp2, ext=((1 << 0) | (3 << 2)), size=4 719009Smarc.orr@gmail.com 729009Smarc.orr@gmail.com maddf xmml, ufp3, ufp4, size=4 739009Smarc.orr@gmail.com maddf xmmh, ufp5, ufp6, size=4 749009Smarc.orr@gmail.com}; 756705Svince@csl.cornell.edu 766705Svince@csl.cornell.edudef macroop HADDPD_XMM_XMM { 776799Sgblack@eecs.umich.edu maddf ufp1, xmmh , xmml, size=8, ext=Scalar 786799Sgblack@eecs.umich.edu maddf xmmh, xmmlm, xmmhm, size=8, ext=Scalar 796705Svince@csl.cornell.edu movfp xmml, ufp1 806705Svince@csl.cornell.edu}; 816705Svince@csl.cornell.edu 826705Svince@csl.cornell.edudef macroop HADDPD_XMM_M { 836705Svince@csl.cornell.edu ldfp ufp1, seg, sib, disp, dataSize=8 846705Svince@csl.cornell.edu ldfp ufp2, seg, sib, "DISPLACEMENT+8", dataSize=8 856799Sgblack@eecs.umich.edu maddf xmml, xmmh, xmml, size=8, ext=Scalar 866799Sgblack@eecs.umich.edu maddf xmmh, ufp1, ufp2, size=8, ext=Scalar 876705Svince@csl.cornell.edu}; 886705Svince@csl.cornell.edu 896705Svince@csl.cornell.edudef macroop HADDPD_XMM_P { 906705Svince@csl.cornell.edu rdip t7 916705Svince@csl.cornell.edu ldfp ufp1, seg, riprel, disp, dataSize=8 926705Svince@csl.cornell.edu ldfp ufp2, seg, riprel, "DISPLACEMENT+8", dataSize=8 936799Sgblack@eecs.umich.edu maddf xmml, xmmh, xmml, size=8, ext=Scalar 946799Sgblack@eecs.umich.edu maddf xmmh, ufp1, ufp2, size=8, ext=Scalar 956705Svince@csl.cornell.edu}; 965081Sgblack@eecs.umich.edu''' 97