* ========== Copyright Header Begin ==========================================
* OpenSPARC T2 Processor File: isa3_saverestore_fc1.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=339701460"
.ident "BY rg131678 ON Wed Aug 6 18:03:09 CDT 2003"
.ident "Using Instruction Hash for Focus :$Id: isa3_saverestore_fc1.s,v 1.3 2007/07/05 22:01:52 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 ..
fmuld8sux16 %f15, %f1, %f0
fmuld8sux16 %f9, %f5, %f0
fmul8sux16 %f6, %f10, %f12
fmul8x16al %f15, %f12, %f8
bshuffle %f12, %f10, %f10
fmovspos %xcc, %f15, %f11
faligndata %f6, %f12, %f10
fmul8x16al %f10, %f2, %f8
faligndata %f0, %f14, %f6
fmuld8ulx16 %f1, %f5, %f6
fmul8sux16 %f2, %f10, %f10
fmul8sux16 %f8, %f14, %f4
fmovdneg %icc, %f14, %f14
fmul8x16al %f13, %f12, %f4
fmuld8sux16 %f13, %f9, %f2
fmul8x16au %f3, %f5, %f10
fornot2s %f13, %f14, %f12
fmul8sux16 %f8, %f6, %f14
fmul8ulx16 %f14, %f2, %f8
fmul8x16au %f1, %f2, %f12
fmul8x16al %f4, %f4, %f14
fmovdneg %icc, %f10, %f11
fmuld8ulx16 %f3, %f6, %f12
fmul8x16au %f14, %f9, %f6
fmovrdgez %g2, %f14, %f12
fmovspos %icc, %f14, %f13
fandnot2s %f13, %f6, %f12
fmul8x16al %f10, %f11, %f8
bshuffle %f12, %f14, %f14
fmul8sux16 %f0, %f8, %f10
fmul8x16au %f2, %f6, %f10
fmul8sux16 %f10, %f4, %f8
fmuld8ulx16 %f2, %f4, %f2
fmovrdgez %g6, %f12, %f12
fmul8x16al %f10, %f6, %f10
fmuld8ulx16 %f2, %f3, %f14
fmul8x16au %f9, %f2, %f14
fmovspos %xcc, %f12, %f12
fmovdleu %xcc, %f15, %f14
fmovrdlez %o3, %f12, %f14
fmul8sux16 %f10, %f10, %f4
fmuld8ulx16 %f2, %f12, %f4
fmul8x16al %f12, %f13, %f4
fmovrslez %l3, %f13, %f15
fmuld8ulx16 %f11, %f6, %f4
fmul8ulx16 %f4, %f14, %f2
fmuld8sux16 %f5, %f4, %f12
fmuld8sux16 %f0, %f11, %f2
fmuld8sux16 %f9, %f8, %f14
fmul8sux16 %f10, %f4, %f14
fmovdneg %icc, %f10, %f11
fmul8sux16 %f0, %f14, %f10
fmul8ulx16 %f12, %f0, %f14
fmovrsgez %l6, %f10, %f10
fmul8x16au %f14, %f8, %f0
fmovdneg %xcc, %f13, %f13
fmuld8ulx16 %f9, %f8, %f2
fmul8x16al %f11, %f15, %f14
fornot2s %f11, %f14, %f10
fmovsleu %xcc, %f15, %f12
fmovdpos %xcc, %f10, %f15
fmul8sux16 %f14, %f2, %f8
faligndata %f10, %f14, %f10
fmuld8ulx16 %f12, %f6, %f12
fmovsleu %icc, %f11, %f11
faligndata %f10, %f4, %f10
fmuld8sux16 %f8, %f11, %f0
fmul8x16al %f6, %f13, %f12
faligndata %f10, %f10, %f0
fmovsleu %xcc, %f10, %f13
faligndata %f0, %f10, %f0
fmul8sux16 %f8, %f12, %f2
fpsub16s %f14, %f12, %f13
fmul8ulx16 %f12, %f8, %f10
fmul8x16au %f6, %f5, %f12
fmul8x16al %f0, %f14, %f10
fmovsleu %icc, %f10, %f10
fmul8ulx16 %f10, %f0, %f2
fmuld8ulx16 %f14, %f6, %f14
fmul8sux16 %f14, %f4, %f0
fmul8x16au %f15, %f0, %f0
fandnot1s %f10, %f6, %f12
fmuld8sux16 %f8, %f7, %f6
fandnot1s %f13, %f12, %f7
fmuld8sux16 %f14, %f12, %f4
fmuld8sux16 %f8, %f0, %f8
fandnot2s %f9, %f14, %f12
fmul8sux16 %f10, %f0, %f2
fmovspos %xcc, %f13, %f13
fmuld8ulx16 %f9, %f15, %f4
fandnot2s %f12, %f10, %f0
fmul8x16al %f4, %f13, %f8
fmul8x16au %f8, %f5, %f10
fmul8x16au %f6, %f15, %f6
fmovrslez %o4, %f15, %f10
fmuld8sux16 %f1, %f0, %f4
fmuld8sux16 %f2, %f14, %f12
fmovdleu %xcc, %f12, %f12
fmuld8ulx16 %f1, %f0, %f4
fmovsneg %icc, %f13, %f15
fandnot1s %f11, %f1, %f13
fmul8x16al %f12, %f4, %f2
faligndata %f0, %f4, %f12
fmuld8ulx16 %f13, %f13, %f4
fmuld8ulx16 %f5, %f8, %f6
fpsub32s %f12, %f11, %f15
fmovdleu %xcc, %f10, %f15
fmovrdgez %g3, %f10, %f12
faligndata %f12, %f0, %f4
fmuld8sux16 %f14, %f3, %f0
fmovdpos %icc, %f14, %f10
fmovrslez %i5, %f15, %f11
fmul8x16au %f10, %f10, %f8
fmovsneg %icc, %f14, %f14
fornot2s %f15, %f10, %f12
fmul8x16al %f4, %f10, %f8
fmovrdlez %i7, %f10, %f10
fmul8x16au %f4, %f10, %f10
fandnot1s %f13, %f12, %f4
fmovdneg %icc, %f15, %f12
fmuld8ulx16 %f7, %f12, %f2
fmul8x16au %f11, %f7, %f0
fmovrslez %i7, %f14, %f11
fandnot1s %f8, %f10, %f15
fmuld8sux16 %f1, %f11, %f14
fmul8sux16 %f0, %f14, %f14
fmuld8ulx16 %f4, %f2, %f6
fmul8ulx16 %f14, %f2, %f10
fmovsleu %icc, %f12, %f13
fmul8x16al %f5, %f12, %f14
fmul8x16au %f14, %f4, %f6
fmuld8sux16 %f10, %f8, %f4
fpadd16s %f11, %f12, %f12
fmuld8sux16 %f12, %f14, %f12
fmul8x16au %f11, %f2, %f14
fmovdneg %xcc, %f14, %f12
fmul8x16au %f14, %f14, %f10
fmuld8sux16 %f4, %f9, %f14
fmul8sux16 %f8, %f2, %f12
fmul8sux16 %f6, %f12, %f8
faligndata %f8, %f12, %f6
fmul8ulx16 %f2, %f10, %f2
fmuld8sux16 %f7, %f13, %f8
fmovrslez %o1, %f14, %f12
fmul8x16au %f2, %f7, %f10
fmuld8ulx16 %f6, %f2, %f8
fmul8x16al %f12, %f1, %f14
fmovsneg %icc, %f13, %f14
fmul8x16al %f3, %f12, %f2
fmuld8ulx16 %f9, %f11, %f14
fmuld8sux16 %f9, %f4, %f2
fmul8x16au %f4, %f14, %f0
fmul8x16au %f12, %f11, %f4
fmuld8ulx16 %f8, %f2, %f6
fmul8x16al %f7, %f13, %f8
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
EXIT_GOOD /* test finish */
/************************************************************************
************************************************************************/