* ========== Copyright Header Begin ==========================================
* OpenSPARC T2 Processor File: isa2_raw_fc_2.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 $ /import/n2-aus-localdir1/somePerson/n2cdmspp/verif/diag/assembly/focus/spc_basic_isa2.pl FOCUS_SEED=832373419"
.ident "BY somePerson ON Thu Jul 17 12:43:04 CDT 2003"
.ident "Using Instruction Hash for Focus :$Id: isa2_raw_fc_2.s,v 1.3 2007/07/05 21:59:44 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 ..
fmuld8ulx16 %f0, %f10, %f8
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
fmul8x16au %f12, %f11, %f10
fmul8ulx16 %f4, %f4, %f12
taddcctv %g5, 0x1993, %g5
taddcctv %o2, 0x083A, %o2
setx 0x34400001400, %l0, %l1
taddcctv %l1, 0x1737, %l1
fmuld8ulx16 %f7, %f3, %f2
fmuld8sux16 %f2, %f3, %f2
fmovrsgez %g3, %f13, %f10
fmul8x16al %f10, %f0, %f2
fandnot2s %f2, %f12, %f14
tsubcctv %l3, 0x1386, %l3
tsubcctv %o6, 0x1598, %o6
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
fpsub16s %f14, %f14, %f15
fmovrdlez %o1, %f14, %f10
fmovrdgez %i2, %f12, %f12
fmul8ulx16 %f6, %f10, %f8
fmul8sux16 %f8, %f10, %f0
fmuld8ulx16 %f6, %f10, %f4
taddcctv %i6, 0x1F96, %i6
fmovrslez %i6, %f15, %f14
setx 0x34400001400, %l0, %l1
fmovrdlez %i7, %f14, %f12
tsubcctv %o3, 0x14FA, %o3
taddcctv %l3, 0x08C8, %l3
fmovrsgez %i3, %f11, %f15
tsubcctv %l2, 0x16F1, %l2
tsubcctv %l2, 0x043A, %l2
fmuld8ulx16 %f2, %f13, %f8
fmul8ulx16 %f0, %f6, %f14
setx 0x34400001400, %l0, %l1
taddcctv %g6, 0x05C2, %g6
taddcctv %g5, 0x1984, %g5
fmuld8sux16 %f13, %f14, %f4
taddcctv %o6, 0x0292, %o6
fmovsneg %icc, %f12, %f11
setx 0x34400001400, %l0, %l1
fmul8ulx16 %f4, %f12, %f8
fmul8x16au %f8, %f12, %f14
fmovrslez %o0, %f10, %f14
fmul8x16au %f12, %f2, %f6
setx 0x34400001400, %l0, %l1
fmul8x16al %f10, %f11, %f2
taddcctv %l3, 0x0F6E, %l3
setx 0x34400001400, %l0, %l1
fmuld8sux16 %f5, %f13, %f8
tsubcctv %l1, 0x02D6, %l1
tsubcctv %g2, 0x0BF1, %g2
taddcctv %o6, 0x01A2, %o6
fmuld8sux16 %f7, %f6, %f6
setx 0x34400001400, %l0, %l1
fandnot2s %f12, %f13, %f3
setx 0x34400001400, %l0, %l1
tsubcctv %o6, 0x154E, %o6
taddcctv %o4, 0x0F45, %o4
fandnot1s %f15, %f9, %f11
fmul8x16al %f13, %f5, %f6
setx 0x34400001400, %l0, %l1
taddcctv %i5, 0x0066, %i5
fmuld8ulx16 %f1, %f1, %f8
fmuld8sux16 %f11, %f4, %f2
faligndata %f2, %f4, %f14
tsubcctv %o1, 0x17A4, %o1
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
taddcctv %i3, 0x066F, %i3
fmovdneg %icc, %f13, %f11
fmovdpos %icc, %f13, %f10
faligndata %f0, %f14, %f2
fpsub32s %f11, %f10, %f11
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
fmul8sux16 %f10, %f10, %f2
tsubcctv %g4, 0x125C, %g4
taddcctv %o7, 0x1283, %o7
taddcctv %o3, 0x0495, %o3
setx 0x34400001400, %l0, %l1
taddcctv %g2, 0x1D1B, %g2
fmul8ulx16 %f0, %f10, %f12
taddcctv %i1, 0x1BBF, %i1
fmuld8sux16 %f9, %f11, %f0
fmul8x16 %f15, %f12, %f14
fmul8ulx16 %f14, %f2, %f8
taddcctv %g7, 0x154C, %g7
setx 0x34400001400, %l0, %l1
tsubcctv %l0, 0x114B, %l0
fmovrdgez %l3, %f14, %f14
taddcctv %l3, 0x06F4, %l3
faligndata %f10, %f6, %f0
fmovsleu %xcc, %f13, %f11
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
tsubcctv %g6, 0x133A, %g6
fmovsleu %xcc, %f15, %f14
fmul8x16al %f8, %f10, %f8
tsubcctv %o3, 0x1AB5, %o3
fmul8ulx16 %f8, %f12, %f4
fmovsleu %icc, %f12, %f13
taddcctv %i7, 0x013B, %i7
setx 0x34400001400, %l0, %l1
fandnot1s %f13, %f10, %f14
fmuld8ulx16 %f14, %f2, %f2
fmuld8ulx16 %f7, %f15, %f4
tsubcctv %l5, 0x0A82, %l5
taddcctv %o6, 0x0D81, %o6
tsubcctv %l6, 0x13B6, %l6
fmul8x16al %f13, %f15, %f10
tsubcctv %i2, 0x1A24, %i2
fmovdpos %icc, %f13, %f13
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
fmuld8ulx16 %f6, %f2, %f4
fmuld8sux16 %f13, %f1, %f4
tsubcctv %g2, 0x0E47, %g2
setx 0x34400001400, %l0, %l1
fmuld8sux16 %f1, %f5, %f4
fmul8x16 %f15, %f12, %f14
fmovdleu %icc, %f15, %f11
fmul8sux16 %f2, %f0, %f14
setx 0x34400001400, %l0, %l1
fmuld8ulx16 %f2, %f15, %f0
fmul8x16au %f9, %f2, %f10
fmul8ulx16 %f6, %f2, %f14
fmuld8ulx16 %f2, %f5, %f0
fmovsleu %xcc, %f11, %f12
fmuld8sux16 %f12, %f2, %f14
fmuld8ulx16 %f2, %f14, %f2
tsubcctv %i5, 0x1C45, %i5
setx 0x34400001400, %l0, %l1
faligndata %f12, %f0, %f14
setx 0x34400001400, %l0, %l1
fmul8x16au %f9, %f6, %f10
fmuld8sux16 %f9, %f14, %f8
tsubcctv %l2, 0x1017, %l2
fmuld8sux16 %f12, %f12, %f12
fmul8sux16 %f8, %f2, %f12
fmuld8ulx16 %f12, %f10, %f2
setx 0x34400001400, %l0, %l1
fmuld8sux16 %f13, %f13, %f14
tsubcctv %g5, 0x17EE, %g5
fmul8sux16 %f12, %f10, %f8
setx 0x34400001400, %l0, %l1
taddcctv %o3, 0x0F54, %o3
setx 0x34400001400, %l0, %l1
fandnot2s %f15, %f3, %f15
fmovsneg %xcc, %f15, %f13
tsubcctv %i1, 0x144D, %i1
fmul8x16au %f11, %f3, %f2
fmul8sux16 %f12, %f8, %f14
faligndata %f6, %f12, %f12
setx 0x34400001400, %l0, %l1
fmul8sux16 %f0, %f8, %f14
taddcctv %l2, 0x1864, %l2
fmul8x16al %f5, %f10, %f12
fmul8sux16 %f12, %f12, %f12
fmuld8ulx16 %f7, %f5, %f14
fandnot1s %f13, %f10, %f7
tsubcctv %l2, 0x0252, %l2
setx 0x34400001400, %l0, %l1
fandnot2s %f15, %f12, %f3
setx 0x34400001400, %l0, %l1
tsubcctv %g3, 0x19A7, %g3
faligndata %f0, %f12, %f10
taddcctv %l0, 0x0B8E, %l0
fmul8x16al %f14, %f6, %f12
setx 0x34400001400, %l0, %l1
fmovsneg %icc, %f14, %f15
tsubcctv %o6, 0x1DCB, %o6
setx 0x34400001400, %l0, %l1
fmuld8ulx16 %f11, %f12, %f8
fmuld8sux16 %f11, %f3, %f2
fmul8ulx16 %f2, %f8, %f12
fmul8sux16 %f12, %f6, %f12
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
fmul8x16al %f3, %f14, %f12
tsubcctv %l1, 0x065A, %l1
tsubcctv %i7, 0x1A45, %i7
setx 0x34400001400, %l0, %l1
fmul8x16au %f1, %f11, %f8
setx 0x34400001400, %l0, %l1
taddcctv %o0, 0x1575, %o0
taddcctv %o0, 0x1834, %o0
setx 0x34400001400, %l0, %l1
taddcctv %l0, 0x0CE8, %l0
taddcctv %l0, 0x0B03, %l0
setx 0x34400001400, %l0, %l1
tsubcctv %l1, 0x06DA, %l1
fmul8sux16 %f2, %f10, %f6
faligndata %f14, %f2, %f6
faligndata %f4, %f14, %f2
fmul8x16au %f6, %f0, %f12
fmuld8ulx16 %f6, %f9, %f4
fmovsneg %xcc, %f13, %f11
fmovdneg %xcc, %f11, %f15
fmovsleu %icc, %f14, %f13
fandnot2s %f12, %f4, %f13
fmuld8sux16 %f11, %f3, %f4
fmuld8ulx16 %f4, %f7, %f6
fmovrsgez %i6, %f11, %f14
setx 0x34400001400, %l0, %l1
fmovrdgez %o7, %f14, %f10
tsubcctv %o4, 0x1B53, %o4
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
setx 0x34400001400, %l0, %l1
fmuld8sux16 %f8, %f9, %f4
setx 0x34400001400, %l0, %l1
bpos,a,pn %icc, loop_1112
fmul8sux16 %f4, %f14, %f14
fmovdneg %xcc, %f12, %f11
fandnot1s %f11, %f9, %f12
tsubcctv %l6, 0x1BF5, %l6
setx 0x34400001400, %l0, %l1
bpos,a,pt %xcc, loop_1139
fandnot2s %f10, %f10, %f12
faligndata %f12, %f8, %f8
taddcctv %l2, 0x0AAF, %l2
fmovsleu %xcc, %f13, %f13
fandnot1s %f9, %f13, %f11
fmul8sux16 %f12, %f12, %f4
fmovsneg %icc, %f12, %f15
fmuld8ulx16 %f11, %f11, %f10
fornot1s %f12, %f13, %f15
faligndata %f6, %f10, %f0
fpsub32s %f10, %f14, %f10
fandnot1s %f10, %f13, %f1
fmul8ulx16 %f6, %f2, %f10
fmul8x16al %f13, %f11, %f4
fmul8ulx16 %f4, %f8, %f12
taddcctv %l6, 0x0600, %l6
fmuld8ulx16 %f4, %f2, %f4
fmul8sux16 %f4, %f14, %f6
faligndata %f6, %f4, %f14
fmuld8ulx16 %f14, %f6, %f8
setx 0x34400001400, %l0, %l1
taddcctv %g3, 0x0D2D, %g3
setx 0x34400001400, %l0, %l1
fmuld8sux16 %f3, %f8, %f8
fandnot2s %f13, %f14, %f15
fmuld8sux16 %f15, %f4, %f6
fmovdpos %xcc, %f11, %f13
tsubcctv %g3, 0x0560, %g3
fmul8ulx16 %f6, %f10, %f0
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
EXIT_GOOD /* test finish */
/************************************************************************
************************************************************************/