* ========== Copyright Header Begin ==========================================
* OpenSPARC T2 Processor File: saveld1.s
* Copyright (C) 1995-2007 Sun Microsystems, Inc. All Rights Reserved
* 4150 Network Circle, Santa Clara, California 95054, U.S.A.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; version 2 of the License.
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
* For the avoidance of doubt, and except that if any non-GPL license
* choice is available it will apply instead, Sun elects to use only
* the General Public License version 2 (GPLv2) at this time for any
* software where a choice of GPL license versions is made
* available with the language indicating that GPLv2 or any later version
* may be used, or where a choice of which version of the GPL is applied is
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* ========== Copyright Header End ============================================
.ident "FOCUSCASE: focus.pm,v 1.1 2003/04/23 17:53:39 somePerson Exp somePerson $ spc_basic_isa3.pl FOCUS_SEED=846072888"
.ident "BY rg131678 ON Tue Aug 5 17:58:50 CDT 2003"
.ident "Using Instruction Hash for Focus :$Id: saveld1.s,v 1.3 2007/07/05 22:02:02 drp Exp $"
/************************************************************************
************************************************************************/
setx DIAG_DATA_AREA, %g1, %g3
!# Initialize registers ..
INIT_TH_FP_REG(%l7, %f0, 0x55555555aaaaaaaa)
INIT_TH_FP_REG(%l7, %f2, 0xaaaaaaaa55555555)
INIT_TH_FP_REG(%l7, %f4, 0xfedcba9876543210)
INIT_TH_FP_REG(%l7, %f6, 0x0123456789abcdef)
INIT_TH_FP_REG(%l7, %f8, 0x55aa55aaff00ff00)
INIT_TH_FP_REG(%l7, %f10, 0x1111111111111111)
INIT_TH_FP_REG(%l7, %f12, 0x8888888888888888)
INIT_TH_FP_REG(%l7, %f14, 0xfedcba9876543210)
!# Execute some ALU ops ..
fmovsneg %icc, %f12, %f10
fandnot2s %f11, %f8, %f10
fmuld8ulx16 %f0, %f13, %f0
faligndata %f12, %f6, %f6
fandnot1 %f10, %f10, %f12
fmuld8sux16 %f1, %f6, %f6
fpsub32s %f12, %f10, %f10
faligndata %f2, %f12, %f14
fmul8sux16 %f6, %f10, %f10
faligndata %f8, %f8, %f14
fmuld8sux16 %f7, %f8, %f0
fmuld8ulx16 %f7, %f4, %f0
fmovdneg %icc, %f13, %f10
fmovdpos %xcc, %f11, %f11
fmul8ulx16 %f6, %f0, %f12
faligndata %f4, %f12, %f14
fmul8ulx16 %f6, %f10, %f0
fmuld8ulx16 %f1, %f2, %f4
fmuld8sux16 %f8, %f11, %f12
faligndata %f10, %f4, %f2
fmuld8ulx16 %f4, %f11, %f8
fmul8x16al %f6, %f8, %f10
fmul8ulx16 %f12, %f6, %f12
fmul8x16au %f14, %f2, %f14
fmuld8sux16 %f5, %f0, %f12
fmuld8sux16 %f1, %f4, %f0
fmovrdgez %l2, %f10, %f10
fmuld8ulx16 %f13, %f12, %f4
fandnot2 %f14, %f12, %f12
fpsub16s %f12, %f12, %f12
fmuld8ulx16 %f2, %f4, %f14
fmuld8ulx16 %f0, %f1, %f0
fmul8ulx16 %f10, %f0, %f4
fmul8x16al %f2, %f10, %f6
fmovdneg %xcc, %f12, %f12
fandnot2s %f1, %f15, %f12
fmuld8ulx16 %f3, %f4, %f2
fmul8sux16 %f4, %f6, %f12
fmul8x16au %f5, %f11, %f2
fmuld8sux16 %f2, %f12, %f10
fmovspos %xcc, %f14, %f10
faligndata %f6, %f10, %f12
fmul8ulx16 %f12, %f10, %f2
fandnot1 %f14, %f10, %f12
fmuld8ulx16 %f0, %f8, %f6
fmul8ulx16 %f14, %f10, %f14
fmul8sux16 %f4, %f14, %f0
fmul8ulx16 %f6, %f14, %f8
fmovrsgez %o5, %f15, %f13
fmul8x16au %f12, %f5, %f14
fpsub16s %f10, %f13, %f15
fmovrdlez %o7, %f10, %f12
fmuld8ulx16 %f0, %f3, %f12
fmovrdlez %l2, %f12, %f12
faligndata %f4, %f12, %f0
fpadd32s %f13, %f13, %f11
fmul8x16au %f1, %f6, %f14
fandnot2s %f11, %f15, %f3
fmuld8ulx16 %f7, %f0, %f12
fmovsleu %xcc, %f15, %f15
fandnot1s %f11, %f12, %f12
fmul8ulx16 %f4, %f12, %f10
fmuld8sux16 %f3, %f10, %f14
fpadd32s %f12, %f14, %f15
fmul8sux16 %f8, %f8, %f14
fmuld8sux16 %f13, %f5, %f12
fmul8ulx16 %f10, %f4, %f4
fmul8sux16 %f0, %f12, %f8
fmul8ulx16 %f12, %f14, %f10
fmuld8sux16 %f3, %f9, %f4
fmul8sux16 %f14, %f2, %f6
fmuld8ulx16 %f5, %f9, %f14
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
EXIT_GOOD /* test finish */
/************************************************************************
************************************************************************/