* ========== Copyright Header Begin ==========================================
* OpenSPARC T2 Processor File: isa3_saverestore_fc2.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=599728880"
.ident "BY rg131678 ON Wed Aug 6 18:03:30 CDT 2003"
.ident "Using Instruction Hash for Focus :$Id: isa3_saverestore_fc2.s,v 1.3 2007/07/05 22:01:53 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 ..
fandnot2s %f11, %f10, %f13
fmuld8sux16 %f13, %f10, %f4
fmovrdlez %i6, %f12, %f10
fmul8x16au %f13, %f10, %f0
fandnot1s %f14, %f3, %f12
fmuld8sux16 %f5, %f3, %f12
faligndata %f0, %f14, %f2
fmul8x16al %f2, %f4, %f12
fmul8x16au %f4, %f5, %f12
fmul8sux16 %f6, %f14, %f6
fmuld8ulx16 %f6, %f2, %f2
fmul8x16au %f15, %f9, %f14
fmuld8ulx16 %f11, %f13, %f14
fmul8sux16 %f4, %f4, %f14
fmuld8ulx16 %f12, %f11, %f14
fpadd32s %f11, %f15, %f13
fmuld8ulx16 %f15, %f10, %f12
fmul8ulx16 %f12, %f4, %f6
fmuld8sux16 %f9, %f4, %f12
fandnot2s %f10, %f10, %f5
fmul8x16al %f8, %f15, %f0
fmuld8ulx16 %f15, %f6, %f14
fandnot2s %f10, %f11, %f1
fmul8x16al %f5, %f14, %f12
fmul8x16au %f5, %f12, %f0
fmuld8sux16 %f10, %f3, %f8
fmovrsgez %o6, %f10, %f10
fmul8ulx16 %f2, %f12, %f8
fandnot2s %f15, %f11, %f13
faligndata %f12, %f10, %f12
fmuld8ulx16 %f1, %f15, %f4
fmuld8sux16 %f2, %f0, %f6
fmuld8ulx16 %f11, %f6, %f0
fmuld8sux16 %f14, %f0, %f4
fmovdneg %xcc, %f11, %f10
fandnot1s %f11, %f14, %f10
fmul8ulx16 %f10, %f12, %f6
fmul8ulx16 %f12, %f14, %f12
faligndata %f2, %f2, %f10
fmuld8sux16 %f14, %f11, %f4
fmuld8ulx16 %f10, %f0, %f14
fandnot2s %f14, %f8, %f10
fmovrdlez %g3, %f10, %f14
fmul8x16al %f10, %f14, %f4
fandnot1 %f14, %f14, %f12
fmuld8ulx16 %f8, %f6, %f14
fandnot2 %f10, %f14, %f12
fpsub16s %f14, %f12, %f11
fmul8ulx16 %f12, %f10, %f6
fmul8x16 %f12, %f14, %f14
fmuld8sux16 %f13, %f1, %f6
fmovdleu %icc, %f12, %f15
fmuld8ulx16 %f7, %f13, %f12
fandnot2s %f15, %f14, %f9
fmovspos %icc, %f10, %f13
fmuld8ulx16 %f1, %f8, %f0
fmovrdlez %g2, %f14, %f10
fmul8x16au %f9, %f12, %f6
fmul8x16al %f8, %f13, %f0
fmovspos %xcc, %f15, %f14
fornot1s %f10, %f12, %f13
fmovrsgez %i0, %f10, %f14
fmul8ulx16 %f14, %f14, %f0
fmuld8sux16 %f11, %f5, %f10
fmuld8ulx16 %f10, %f13, %f2
fmul8sux16 %f0, %f12, %f0
fmul8x16au %f0, %f14, %f14
fmuld8ulx16 %f11, %f0, %f6
fmovrdlez %l6, %f10, %f10
fmovdleu %icc, %f15, %f12
fmul8x16au %f6, %f3, %f12
fandnot1s %f15, %f13, %f11
fmovrdgez %l2, %f12, %f10
faligndata %f6, %f10, %f12
fmovrslez %g3, %f12, %f12
faligndata %f12, %f8, %f4
fandnot2s %f13, %f11, %f5
fmovspos %icc, %f14, %f10
fandnot2s %f13, %f11, %f8
faligndata %f0, %f2, %f10
fmul8x16au %f5, %f14, %f4
fmul8ulx16 %f2, %f14, %f14
fmovsleu %icc, %f11, %f10
fmuld8sux16 %f5, %f5, %f4
fmuld8ulx16 %f3, %f11, %f6
fmovrdlez %g2, %f14, %f14
fmul8sux16 %f10, %f0, %f2
fmuld8sux16 %f5, %f14, %f10
faligndata %f8, %f0, %f10
fmul8x16al %f14, %f14, %f14
fmuld8ulx16 %f3, %f11, %f4
fmovrdgez %g2, %f10, %f12
fmul8sux16 %f10, %f10, %f10
faligndata %f12, %f4, %f14
fmuld8ulx16 %f13, %f2, %f2
fmuld8ulx16 %f0, %f9, %f8
fmovrdgez %g5, %f12, %f10
fmul8x16au %f4, %f14, %f8
fmuld8sux16 %f2, %f5, %f6
fmul8x16al %f1, %f11, %f12
fmul8ulx16 %f8, %f14, %f12
fmul8x16al %f5, %f3, %f10
fmuld8sux16 %f14, %f1, %f12
fmovdneg %icc, %f11, %f11
fandnot2 %f12, %f12, %f10
fmuld8sux16 %f7, %f2, %f14
fmovdpos %xcc, %f12, %f15
fpadd32s %f10, %f14, %f12
fandnot1s %f14, %f11, %f7
fmovdleu %icc, %f10, %f10
fmovdleu %xcc, %f15, %f13
fmul8sux16 %f14, %f4, %f10
fmovdleu %icc, %f12, %f13
fmul8x16au %f13, %f12, %f4
fmul8sux16 %f12, %f8, %f12
fmul8x16au %f2, %f14, %f6
fmul8ulx16 %f8, %f0, %f14
fandnot2s %f2, %f14, %f13
fmuld8ulx16 %f5, %f6, %f4
fmuld8sux16 %f13, %f14, %f4
fmul8sux16 %f10, %f6, %f8
fmovrdgez %i3, %f14, %f12
fmuld8ulx16 %f2, %f14, %f6
fmuld8sux16 %f6, %f2, %f0
fmul8x16al %f12, %f11, %f6
fmuld8sux16 %f4, %f11, %f2
faligndata %f14, %f8, %f10
fmuld8sux16 %f9, %f14, %f0
fmovspos %xcc, %f14, %f10
fmuld8sux16 %f15, %f11, %f2
fmovsleu %icc, %f11, %f12
fandnot1s %f11, %f15, %f6
fmuld8sux16 %f8, %f7, %f2
fandnot2s %f13, %f13, %f9
fmovsleu %icc, %f13, %f15
bshuffle %f12, %f14, %f10
fmovspos %xcc, %f12, %f12
fmul8x16al %f7, %f11, %f2
fmul8sux16 %f12, %f0, %f14
fmuld8ulx16 %f3, %f10, %f8
fmul8x16al %f12, %f1, %f2
fmuld8sux16 %f7, %f11, %f2
fmul8x16au %f6, %f11, %f8
fmul8ulx16 %f6, %f10, %f8
fmul8sux16 %f14, %f12, %f8
fmul8x16au %f12, %f14, %f2
fmuld8ulx16 %f10, %f12, %f0
faligndata %f10, %f10, %f6
fmul8sux16 %f6, %f10, %f8
fandnot2 %f10, %f14, %f14
fmovrsgez %l1, %f11, %f12
fmuld8ulx16 %f2, %f5, %f10
fmul8sux16 %f14, %f8, %f12
fmuld8sux16 %f1, %f7, %f12
fandnot1s %f11, %f12, %f14
fmul8ulx16 %f8, %f4, %f14
fmul8x16au %f8, %f7, %f14
fmul8x16au %f13, %f2, %f10
fmul8x16al %f15, %f12, %f8
fmul8ulx16 %f6, %f4, %f12
fmul8x16au %f5, %f2, %f12
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
EXIT_GOOD /* test finish */
/************************************************************************
************************************************************************/