aboutsummaryrefslogtreecommitdiff
path: root/sim/testsuite/bfin/c_cc_flagdreg_mvbrsft_s1.s
blob: 24505c203d9a4b08df83a2c7e859b095db243a7c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
//Original:/proj/frio/dv/testcases/core/c_cc_flagdreg_mvbrsft_s1/c_cc_flagdreg_mvbrsft_s1.dsp
// Spec Reference: cc: set (ccflag & cc2dreg) used (ccmv & brcc & dsp32sft)
# mach: bfin

.include "testutils.inc"
	start

	INIT_P_REGS 0;

	imm32 r0, 0xa08d2311;
	imm32 r1, 0x10120040;
	imm32 r2, 0x62b61557;
	imm32 r3, 0x07300007;
	imm32 r4, 0x00740088;
	imm32 r5, 0x609950aa;
	imm32 r6, 0x20bb06cc;
	imm32 r7, 0xd90e108f;

	ASTAT = R0;

	CC = R1;					// cc2dreg
	R2.H = ( A1 = R2.L * R3.L ), A0 = R2.H * R3.L;	// dsp32mac
	IF CC R1 = R3;					// ccmov
	CC = ! CC;					// cc2dreg
	R4.H = R1.L + R0.L (S);				// dsp32alu
	IF CC R3 = R2;					// ccmov
	CC = R0 < R1;					// ccflag
	R4.L = R5.L << 1;				// dsp32shiftimm
	IF CC R4 = R5;					// ccmov
	CC = R2 == R3;					// ccflag
	R7 = R1.L * R4.L, R6 = R1.H * R4.H;		// dsp32mult
	IF CC R4 = R5;					// ccmov
	CC = R0;					// cc2dreg
	A1 = R2.L * R3.L, A0 += R2.L * R3.H;		// dsp32mac
	IF !CC JUMP LABEL1;				// branch on
	CC = ! CC;					// cc2dreg
	P1.L = 0x3000;					// ldimmhalf
	IF !CC JUMP LABEL2 (BP);			// branch
LABEL1:
	R6 = R6 + R2;
	JUMP.S END;
LABEL2:
	R7 = R5 - R7;
	CC = R0 < R1;	// ccflag
	P2 = A0.w;
	IF CC JUMP END (BP);	// branch
	P3 = A1.w;
	R5 = R5 + R7;

END:

	CHECKREG r0, 0xA08D2311;
	CHECKREG r1, 0x07300007;
	CHECKREG r2, 0x00011557;
	CHECKREG r3, 0x07300007;
	CHECKREG r4, 0x609950AA;
	CHECKREG r5, 0x609950AA;
	CHECKREG r6, 0x056C9760;
	CHECKREG r7, 0x6094E75E;
	CHECKREG p1, 0x00003000;
	CHECKREG p2, 0x01382894;
	CHECKREG p3, 0x00000000;

	imm32 r0, 0x408d2711;
	imm32 r1, 0x15124040;
	imm32 r2, 0x62661557;
	imm32 r3, 0x073b0007;
	imm32 r4, 0x01f49088;
	imm32 r5, 0x6e2959aa;
	imm32 r6, 0xa0b506cc;
	imm32 r7, 0x00000002;

	CC = R1;	// cc2dreg

	R2 = ROT R2 BY 1;	// dsp32shiftim_rot
	CC = ! CC;	// cc2dreg
	R3 >>= R7;	// alu2op sft
	R3 = ROT R0 BY -3;	// dsp32shiftim_rot
	CC = R0 < R1;	// ccflag
	R3 = ( A1 = R7.L * R4.L ),  R2 = ( A0 = R7.H * R4.H )  (S2RND);	// dsp32mac pair
	R6 = ROT R4 BY 5;	// dsp32shiftim_rot
	CC = R2 == R3;	// ccflag
	P1 = R1;	// regmv
	IF CC R4 = R5;	// ccmov
	CC = R0;	// cc2dreg
	R1 = R0 +|- R1 , R6 = R0 -|+ R1 (ASR);	// dsp32alu sft
	R7 = ROT R6 BY R7.L;	// dsp32shiftim_rot

	CHECKREG r0, 0x408D2711;
	CHECKREG r1, 0x2ACFF368;
	CHECKREG r2, 0x00000000;
	CHECKREG r3, 0xFFFC8440;
	CHECKREG r4, 0x01F49088;
	CHECKREG r5, 0x6E2959AA;
	CHECKREG r6, 0x15BD33A8;
	CHECKREG r7, 0x56F4CEA2;
	CHECKREG p1, 0x15124040;

	pass