1. 29 Sep, 2016 1 commit
  2. 23 Sep, 2016 1 commit
    • Christoph Mallon's avatar
      Fix typo. · 279bc8dd
      Christoph Mallon authored
      The negation accidentally got lost when using be_mode_needs_gp_reg().
      279bc8dd
  3. 18 Sep, 2016 3 commits
  4. 17 May, 2016 1 commit
  5. 12 May, 2016 1 commit
  6. 04 Apr, 2016 1 commit
    • Matthias Braun's avatar
      be: Rewrite stack frame handling · b6787e36
      Matthias Braun authored
      This is a bigger rewrite of stack frame handling in the backend:
      
      - Do the stack frame type layout late, after all the spill slots have
        been created. This way we can avoid (and remove) the brittle
        frame_alloc_area().
      - Standardize the meaning of stack entity offsets. After stack frame type
        layout they are relative to the stack pointer position at the beginning
        of the function.  It is all in one type now, no splitting into "arg",
        "between" and "stack_frame" type anymore.
      - Generalize the stack pointer simulation code to work with a single
        callback. Represent stack state as current offset and align_padding
        number. Now that callbacks can access and modify them both we do not
        need custom code in the sparc backend anymore.
      - Remove alignment specification on IncSP, only keep a ignore_align flag
        used for the last IncSP that has to remove all existing sp adjustments
        and may end up on a misaligned SP on ia32/amd64.
      - Align stack by default on ia32+amd64 backends.
      b6787e36
  7. 28 Mar, 2016 1 commit
  8. 21 Mar, 2016 1 commit
  9. 15 Mar, 2016 1 commit
  10. 14 Mar, 2016 1 commit
  11. 14 Dec, 2015 1 commit
  12. 07 Dec, 2015 3 commits
  13. 03 Dec, 2015 1 commit
  14. 06 Oct, 2015 1 commit
    • Matthias Braun's avatar
      Introduce IR_LINKAGE_NO_IDENTITY · 5fc82d98
      Matthias Braun authored
      This flag can be set on entities where the actual address isn't
      known/compared against other address. This also fixes a bug where we
      used the mach-o csrings section for global char arrays which need
      distinct addresses.
      5fc82d98
  15. 25 Sep, 2015 1 commit
  16. 10 Sep, 2015 1 commit
  17. 09 Sep, 2015 1 commit
    • Christoph Mallon's avatar
      be: Wire stack nodes after code selection. · bed91301
      Christoph Mallon authored
      This resolves problems with hidden dependencies during code selection, which cause dependency cycles and therefore fixes backend/scheduled.c.
      Also it grants the code selection slightly more freedom by not arbitrarily restricting the order by stack dependencies.
      bed91301
  18. 08 Sep, 2015 1 commit
  19. 29 Aug, 2015 1 commit
  20. 20 Aug, 2015 1 commit
    • Matthias Braun's avatar
      Cleanup after def92e0a · 7c907708
      Matthias Braun authored
      Properly use get_irn_pinned/set_irn_pinned as bool value instead of
      comparing setting the ir_op enum values.
      7c907708
  21. 14 Aug, 2015 2 commits
  22. 09 Aug, 2015 1 commit
    • Christoph Mallon's avatar
      be: Reintroduce be_Start. · 36de1849
      Christoph Mallon authored
      All backends have similar empty Start nodes, which just provide registers.
      So having one generic backend Start node to share some infrastructure is sensible.
      36de1849
  23. 07 Aug, 2015 1 commit
  24. 29 Jul, 2015 1 commit
  25. 28 Jul, 2015 1 commit
    • Christoph Mallon's avatar
      be: Add and use be_new_Proj(). · 9a6b8525
      Christoph Mallon authored
      It is like new_r_Proj(), but the mode is determined automatically from the out requirement of the predecessor.
      This probably resolves some mode mismatches in untested code paths -- AMD64 backend and SPARC hard float, I'm looking at you!
      9a6b8525
  26. 27 Jul, 2015 1 commit
  27. 22 Jul, 2015 1 commit
  28. 08 Jul, 2015 2 commits
  29. 01 Jul, 2015 4 commits
  30. 26 Jun, 2015 2 commits