Skip to content
  1. Jun 20, 2013
    • Ulrich Weigand's avatar
      · 865a1efc
      Ulrich Weigand authored
      [PowerPC] Support compare mnemonics with implied CR0
      
      Just like for branch mnemonics (where support was recently added), the
      assembler is supposed to support extended mnemonics for the compare
      instructions where no condition register is specified explicitly
      (and CR0 is assumed implicitly).
      
      This patch adds support for those extended compare mnemonics.
      
      
      Index: llvm-head/test/MC/PowerPC/ppc64-encoding-ext.s
      ===================================================================
      --- llvm-head.orig/test/MC/PowerPC/ppc64-encoding-ext.s
      +++ llvm-head/test/MC/PowerPC/ppc64-encoding-ext.s
      @@ -449,21 +449,37 @@
       
       # CHECK: cmpdi 2, 3, 128                 # encoding: [0x2d,0x23,0x00,0x80]
                cmpdi 2, 3, 128
      +# CHECK: cmpdi 0, 3, 128                 # encoding: [0x2c,0x23,0x00,0x80]
      +         cmpdi 3, 128
       # CHECK: cmpd 2, 3, 4                    # encoding: [0x7d,0x23,0x20,0x00]
                cmpd 2, 3, 4
      +# CHECK: cmpd 0, 3, 4                    # encoding: [0x7c,0x23,0x20,0x00]
      +         cmpd 3, 4
       # CHECK: cmpldi 2, 3, 128                # encoding: [0x29,0x23,0x00,0x80]
                cmpldi 2, 3, 128
      +# CHECK: cmpldi 0, 3, 128                # encoding: [0x28,0x23,0x00,0x80]
      +         cmpldi 3, 128
       # CHECK: cmpld 2, 3, 4                   # encoding: [0x7d,0x23,0x20,0x40]
                cmpld 2, 3, 4
      +# CHECK: cmpld 0, 3, 4                   # encoding: [0x7c,0x23,0x20,0x40]
      +         cmpld 3, 4
       
       # CHECK: cmpwi 2, 3, 128                 # encoding: [0x2d,0x03,0x00,0x80]
                cmpwi 2, 3, 128
      +# CHECK: cmpwi 0, 3, 128                 # encoding: [0x2c,0x03,0x00,0x80]
      +         cmpwi 3, 128
       # CHECK: cmpw 2, 3, 4                    # encoding: [0x7d,0x03,0x20,0x00]
                cmpw 2, 3, 4
      +# CHECK: cmpw 0, 3, 4                    # encoding: [0x7c,0x03,0x20,0x00]
      +         cmpw 3, 4
       # CHECK: cmplwi 2, 3, 128                # encoding: [0x29,0x03,0x00,0x80]
                cmplwi 2, 3, 128
      +# CHECK: cmplwi 0, 3, 128                # encoding: [0x28,0x03,0x00,0x80]
      +         cmplwi 3, 128
       # CHECK: cmplw 2, 3, 4                   # encoding: [0x7d,0x03,0x20,0x40]
                cmplw 2, 3, 4
      +# CHECK: cmplw 0, 3, 4                   # encoding: [0x7c,0x03,0x20,0x40]
      +         cmplw 3, 4
       
       # FIXME: Trap mnemonics
       
      Index: llvm-head/lib/Target/PowerPC/PPCInstrInfo.td
      ===================================================================
      --- llvm-head.orig/lib/Target/PowerPC/PPCInstrInfo.td
      +++ llvm-head/lib/Target/PowerPC/PPCInstrInfo.td
      @@ -2201,3 +2201,12 @@ defm : BranchExtendedMnemonic<"ne", 68>;
       defm : BranchExtendedMnemonic<"nu", 100>;
       defm : BranchExtendedMnemonic<"ns", 100>;
       
      +def : InstAlias<"cmpwi $rA, $imm", (CMPWI CR0, gprc:$rA, s16imm:$imm)>;
      +def : InstAlias<"cmpw $rA, $rB", (CMPW CR0, gprc:$rA, gprc:$rB)>;
      +def : InstAlias<"cmplwi $rA, $imm", (CMPLWI CR0, gprc:$rA, u16imm:$imm)>;
      +def : InstAlias<"cmplw $rA, $rB", (CMPLW CR0, gprc:$rA, gprc:$rB)>;
      +def : InstAlias<"cmpdi $rA, $imm", (CMPDI CR0, g8rc:$rA, s16imm:$imm)>;
      +def : InstAlias<"cmpd $rA, $rB", (CMPD CR0, g8rc:$rA, g8rc:$rB)>;
      +def : InstAlias<"cmpldi $rA, $imm", (CMPLDI CR0, g8rc:$rA, u16imm:$imm)>;
      +def : InstAlias<"cmpld $rA, $rB", (CMPLD CR0, g8rc:$rA, g8rc:$rB)>;
      +
      
      llvm-svn: 184435
      865a1efc
  2. Jun 10, 2013
    • Ulrich Weigand's avatar
      · aa4a2d71
      Ulrich Weigand authored
      [PowerPC] Support branch mnemonics with implied CR0
      
      The extended branch mnemonics are supposed to use an implied CR0
      if there is no explicit condition register specified.  This patch
      adds extra variants of the mnemonics to this effect.
      
      Problem reported by Joerg Sonnenberger.
      
      llvm-svn: 183686
      aa4a2d71
  3. May 03, 2013
    • Ulrich Weigand's avatar
      · d839490f
      Ulrich Weigand authored
      [PowerPC] Support extended mnemonics in AsmParser
      
      This patch adds infrastructure to support extended mnemonics in the
      PowerPC assembler parser.  It adds support specifically for those
      extended mnemonics that LLVM will itself generate.
      
      The test case lists *all* extended mnemonics according to the
      PowerPC ISA v2.06 Book I, but marks those not yet supported
      as FIXME.
      
      llvm-svn: 181051
      d839490f
Loading