* ========== Copyright Header Begin ==========================================
* OpenSPARC T2 Processor File: spc_basic_isa2_fc_0.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 $ jk1 FOCUS_SEED=709814444"
.ident "BY jb140515 ON Thu Jun 19 16:28:43 CDT 2003"
.ident "Using Instruction Hash for Focus :$Id: spc_basic_isa2_fc_0.s,v 1.3 2007/07/05 22:02:03 drp Exp $"
/************************************************************************
************************************************************************/
!# 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 ..
fmul8x16al %f2, %f13, %f2
fmul8x16au %f15, %f12, %f2
fmovspos %icc, %f11, %f10
fmovsleu %xcc, %f13, %f12
fmovsneg %icc, %f15, %f10
fandnot2s %f12, %f15, %f1
fmuld8sux16 %f0, %f2, %f8
faligndata %f4, %f12, %f12
fmul8x16al %f7, %f15, %f8
fmovsleu %xcc, %f14, %f14
fmuld8ulx16 %f5, %f12, %f14
fmuld8ulx16 %f12, %f12, %f6
fmovsleu %icc, %f12, %f15
fmovsleu %icc, %f13, %f12
fmul8x16al %f15, %f8, %f6
fmul8sux16 %f0, %f10, %f14
fmul8x16al %f10, %f6, %f12
fmuld8sux16 %f14, %f9, %f2
fandnot2 %f10, %f14, %f10
fmul8x16al %f13, %f14, %f8
fmovrslez %l3, %f15, %f14
fmul8x16au %f15, %f11, %f12
fmuld8ulx16 %f9, %f5, %f0
fmul8x16al %f3, %f14, %f8
fmul8sux16 %f8, %f2, %f10
fmul8x16au %f3, %f15, %f0
fmul8x16al %f7, %f15, %f4
fmul8x16au %f14, %f14, %f12
fmuld8ulx16 %f11, %f1, %f2
faligndata %f12, %f0, %f4
fandnot1 %f10, %f12, %f14
fmuld8sux16 %f11, %f2, %f2
fmuld8ulx16 %f7, %f10, %f2
fmul8x16au %f4, %f3, %f14
fandnot2s %f15, %f5, %f13
fmuld8sux16 %f10, %f13, %f8
fmovrslez %l5, %f11, %f10
fmul8x16al %f3, %f14, %f10
fmuld8sux16 %f1, %f0, %f10
fmuld8ulx16 %f4, %f7, %f2
fmuld8sux16 %f8, %f10, %f6
fmul8x16au %f15, %f12, %f6
fandnot2s %f9, %f15, %f15
fmul8x16al %f11, %f9, %f8
fandnot1s %f5, %f15, %f11
fmul8x16au %f2, %f15, %f2
fmul8x16al %f13, %f6, %f14
faligndata %f8, %f2, %f10
fmuld8sux16 %f0, %f7, %f6
fmul8x16al %f15, %f6, %f10
fmul8x16al %f8, %f15, %f4
fmul8x16au %f11, %f0, %f0
fmovsneg %icc, %f11, %f14
fmovsneg %xcc, %f14, %f10
fmuld8sux16 %f2, %f12, %f8
faligndata %f14, %f4, %f10
fmovsleu %icc, %f10, %f15
fmul8x16al %f11, %f5, %f4
fmovrdgez %i6, %f10, %f14
fmuld8ulx16 %f4, %f12, %f8
fmovsneg %icc, %f11, %f11
fpsub16s %f11, %f12, %f12
fandnot2s %f0, %f11, %f10
fmovrslez %i0, %f13, %f15
fmul8x16au %f11, %f1, %f0
faligndata %f10, %f2, %f4
fmul8sux16 %f12, %f14, %f4
faligndata %f4, %f8, %f14
fmuld8sux16 %f0, %f4, %f14
fmuld8ulx16 %f7, %f4, %f14
faligndata %f4, %f10, %f0
fmovdleu %xcc, %f11, %f11
fmul8x16al %f14, %f12, %f10
fmul8x16al %f11, %f1, %f12
fmul8sux16 %f10, %f0, %f14
fmovdpos %xcc, %f10, %f13
fmovrsgez %l2, %f15, %f14
fmuld8sux16 %f11, %f11, %f4
fandnot1s %f11, %f12, %f1
fmuld8sux16 %f2, %f7, %f8
fmul8sux16 %f12, %f2, %f6
fmul8x16au %f15, %f5, %f14
fandnot1s %f13, %f10, %f11
fmovsleu %xcc, %f13, %f12
fmuld8sux16 %f5, %f0, %f0
fmovrslez %g5, %f12, %f14
fandnot2s %f10, %f11, %f3
fmul8x16al %f13, %f11, %f0
fandnot2s %f12, %f11, %f13
fmovrslez %o2, %f14, %f15
faligndata %f12, %f10, %f8
fmul8x16au %f11, %f4, %f2
fmuld8sux16 %f3, %f6, %f8
fmuld8ulx16 %f11, %f3, %f10
fmuld8ulx16 %f7, %f14, %f0
fmul8sux16 %f0, %f0, %f14
fmul8x16al %f0, %f14, %f8
fmuld8sux16 %f2, %f4, %f6
fmuld8ulx16 %f2, %f4, %f4
fmuld8ulx16 %f2, %f10, %f2
fmovrsgez %o5, %f11, %f13
fmuld8sux16 %f0, %f3, %f6
faligndata %f10, %f8, %f12
fmuld8sux16 %f9, %f14, %f2
fmovsneg %xcc, %f10, %f13
fmuld8sux16 %f11, %f9, %f10
fmul8x16al %f3, %f9, %f10
fmuld8sux16 %f4, %f3, %f2
fandnot2s %f12, %f11, %f15
fandnot1s %f10, %f0, %f10
fpadd32s %f12, %f14, %f10
faligndata %f6, %f10, %f4
fmovsneg %icc, %f15, %f15
fmul8sux16 %f8, %f4, %f10
fmul8sux16 %f0, %f10, %f2
faligndata %f4, %f10, %f0
fmovdneg %icc, %f11, %f13
fmul8x16al %f0, %f10, %f6
fmul8x16al %f7, %f2, %f10
fmuld8sux16 %f15, %f5, %f12
fmuld8sux16 %f14, %f14, %f14
fmuld8ulx16 %f13, %f9, %f6
fmuld8sux16 %f0, %f11, %f10
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
EXIT_GOOD /* test finish */
/************************************************************************
************************************************************************/