summaryrefslogtreecommitdiffstats
path: root/lib/Target/MBlaze/TODO
blob: 737f111c638ab2550fefa19988a1d55395ac536e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
* Writing out ELF files is close to working but the following needs to
  be examined more closely:
    - ELF files are written with the wrong E_MACHINE value because
      ELFObjectWriter::WriteHeader function does not yet support
      target specific E_MACHINE values.
    - ELF relocation records are incorrect because the function
      ELFObjectWriter::RecordRelocation is hard coded for X86/X86-64.
    - Relocations use 2-byte / 4-byte to terminology in reference to
      the size of the immediate value being changed. The Xilinx
      terminology seems to be (???) 4-byte / 8-byte in reference
      to the number of bytes of instructions that are being changed.
    - BRLID and like instructions are always assumed to use a 4-byte
      immediate value for the relocation and BEQID and like instructions
      are always assumed to use a 2-byte immediate value for the relocation.
      I think this means that conditional branches like BEQID can only
      branch += 32768 bytes (~8192 instructions). We should allow conditional
      branches to use 4-byte relocations but I'm not sure how to do that
      right now.

* Code generation seems to work relatively well now but the following
  needs to be examined more closely:
    - The stack layout needs to be examined to make sure it meets
      the standard, especially in regards to var arg functions.
    - The delay slot filler is ad hoc but seems to work. Load and
      store instructions were prevented from being moved to delay
      slots but I'm not sure that is necessary.