15c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# RUN: llvm-mc %s -triple=mipsel -show-encoding -mattr=micromips \ 25c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# RUN: | FileCheck %s -check-prefix=CHECK-EL 35c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# RUN: llvm-mc %s -triple=mips -show-encoding -mattr=micromips \ 45c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# RUN: | FileCheck %s -check-prefix=CHECK-EB 55c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# Check that the assembler can handle the documented syntax 65c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# for arithmetic and logical instructions. 75c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic#------------------------------------------------------------------------------ 85c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# Branch Instructions 95c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic#------------------------------------------------------------------------------ 105c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# Little endian 115c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic#------------------------------------------------------------------------------ 12ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines# CHECK-EL: b 1332 # encoding: [0x00,0x94,0x9a,0x02] 13ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines# CHECK-EL: nop # encoding: [0x00,0x0c] 145c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: beq $9, $6, 1332 # encoding: [0xc9,0x94,0x9a,0x02] 155c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: nop # encoding: [0x00,0x00,0x00,0x00] 165c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: bgez $6, 1332 # encoding: [0x46,0x40,0x9a,0x02] 175c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: nop # encoding: [0x00,0x00,0x00,0x00] 185c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: bgezal $6, 1332 # encoding: [0x66,0x40,0x9a,0x02] 195c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: nop # encoding: [0x00,0x00,0x00,0x00] 205c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: bltzal $6, 1332 # encoding: [0x26,0x40,0x9a,0x02] 215c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: nop # encoding: [0x00,0x00,0x00,0x00] 225c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: bgtz $6, 1332 # encoding: [0xc6,0x40,0x9a,0x02] 235c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: nop # encoding: [0x00,0x00,0x00,0x00] 245c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: blez $6, 1332 # encoding: [0x86,0x40,0x9a,0x02] 255c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: nop # encoding: [0x00,0x00,0x00,0x00] 265c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: bne $9, $6, 1332 # encoding: [0xc9,0xb4,0x9a,0x02] 275c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: nop # encoding: [0x00,0x00,0x00,0x00] 285c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: bal 1332 # encoding: [0x60,0x40,0x9a,0x02] 295c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: nop # encoding: [0x00,0x00,0x00,0x00] 305c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: bltz $6, 1332 # encoding: [0x06,0x40,0x9a,0x02] 315c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EL: nop # encoding: [0x00,0x00,0x00,0x00] 3237ed9c199ca639565f6ce88105f9e39e898d82d0Stephen Hines# CHECK-EL: bgezals $6, 1332 # encoding: [0x66,0x42,0x9a,0x02] 33ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines# CHECK-EL: nop # encoding: [0x00,0x0c] 3437ed9c199ca639565f6ce88105f9e39e898d82d0Stephen Hines# CHECK-EL: bltzals $6, 1332 # encoding: [0x26,0x42,0x9a,0x02] 35ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines# CHECK-EL: nop # encoding: [0x00,0x0c] 365c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic#------------------------------------------------------------------------------ 375c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# Big endian 385c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic#------------------------------------------------------------------------------ 39ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines# CHECK-EB: b 1332 # encoding: [0x94,0x00,0x02,0x9a] 40ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines# CHECK-EB: nop # encoding: [0x0c,0x00] 415c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: beq $9, $6, 1332 # encoding: [0x94,0xc9,0x02,0x9a] 425c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: nop # encoding: [0x00,0x00,0x00,0x00] 435c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: bgez $6, 1332 # encoding: [0x40,0x46,0x02,0x9a] 445c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: nop # encoding: [0x00,0x00,0x00,0x00] 455c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: bgezal $6, 1332 # encoding: [0x40,0x66,0x02,0x9a] 465c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: nop # encoding: [0x00,0x00,0x00,0x00] 475c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: bltzal $6, 1332 # encoding: [0x40,0x26,0x02,0x9a] 485c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: nop # encoding: [0x00,0x00,0x00,0x00] 495c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: bgtz $6, 1332 # encoding: [0x40,0xc6,0x02,0x9a] 505c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: nop # encoding: [0x00,0x00,0x00,0x00] 515c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: blez $6, 1332 # encoding: [0x40,0x86,0x02,0x9a] 525c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: nop # encoding: [0x00,0x00,0x00,0x00] 535c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: bne $9, $6, 1332 # encoding: [0xb4,0xc9,0x02,0x9a] 545c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: nop # encoding: [0x00,0x00,0x00,0x00] 555c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: bal 1332 # encoding: [0x40,0x60,0x02,0x9a] 565c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: nop # encoding: [0x00,0x00,0x00,0x00] 575c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: bltz $6, 1332 # encoding: [0x40,0x06,0x02,0x9a] 585c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic# CHECK-EB: nop # encoding: [0x00,0x00,0x00,0x00] 5937ed9c199ca639565f6ce88105f9e39e898d82d0Stephen Hines# CHECK-EB: bgezals $6, 1332 # encoding: [0x42,0x66,0x02,0x9a] 60ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines# CHECK-EB: nop # encoding: [0x0c,0x00] 6137ed9c199ca639565f6ce88105f9e39e898d82d0Stephen Hines# CHECK-EB: bltzals $6, 1332 # encoding: [0x42,0x26,0x02,0x9a] 62ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines# CHECK-EB: nop # encoding: [0x0c,0x00] 635c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic 64ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines .text 65ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines .type main, @function 66ebe69fe11e48d322045d5949c83283927a0d790bStephen Hines .set micromips 67ebe69fe11e48d322045d5949c83283927a0d790bStephen Hinesmain: 685c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic b 1332 695c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic beq $9,$6,1332 705c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic bgez $6,1332 715c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic bgezal $6,1332 725c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic bltzal $6,1332 735c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic bgtz $6,1332 745c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic blez $6,1332 755c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic bne $9,$6,1332 765c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic bal 1332 775c042162beb3c2dd556e00aab84c4278a69cd5b1Zoran Jovanovic bltz $6,1332 7837ed9c199ca639565f6ce88105f9e39e898d82d0Stephen Hines bgezals $6,1332 7937ed9c199ca639565f6ce88105f9e39e898d82d0Stephen Hines bltzals $6,1332 80