[llvm-commits] [PATCH] Analog Devices Blackfin back-end
Jakob Stoklund Olesen
stoklund at 2pi.dk
Thu Jul 23 23:48:54 PDT 2009
Hi,
Finally my blackfin back-end is ready to be included in the main tree.
It is still experimental. I have compiled most of CodeGen/Generic as
well as my own test cases. The blackfin assembler (bfin-elf-as) is
happy with the output, but I have not yet tested it on real hardware.
I have access to blackfin hardware, so I can do that later. There is a
GNU tool-chain at http://blackfin.uclinux.org/
I have some XFAIL test cases. They are:
- RegisterScavenger asserts caused by the heavy use if sub-registers.
- Readcyclecounter failing because it wants to return an illegal i64.
- Illegal i16 logic operations introduced after LegalizeOps.
These issues will be easier to fix after the back-end goes in. Then I
can make test cases at the same time.
The Blackfin DSP has some features that have stressed the code
generator quite a bit:
- It has more register classes that any other target. Fortunately
register class support has improved a lot since 2.5.
- Some register class constraints are not yet supported. For instance
there are two ADD variants: D=D+D and P=P+P.
- The legal types are i16 and i32, but i16 is quite limited in the
number of supported operations. This has caused a lot of fun with the
DAG combiner.
- Sub-register operations are used a lot more than on X86.
Some things are simply not implemented yet, like hardware loops and
circular buffer addressing.
I hope you will consider this for inclusion in the tree.
Best regards,
/jakob
-------------- next part --------------
A non-text attachment was scrubbed...
Name: blackfin.patch
Type: application/octet-stream
Size: 205177 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20090724/9b1e2159/attachment.obj>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: autoconf-blackfin.patch
Type: application/octet-stream
Size: 6427 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20090724/9b1e2159/attachment-0001.obj>
More information about the llvm-commits
mailing list