1
2	.sdata
3shared:	.word	11
4
5	.data
6unshared:
7	.word	1
8	.word	2
9	.word	3
10	.word	4
11
12	.text
13func:
14	.set noreorder
15	li	$4, 0x12345678	# 0000 lui	a0,0x1234
16				# 0004 ori	a0,a0,0x5678
17	la	$4, shared	# 0008 addiu	a0,gp,shared
18	la	$4, unshared	# 000c lui	a0,hi(unshared)
19				# 0010 addiu	a0,a0,lo(unshared)
20	la	$4, end		# 0014 lui	a0,hi(end)
21				# 0018 addiu	a0,a0,lo(end)
22	j	end		# 001c j	end
23	jal	end		# 0020 jal	end
24	lw	$4, shared	# 0024 lw	a0,shared(gp)
25	lw	$4, unshared	# 0028 lui	a0,hi(unshared)
26				# 002c lw	a0,lo(unshared)(a0)
27	lw	$4, end		# 0030 lui	a0,hi(end)
28				# 0034 lw	a0,lo(end)(a0)
29	ld	$4, shared	# 0038 lw	a0,shared(gp)
30				# 003c lw	a1,shared+4(gp)
31	ld	$4, unshared	# 0040 lui	at,hi(unshared)
32				# 0044 lw	a0,lo(unshared)(at)
33				# 0048 lw	a1,lo(unshared)+4(at)
34	ld	$4, end		# 004c lui	at,hi(end)
35				# 0050 lw	a0,lo(end)(at)
36				# 0054 lw	a1,lo(end)+4(at)
37	sw	$4, shared	# 0058 sw	a0,shared(gp)
38	sw	$4, unshared	# 005c lui	at,hi(unshared)
39				# 0060 sw	a0,lo(unshared)(at)
40	sd	$4, shared	# 0064 sw	a0,shared(gp)
41				# 0068 sw	a1,shared+4(gp)
42	sd	$4, unshared	# 006c lui	at,hi(unshared)
43				# 0070 sw	a0,lo(unshared)(at)
44				# 0074 sw	a1,lo(unshared)+4(at)
45	ulh	$4, unshared	# 0078 lui	at,hi(unshared)
46				# 007c addiu	at,at,lo(unshared)
47				# 0080 lb	a0,0(at)
48				# 0084 lbu	at,1(at)
49				# 0088 sll	a0,a0,8
50				# 008c or	a0,a0,at
51	ush	$4, unshared	# 0090 lui	at,hi(unshared)
52				# 0094 addiu	at,at,lo(unshared)
53				# 0098 sb	a0,1(at)
54				# 009c srl	a0,a0,8
55				# 00a0 sb	a0,0(at)
56				# 00a4 lbu	at,1(at)
57				# 00a8 sll	a0,a0,8
58				# 00ac or	a0,a0,at
59	ulw	$4, unshared	# 00b0 lui	at,hi(unshared)
60				# 00b4 addiu	at,at,lo(unshared)
61				# 00b8 lwl	a0,0(at)
62				# 00bc lwr	a0,3(at)
63	usw	$4, unshared	# 00c0 lui	at,hi(unshared)
64				# 00c4 addiu	at,at,lo(unshared)
65				# 00c8 swl	a0,0(at)
66				# 00cc swr	a0,3(at)
67	li.d	$4, 1.0		# 00d0 lui	a0,0x3ff0
68				# 00d4 move	a1,zero
69	li.d	$4, 1.9		# 00d8 lui	at,hi(F1.9)
70				# 00dc lw	a0,lo(F1.9)(at)
71				# 00e0 lw	a1,lo(F1.9)+4(at)
72	li.d	$f0, 1.0	# 00e4 lui	at,0x3ff0
73				# 00e8 mtc1	at,$f1
74				# 00ec mtc1	zero,$f0
75	li.d	$f0, 1.9	# 00f0 ldc1	$f0,L1.9(gp)
76	seq	$4, $5, -100	# 00f4 addiu	a0,a1,100
77				# 00f8 sltiu	a0,a0,1
78	sne	$4, $5, -100	# 00fc addiu	a0,a1,100
79				# 0100 sltu	a0,zero,a0
80	move	$4, $5		# 0104 move	a0,a1
81
82# Not available in 32-bit mode
83#	dla	$4, shared
84#	dla	$4, unshared
85#	uld	$4, unshared
86#	usd	$4, unshared
87
88# Should produce warnings given -mgp32
89#	bgt	$4, 0x7fffffff, end
90#	bgtu	$4, 0xffffffff, end
91#	ble	$4, 0x7fffffff, end
92#	bleu	$4, 0xffffffff, end
93
94# Should produce warnings given -mfp32
95#	add.d	$f1, $f2, $f3
96
97end:
98
99# Force at least 8 (non-delay-slot) zero bytes, to make 'objdump' print ...
100      .space  8
101