aboutsummaryrefslogtreecommitdiff
path: root/sim/testsuite/msp430/mpyull_hwmult.s
blob: 911fa115709c7b76ee606d3bcb9727ae2226d87f (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
# Test that unsigned widening multiplication of 32-bit operands to produce a
# 64-bit result is simulated correctly, when using 32-bit or F5series hardware
# multiply functionality.
# 0xffff fffc * 0x2 = 0x1 ffff fff8
# mach: msp430

# 32-bit hwmult register addresses
.set MPY32L,	0x0140
.set MPY32H,	0x0142
.set OP2L,	0x0150
.set OP2H,	0x0152
.set RES0,	0x0154
.set RES1,	0x0156
.set RES2,	0x0158
.set RES3,	0x015A

# F5series hwmult register addresses
.set MPY32L_F5,		0x04D0
.set MPY32H_F5,		0x04D2
.set OP2L_F5,		0x04E0
.set OP2H_F5,		0x04E2
.set RES0_F5,		0x04E4
.set RES1_F5,		0x04E6
.set RES2_F5,		0x04E8
.set RES3_F5,		0x04EA

.include "testutils.inc"

	start

	; Test 32bit hwmult
	MOV.W	#2, &MPY32L		; Load operand 1 Low into multiplier
	MOV.W	#0, &MPY32H		; Load operand 1 High into multiplier
	MOV.W	#-4, &OP2L		; Load operand 2 Low into multiplier
	MOV.W	#-1, &OP2H		; Load operand 2 High, trigger MPY

	CMP.W	#-8, &RES0	{ JNE	.L5
	CMP.W	#-1, &RES1	{ JNE	.L5
	CMP.W	#1, &RES2	{ JNE	.L5
	CMP.W	#0, &RES3	{ JNE	.L5

	; Test f5series hwmult
	MOV.W	#2, &MPY32L_F5
	MOV.W	#0, &MPY32H_F5
	MOV.W	#-4, &OP2L_F5
	MOV.W	#-1, &OP2H_F5

	CMP.W	#-8, &RES0_F5	{ JNE	.L5
	CMP.W	#-1, &RES1_F5	{ JNE	.L5
	CMP.W	#1, &RES2_F5	{ JNE	.L5
	CMP.W	#0, &RES3_F5	{ JEQ	.L6
.L5:
	fail
.L6:
	pass