[LLVMdev] TTA-Based Co-design Environment (TCE) v1.4 released
Pekka Jääskeläinen
pekka.jaaskelainen at tut.fi
Mon Apr 11 10:10:00 PDT 2011
TTA-Based Co-design Environment (TCE) is a toolset for designing
application-specific processors (ASP) based on the Transport Triggered
Architecture (TTA). The toolset provides a complete retargetable co-design
flow from C programs down to synthesizable VHDL and parallel program
binaries. Processor customization points include the register files,
function units, supported operations, and the interconnection network.
This release includes support for LLVM 2.9, some new VHDL
implementations (an FPU and streaming operations), a connectivity
optimizer, code generation improvements, plenty of bug fixes and
more. See the CHANGES file for a more thorough listing.
Notable new features
--------------------
- Support for LLVM 2.9.
- OpenCL Embedded compliant FPU implementations by Timo Viitanen / TUT
- Generic VHDL implementations for the basic streaming operations
from Jani Boutellier / University of Oulu.
- ConnectionSweeper IC network exploration algorithm.
Optimizes the IC network by sweeping the buses of the machine and
removing the least important connections first until a cycle count
worsening threshold is reached. Tries to remove RF connections
first as they are usually more expensive than the bypass connections.
- Added --pareto_set switch to the explorer for printing pareto efficient
configurations. Currently supports the connectivity and cycle count as
the quality metrics.
- proge: IP-XACT support updated to version 1.5
- Added switch --print-resource-constraints to tcecc to assist in
deciding which resources to add to the machine to improve the
schedule. Dumps DDGs to dot files along with dependence and
resource constraint analysis data.
Code generator improvements
---------------------------
- Passes the first function parameter in register instead of stack.
- Uses negative guard more aggressively, less stupid guard xoring operations.
- Emulation pattern generation improved, can use immediates directly when
using DAG to emulate missing operations.
- Some other minor pattern improvements leading to slightly better code
on some situations.
- Alias analysis improvements, understands that register spills to stack
cannot alias with other memory operations
- Software Bypasser is much more aggressive.
Acknowledgements
----------------
Thanks to Timo Viitanen for your first TCE contribution (the OpenCL
embedded-compliant FPU implementations) in this release!
Links
-----
TCE home page: http://tce.cs.tut.fi
This announcement: http://tce.cs.tut.fi/downloads/ANNOUNCEMENT
Download: http://tce.cs.tut.fi/downloads
Change log: http://tce.cs.tut.fi/downloads/CHANGES
--
Pekka
More information about the llvm-dev
mailing list