# frv testcase for cmxor $FRinti,$FRintj,$FRintk,$CCi,$cond
# mach: all

	.include "testutils.inc"

	start

	.global cmxor
cmxor:
	set_spr_immed	0x1b1b,cccr

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0x5555,0x5555,fr8
	cmxor      	fr7,fr8,fr8,cc0,1
	test_fr_iimmed 	0xffffffff,fr8

	set_fr_iimmed	0x0000,0x0000,fr7
	set_fr_iimmed	0x0000,0x0000,fr8
	cmxor		fr7,fr8,fr8,cc0,1
	test_fr_iimmed  0x00000000,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0xaaaa,0xaaaa,fr8
	cmxor      	fr7,fr8,fr8,cc4,1
	test_fr_iimmed	0x00000000,fr8

	set_fr_iimmed   0xdead,0x0000,fr7
	set_fr_iimmed   0x0000,0xbeef,fr8
	cmxor		fr7,fr8,fr8,cc4,1
	test_fr_iimmed  0xdeadbeef,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0x5555,0x5555,fr8
	cmxor      	fr7,fr8,fr8,cc1,0
	test_fr_iimmed 	0xffffffff,fr8

	set_fr_iimmed	0x0000,0x0000,fr7
	set_fr_iimmed	0x0000,0x0000,fr8
	cmxor		fr7,fr8,fr8,cc1,0
	test_fr_iimmed  0x00000000,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0xaaaa,0xaaaa,fr8
	cmxor      	fr7,fr8,fr8,cc5,0
	test_fr_iimmed	0x00000000,fr8

	set_fr_iimmed   0xdead,0x0000,fr7
	set_fr_iimmed   0x0000,0xbeef,fr8
	cmxor		fr7,fr8,fr8,cc5,0
	test_fr_iimmed  0xdeadbeef,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0x5555,0x5555,fr8
	cmxor      	fr7,fr8,fr8,cc0,0
	test_fr_iimmed 	0x55555555,fr8

	set_fr_iimmed	0xdead,0xbeef,fr7
	set_fr_iimmed	0x0000,0x0000,fr8
	cmxor		fr7,fr8,fr8,cc0,0
	test_fr_iimmed  0x00000000,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0xaaaa,0xaaaa,fr8
	cmxor      	fr7,fr8,fr8,cc4,0
	test_fr_iimmed	0xaaaaaaaa,fr8

	set_fr_iimmed   0xdead,0x0000,fr7
	set_fr_iimmed   0x0000,0xbeef,fr8
	cmxor		fr7,fr8,fr8,cc4,0
	test_fr_iimmed  0x0000beef,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0x5555,0x5555,fr8
	cmxor      	fr7,fr8,fr8,cc1,1
	test_fr_iimmed 	0x55555555,fr8

	set_fr_iimmed	0xdead,0xbeef,fr7
	set_fr_iimmed	0x0000,0x0000,fr8
	cmxor		fr7,fr8,fr8,cc1,1
	test_fr_iimmed  0x00000000,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0xaaaa,0xaaaa,fr8
	cmxor      	fr7,fr8,fr8,cc5,1
	test_fr_iimmed	0xaaaaaaaa,fr8

	set_fr_iimmed   0xdead,0x0000,fr7
	set_fr_iimmed   0x0000,0xbeef,fr8
	cmxor		fr7,fr8,fr8,cc5,1
	test_fr_iimmed  0x0000beef,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0x5555,0x5555,fr8
	cmxor      	fr7,fr8,fr8,cc2,0
	test_fr_iimmed 	0x55555555,fr8

	set_fr_iimmed	0xdead,0xbeef,fr7
	set_fr_iimmed	0x0000,0x0000,fr8
	cmxor		fr7,fr8,fr8,cc2,1
	test_fr_iimmed  0x00000000,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0xaaaa,0xaaaa,fr8
	cmxor      	fr7,fr8,fr8,cc6,0
	test_fr_iimmed	0xaaaaaaaa,fr8

	set_fr_iimmed   0xdead,0x0000,fr7
	set_fr_iimmed   0x0000,0xbeef,fr8
	cmxor		fr7,fr8,fr8,cc6,1
	test_fr_iimmed  0x0000beef,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0x5555,0x5555,fr8
	cmxor      	fr7,fr8,fr8,cc3,0
	test_fr_iimmed 	0x55555555,fr8

	set_fr_iimmed	0xdead,0xbeef,fr7
	set_fr_iimmed	0x0000,0x0000,fr8
	cmxor		fr7,fr8,fr8,cc3,1
	test_fr_iimmed  0x00000000,fr8

	set_fr_iimmed   0xaaaa,0xaaaa,fr7
	set_fr_iimmed   0xaaaa,0xaaaa,fr8
	cmxor      	fr7,fr8,fr8,cc7,0
	test_fr_iimmed	0xaaaaaaaa,fr8

	set_fr_iimmed   0xdead,0x0000,fr7
	set_fr_iimmed   0x0000,0xbeef,fr8
	cmxor		fr7,fr8,fr8,cc7,1
	test_fr_iimmed  0x0000beef,fr8

	pass
