Skip to content
  1. Jun 24, 2013
    • Ulrich Weigand's avatar
      · ba19f796
      Ulrich Weigand authored
      [PowerPC] Add some FIXMEs
      
      A bunch of extendend mnemomics ought to support '.' forms.
      Add FIXMEs to the test case for those.
      
      llvm-svn: 184757
      ba19f796
    • Ulrich Weigand's avatar
      · 86247b6e
      Ulrich Weigand authored
      [PowerPC] Add predicted forms of branches
      
      This adds support for the predicted forms of branches (+/-).
      There are three cases to consider:
      - Branches using a PPC::Predicate code
        For these, I've added new PPC::Predicate codes corresponding
        to the BO values for predicted branch forms, and updated insn
        printing to print them correctly.  I've also added new aliases
        for the asm parser matching the new forms.
      - bt/bf
        I've added new aliases matching to gBC etc.
      - bd(n)z variants
        I've added new instruction patterns for the predicted forms.
      
      In all cases, the new patterns are used for the asm parser only.
      (The new infrastructure ought to be sufficient to allow use by
      the compiler too at some point.)
      
      llvm-svn: 184754
      86247b6e
    • Ulrich Weigand's avatar
      · fedd5a75
      Ulrich Weigand authored
      [PowerPC] Add t/f branch mnemonics to asm parser
      
      This adds the bt/bf/bd(n)zt/bd(n)zf mnemonics as aliases for the
      asm parser, resolving to the generic conditional patterns.
      
      llvm-svn: 184725
      fedd5a75
    • Ulrich Weigand's avatar
      · 824b7d8d
      Ulrich Weigand authored
      [PowerPC] Support generic conditional branches in asm parser
      
      This adds instruction patterns to cover the generic forms of
      the conditional branch instructions.  This allows the assembler
      to support the generic mnemonics.
      
      The compiler will still generate the various specific forms
      of the instruction that were already supported.
      
      llvm-svn: 184722
      824b7d8d
    • Ulrich Weigand's avatar
      · b6a30d15
      Ulrich Weigand authored
      [PowerPC] Support absolute branches
      
      There is currently only limited support for the "absolute" variants
      of branch instructions.  This patch adds support for the absolute
      variants of all branches that are currently otherwise supported.
      
      This requires adding new fixup types so that the correct variant
      of relocation type can be selected by the object writer.
      
      While the compiler will continue to usually choose the relative
      branch variants, this will allow the asm parser to fully support
      the absolute branches, with either immediate (numerical) or
      symbolic target addresses.
      
      No change in code generation intended.
      
      llvm-svn: 184721
      b6a30d15
    • Ulrich Weigand's avatar
      · 5b9d591a
      Ulrich Weigand authored
      [PowerPC] Support bd(n)zl and bd(n)zlrl
      
      This adds support for the bd(n)zl and bd(n)zlrl instructions.
      The patterns are currently used for the asm parser only.
      
      llvm-svn: 184720
      5b9d591a
    • Ulrich Weigand's avatar
      · d20e91ed
      Ulrich Weigand authored
      [PowerPC] Support b(cond)l in the asm parser
      
      This patch adds support for the conditional variants of bl.
      The pattern is currently used by the asm parser only.
      
      llvm-svn: 184719
      d20e91ed
    • Ulrich Weigand's avatar
      · 1847bb81
      Ulrich Weigand authored
      [PowerPC] Support blrl and variants in the asm parser
      
      This patch adds support for blrl and its conditional variants.
      The patterns are (currently) used for the asm parser only.
      
      llvm-svn: 184718
      1847bb81
    • Amaury de la Vieuville's avatar
      ARM: check predicate bits for thumb instructions · 8449c0d5
      Amaury de la Vieuville authored
      When encoded to thumb, VFP instruction and VMOV/VDUP between scalar and
      core registers, must have their predicate bit to 0b1110.
      
      llvm-svn: 184707
      8449c0d5
    • Amaury de la Vieuville's avatar
      ARM: rGPR is meant to be unpredictable, not undefined · 8175bda3
      Amaury de la Vieuville authored
      llvm-svn: 184706
      8175bda3
    • Amaury de la Vieuville's avatar
      ARM: fix thumb1 nop decoding · f2f00b4e
      Amaury de la Vieuville authored
      In thumb1, NOP is a pseudo-instruction equivalent to mov r8, r8.
      However the disassembler should not use this alias.
      
      llvm-svn: 184703
      f2f00b4e
    • Amaury de la Vieuville's avatar
      ARM: fix IT decoding · 2f0ac8d9
      Amaury de la Vieuville authored
      mask == 0 -> UNPRED
      
      llvm-svn: 184702
      2f0ac8d9
    • Amaury de la Vieuville's avatar
      ARM: enable decoding of pc-relative PLD/PLI · 4b6c076d
      Amaury de la Vieuville authored
      llvm-svn: 184701
      4b6c076d
  2. Jun 23, 2013
  3. Jun 21, 2013
    • Ulrich Weigand's avatar
      · 91add7df
      Ulrich Weigand authored
      [PowerPC] Support R_PPC_REL16 family of relocations
      
      The GNU assembler supports (as extension to the ABI) use of PC-relative
      relocations in half16 fields, which allows writing code like:
      
        li 1, base-.
      
      This patch adds support for those relocation types in the assembler.
      
      llvm-svn: 184552
      91add7df
    • Ulrich Weigand's avatar
      · 876a0d01
      Ulrich Weigand authored
      [PowerPC] Support various tls-related modifiers
      
      The current code base only supports the minimum set of tls-related
      relocations and @modifiers that are necessary to support compiler-
      generated code.  This patch extends this to the full set defined
      in the ABI (and supported by the GNU assembler) for the benefit
      of the assembler parser.
      
      llvm-svn: 184551
      876a0d01
    • Ulrich Weigand's avatar
      · e9126f55
      Ulrich Weigand authored
      [PowerPC] Support @higher et.al. modifiers
      
      This adds support for the @higher, @highera, @highest, and @highesta
      modifers, including some missing relocation types.
      
      llvm-svn: 184550
      e9126f55
    • Ulrich Weigand's avatar
      · 72ddbd65
      Ulrich Weigand authored
      [PowerPC] Support @toc@h modifier
      
      This adds the relocation type and other necessary infrastructure
      to use the @toc@h modifier in the assembler.
      
      llvm-svn: 184549
      72ddbd65
    • Ulrich Weigand's avatar
      · e67c565d
      Ulrich Weigand authored
      [PowerPC] Support @h modifier
      
      This adds necessary infrastructure to support the @h modifier.
      Note that all required relocation types were already present
      (and unused).
      
      This patch provides support for using @h in the assembler;
      it would also be possible to now use this feature in code
      generated by the compiler, but this is not done yet.
      
      llvm-svn: 184548
      e67c565d
    • Kevin Enderby's avatar
      Update the X86 disassembler to use xacquire and xrelease when appropriate. · 35fd7923
      Kevin Enderby authored
      This is a bit tricky as the xacquire and xrelease hints use the same bytes,
      0xf2 and 0xf3, as the repne and rep prefixes.
      
      Fortunately llvm has different llvm MCInst Opcode enums for rep/xrelease
      and repne/xacquire. So to make this work a boolean was added the
      InternalInstruction struct as part of the Prefix state which is set with the
      added logic in readPrefixes() when decoding an instruction to determine
      if these prefix bytes are to be disassembled as xacquire or xrelease.  Then
      we let the matcher pick the normal prefix instructionID and we change the
      Opcode after that when it is set into the MCInst being created.
      
      rdar://11019859
      
      llvm-svn: 184490
      35fd7923
  4. Jun 20, 2013
    • Joey Gouly's avatar
      This reverts r155000. · f81d036e
      Joey Gouly authored
      The cdp2 instruction should have the same restrictions as cdp on the
      co-processor registers.
      
      VFP instructions on v8/AArch32 share the same encoding space as cdp2.
      
      llvm-svn: 184445
      f81d036e
    • Ulrich Weigand's avatar
      · d412098f
      Ulrich Weigand authored
      [MC] Support @ variants with directional labels
      
      The assembler parser common code supports recognizing symbol variants
      using the @ modifer.  On PowerPC, it should also be possible to use
      (some of) those modifiers with directional labels, like "1f@l".
      
      This patch adds support for accepting symbol variants on directional
      labels as well.
      
      llvm-svn: 184437
      d412098f
    • Ulrich Weigand's avatar
      · 96e65783
      Ulrich Weigand authored
      [PowerPC] Optimize @ha/@l constructs
      
      This patch adds support for having the assembler optimize fixups
      to constructs like "symbol@ha" or "symbol@l" if "symbol" can be
      resolved at assembler time.
      
      This optimization is already present in the PPCMCExpr.cpp code
      for handling PPC_HA16/PPC_LO16 target expressions.  However,
      those target expression were used only on Darwin targets.
      
      This patch changes target expression code so that they are
      usable also with the GNU assembler (using the @ha / @l syntax
      instead of the ha16() / lo16() syntax), and changes the
      MCInst lowering code to generate those target expressions
      where appropriate.
      
      It also changes the asm parser to generate HA16/LO16 target
      expressions when parsing assembler source that uses the
      @ha / @l modifiers.  The effect is that now the above-
      mentioned optimization automatically becomes available
      for those situations too.
       
      
      llvm-svn: 184436
      96e65783
    • 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
    • Vladimir Medic's avatar
  5. Jun 19, 2013
    • Ulrich Weigand's avatar
      · 64f44051
      Ulrich Weigand authored
      [MC/DWARF] Generate multiple .debug_line entries for adjacent .loc directives
      
      The compiler occasionally generates multiple .loc directives in a row
      (at the same instruction address).  These need to be transformed into
      multple actual .debug_line table entries, since they are used to signal
      certain information to the debugger (e.g. if the opening brace of a
      function body is on the same line as the declaration).
      
      The MCAsmStreamer version of EmitDwarfLocDirective handles this
      correctly by emitting a .loc directive every time it is called.
      However, the MCObjectStream version simply defaults to recording
      the information and emitting only a single table entry later,
      e.g. when EmitInstruction is called.
      
      This patch introduces a MCAsmStreamer::EmitDwarfLocDirective
      version that emits a line table entry for a .loc directive
      that may already be pending before recording the new directive.
      (This is similar to how this is handled in GNU as.)
      
      With this patch (and the code alignment factor patch) applied,
      I'm now getting identical DWARF .debug sections for all test-suite
      object files on PowerPC for the internal and the external assembler.
      
      llvm-svn: 184357
      64f44051
  6. Jun 18, 2013
  7. Jun 17, 2013
  8. Jun 14, 2013
  9. Jun 13, 2013
  10. Jun 12, 2013
    • Ulrich Weigand's avatar
      · 32d725b8
      Ulrich Weigand authored
      [MC/DWARF] Support .debug_frame / .debug_line code alignment factors
      
      I've been comparing the object file output of LLVM's integrated
      assembler against the external assembler on PowerPC, and one
      area where differences still remain are in DWARF sections.
      
      In particular, the GNU assembler generates .debug_frame and
      .debug_line sections using a code alignment factor of 4, since
      all PowerPC instructions have size 4 and must be aligned to a
      multiple of 4.  However, current MC code hard-codes a code
      alignment factor of 1.
      
      This patch changes this by adding a "minimum instruction alignment"
      data element to MCAsmInfo and using this as code alignment factor.
      
      This requires passing a MCContext into MCDwarfLineAddr::Encode
      and MCDwarfLineAddr::EncodeAdvanceLoc.  Note that one caller,
      MCDwarfLineAddr::Write, didn't actually have that information
      available.  However, it turns out that this routine is in fact
      never used in the whole code base, so the patch simply removes
      it.  If it turns out to be needed again at a later time, it
      could be re-added with an updated interface.
      
      llvm-svn: 183834
      32d725b8
Loading