ST200 family


The ST200 is a family of very long instruction word processor cores based on technology jointly developed by Hewlett-Packard Laboratories and STMicroelectronics under the name Lx. The main application of the ST200 family is embedded media processing.

Lx architecture

The Lx architecture is closer to the original VLIW architecture defined by the Trace processor series from Multiflow than to the EPIC architectures exemplified by the IA-64. Precisely, the Lx is a symmetric clustered architecture, where clusters communicate through explicit send and receive instructions. Each cluster executes up to 4 instructions per cycle with a maximum of one control instruction, one memory instruction, and two multiply instructions per cycle. All arithmetic instructions operate on integer values with operands belonging either to the general register file or to the branch register file. General register $r0 always reads as zero, while general register $r63 is the link register. In order to eliminate some conditional branches, the Lx architecture also provides partial predication support in the form of conditional selection instructions. There is no division instruction, but a divide step instruction is provided. All instructions are fully pipelined. The RAW latencies are single-cycle except for the load, multiply, compare to branch RAW latencies. The WAR latencies are zero cycles and the WAW latencies are single cycle.
The principal architects for the ST200 Lx implementation
were Paolo Faraboschi and Fred Homewood. Key members of the architecture and microarchitecture team included Geoffrey Brown, Giuseppe Desoli, Gary Vondran, Trefor Southwell, Tony Jarvis, and Alex Starr.
The architecture was really a true cross company development, co-sited for the early duration of the project, lasting some two years.

ST200 cores

The ST200 VLIW family currently comprises the ST210, ST220, ST231 cores, which are single-cluster implementations of the Lx architecture. The differences among these cores are minimal:
In digital video, STM reported in 2009 that it had shipped over 40 million systems-on-chip containing a VLIW processor from the ST200 family. Since many of these SoCs contain multiple ST200s, they actually shipped in excess of 70 million of these VLIW processors.

Compiling tools

The first ST210 compiler was the HP Lx compiler developed at HP Labs Cambridge, itself a descendant of the Multiflow Trace scheduling compiler and heavily modified by HP to target the embedded domain. Starting with the ST220, STMicroelectronics introduced compilers based on the Open64 technology. In these compilers, the Open64 release has been improved by upgrading its GCC C and C++ front-end from 2.96 to 3.x and later 4.x, in order to achieve full C++ compliance. The GNU C extensions have been fully implemented in the Open64, including the asm statements. As a result, the Linux kernel can be compiled for the ST200.
The other ST200 compilation tools are straightforward ports of GNU as, GNU ld, and GDB.