Sound and Vision: A Technical Overview of the Emotion Engine
The Emotion Engine: Basic Architecture
As was stated above, the Emotion Engine's primary piece of output is the
display list. Generating those display lists involves a number of steps besides
just the obvious geometry calculations. For instance, if the software you're
running is a racing game, then you've got to first calculate the virtual
friction between a car's tires and the road (among other things) when the car
turns a corner before you can draw the next scene. Or if the game is an FPS, you
have to run the enemy AI's path-finding code so you'll know where to place them
on each frame. So there's a lot of stuff that goes on behind the scenes and
affects the output on the screen. All of this labor--geometry calculations,
physics calculations, AI, data transfers, etc.-- is divided up among the
- MIPS III CPU core
- Vector Unit (which is actually two vector units, VU0 and VU1).
- floating-point coprocessor, or FPU
- Image Processing Unit (The IPU is basically an MPEG2 decoder with
some other capabilities).
- 10-channel DMA controller
- Graphics Interface unit. (GIF)
- RDRAM interface and I/O interface (for connecting to the two
RDRAM banks and the I/O Processor, respectively))
All of the above components are integrated onto one die and are connected
(with the exception of the FPU) via a shared 128-bit internal bus.
As was noted in the bullet list, the VU can be further divided into two
independent, 128-bit SIMD/VLIW vector processing units, VU0 and VU1.
These units, though they're microarchitecturally identical, are each intended to
fill a specific role. Toshiba, who designed the Emotion Engine and licensed it
to Sony, didn't feel that it was optimal to have three pieces of general purpose
hardware (a CPU and two vector processors) that could be assigned to any task
that was needed. Instead, they fixed the roles of the devices in advance,
customized the devices to fit those roles, and organized them into logical
units. In that respect, they're sort of like employees who've been grouped
together on the basis of talent and assigned to teams. Let's look at the
division of labor amongst the components:
- CPU + FPU: basic program control, housekeeping, etc.
- CPU + FPU + VU0: behavior and emotion synthesis, physics
- VU1: simple geometry calculations that produce display lists which
are sent directly to the Graphics Synth (via the GIF).
- IPU: image decompression.
Of the above "teams," 2 and 3 are the ones I want to talk about
The CPU/FPU/VU0 team
The FPU and VU0 are coprocessors for the MIPS III CPU core. This means
that the CPU, the FPU, and VU0 all form a logical and functional unit (or a
team, if you will) where the CPU is the primary, controlling device and the
other two components extend its functionality. This CPU/FPU/VU0 team has a
common set of goals: emotion synthesis, physics, behavior simulation, etc. I'll
be going into much more detail on this collaboration in the second half of the
There are two main things that bind this team together and allow them to work
very closely with each other. The first is the way they communicate with each
other: VU0 and the FPU each have a dedicated, 128-bit coprocessor bus
that connects them directly to the CPU. That way, they don't have to talk over
the main, shared bus. The dedicated 128b bus also gives the CPU direct access to
VU0's registers, and allows VU0 to fill its role as a standard, MIPS III
The other important component that ties the CPU core and VU0 closely together
is the Scratch Pad RAM. The SPRAM is 16K of very fast RAM that lives on
the CPU, but that both the CPU and VU0 can use to store data structures. The
SPRAM also acts as a staging area for data, before it's sent out over the 128b
internal bus. So the SPRAM is kind of like a shared workspace, where the CPU and
VU0 collaborate on a piece of data before sending it out to wherever it needs to
The VU1/Graphics Synth team
The other main team is composed of VU1 and the Graphics Synthesizer (which
communicate via the GIF). Just as VU0 has a dedicated bus to the CPU core, VU1
has its own 128-bit dedicated path to the GIF. However, VU1 and the Graphics
Synth aren't as closely tied together as are the CPU/FPU/VU0 group. VU1 and the
GS are more like equal partners, and one doesn't control the other. You're
probably wondering at this point just who does control VU1. This is an
interesting question, and we'll discuss the answer when we talk about VU1's
architecture in detail.
Putting the teams together
Though the roles of the components were fixed by the PS2's designers, the
overall design is still quite flexible. You divvy up an application's work
amongst the teams however you like. For instance, the CPU/FPU/VU0 group can
generate display lists and do geometry processing in parallel with VU1, so both
groups can send display lists to the GIF at the same time.
Or, the CPU/FPU/VU0 group can act as a sort of preprocessor for VU1. The CPU
and co. process conditional branches in the rendering code and load data from
main memory. They then generate world information that VU1 takes as input and
and turns into a display list.
This flexibility allows a developer to customize the process of generating
and rendering the 3D environment to suit the needs of the specific application
you're working with.
Now that we've gone over the basics of the Emotion Engine's operation, it's
time to get hardcore. For the remainder of this article, I'll go in-depth on the
MIPS III CPU core, VU0, and VU1. I'll give you the straight scoop on how these
components are designed, and how they're integrated with each other. If terms
like instruction latency, pipelining, and SIMD make your eyes glaze over, then
you might want to check out here. If, however, you're an architecture enthusiast
who eats CPU internals for breakfast, then hang on, because what follows is