PlayStation 2 technical specifications

From Infogalactic: the planetary knowledge core
(Redirected from PlayStation 2 hardware)
Jump to: navigation, search

Lua error in package.lua at line 80: module 'strict' not found.

The PlayStation 2 technical specifications describe the various components of the PlayStation 2 (PS2) video game console.

Overview

The sixth-generation hardware of the PlayStation 2 video game console consists of various components. At the heart of the console's configuration is its central processing unit (CPU), a custom RISC processor known as the Emotion Engine which operates at 299 MHz. The CPU heavily relies on its integration with two vector units, known as VU0 and VU1, the Graphics Synthesizer, and a floating-point unit (FPU) in order to render 3D graphics. Other components, such as the system's DVD-ROM optical drive and DualShock 2 controller, provide the software and user control input.

PlayStation 2 software is distributed on CD-ROM and DVD-ROM. In addition, the console can play audio CDs and DVD movies, and is backwardly compatible with original PlayStation (PS1) games. This backward compatibility is accomplished through the inclusion of the original PlayStation's CPU which also serves as the PS2's I/O processor.[1] The PS2 also supports limited functionality with PS1 memory cards and controllers. The PS2's DualShock 2 controller is an upgraded version of the PS1's DualShock with analog face, shoulder and D-pad buttons replacing the digital buttons of the original.[2] Like its predecessor, the DualShock 2 controller features force feedback technology.

The standard PlayStation 2 memory card has an 8 MB capacity and uses Sony's MagicGate encryption. This requirement prevented the production of memory cards by third parties who did not purchase a MagicGate license. Memory cards without encryption can be used to store PlayStation game saves, but PlayStation games would be unable to read from or write to the card – such a card could only be used as a backup. There are a variety of non-Sony manufactured memory cards available for the PlayStation 2, allowing for a larger memory capacity than the standard 8 MB. However their use is unsupported and compatibility is not guaranteed. These memory cards can have up to 128 MB storage space.

The console also features USB and IEEE 1394 expansion ports. Compatibility with USB and IEEE 1394 devices is dependent on the software supporting the device. For example, the PS2 BIOS will not boot an ISO image from a USB flash drive or operate a USB printer, as the machine's operating system does not include this functionality. By contrast, Gran Turismo 4 and Tourist Trophy are programmed to save screenshots to a USB mass storage device and print images on certain USB printers. A PlayStation 2 HDD can be installed via the expansion bay in the back of the console, and was required to play certain games, notably the popular Final Fantasy XI.[3] This was available on only certain models (see Connectivity).

Technical specifications[4][5][6][7][8]

Central processing unit

An SCPH-10000 motherboard
An SCPH-30001 motherboard
Graphics Synthesizer as found in SCPH-390xx
Older EE+GS that does not incorporate system memory as found in SCPH-700xx
ASIC that incorporates the EE, GS, and system memory as found in SCPH-7900x and later
An 8 MB PlayStation 2 memory card.
  • CPU: MIPS R5900-based "Emotion Engine", clocked at 294.912 MHz (299 MHz on newer versions), with 128-bit SIMD capabilities[9][10] 10.5 million transistors
    • CPU core: MIPS R5900(COP0), 64-bit, little endian (mipsel). CPU is a superscalar, in-order 2-issue design with 6 stage long integer pipelines, 32 128bit GPR registers, two 64bit integer ALUs, 128bit Load-Store Unit(LSU) and a Branch Execution Unit(BXU).
    • Instruction set: MIPS III, MIPS IV subset with Sony's proprietary 107 vector SIMD Multimedia Instructions (MMI) instructions. The custom instruction set was implemented by grouping the two 64-bit integer ALUs.
      • 32bit FPU Coprocessor(COP1) with 6 stage long pipeline (Floating Point Multiply Accumulator × 1, Floating Point Divider × 1). FPU isn't IEEE compliant
    • 32 bit VLIW-SIMD Vector Units at 147.456 MHz: VPU0 and VPU1 (Floating Point Multiply Accumulator × 9, Floating Point Divider × 1) each VPU contains vector unit(VU), instruction cache, data cache and interface unit. Each vector unit also has upper execution unit containing 4xfMAC and lower execution unit containing fDIV, integer ALU, Load-Store Unit, branch logic, 16 16-bit integer registers and 32 128-bit floating point registers. VPU1 has additional EFU unit.
      • VPU0(COP2)(FMAC x 4, FDIV x 1)which is tightly coupled with the main CPU and is typically used for polygon and geometry transformations optionally (under parallel or serial connection), physics and other gameplay based tasks
      • VPU1(Elementary Functional Unit-EFU)(FMAC x 5, FDIV x 2)which operates independently controlled by microcode, parallel to the CPU core, is typically used for polygon and geometry transformations, clipping, culling, lighting and other visual based calculations (Texture matrix able for 2 coordinates (UV/ST)[11]
        • Parallel: Results of VU0/FPU sent as another display list via MFIFO (E.G. complex characters/vehicles/etc.)
        • Serial: Results of VU0/FPU sent to VU1 (via 3 methods) and can act as an optional geometry pre-processor that does all base work to update the scene every frame (E.G. camera, perspective, boning and laws of movement such as animations or physics)[12]
    • Image Processing Unit (IPU): MPEG-2 Compressed Image Macroblock Layer Decoder allowing playback of DVDs and game FMV. It also allowed vector quantization for 2D graphics data.[13]
    • Memory management unit(MMU),[14] RDRAM controller and DMA controller: handle memory access within the system
    • Cache memory: Instruction Cache: 16 KB, Data Cache : 8 KB + 16 KB Scratchpad (ScrP)
    • Scratchpad(SPR) is extended area of memory visible to the EE CPU. This extended memory provides 16 Kilobytes of fast RAM available to be used by the application. Scratch Pad memory can be used to store temporary that data that is waiting to be sent via DMA or for any other temporary storage up to the programmer.

Interfaces

  • I/O Processor interconnection: Remote Procedure Call over a serial link, DMA controller for bulk transfer
  • Memory bus. Bandwidth: 3.2 gigabytes per second
  • Graphics interface (GIF) The DMA channel that connects the EE CPU to the GS co-processor. To draw something to the screen, one must send render commands to the GS via the GIF channel: 64-bit, 150 MHz bus, maximum theoretical bandwidth of 1.2 GB/s.[15]
  • Display lists generated by CPU/VPU0 and VPU1 are sent to the GIF, which prioritizes them before dispatching them to the Graphics Synthesizer for rendering.
  • Vector Unit Interface(VIF) which consists of two DMA channels VIF0 for VPU0 and VIF1 for VPU1. Vector units and the main CPU communicate via VIF DMA channels.
  • SIF - Serial Interface or Subsystem Interface which consists of 3 DMA channels:
  • Subsystem Interface 0(SIF0) and Subsystem Interface 1(SIF1) used for communication between the EE main CPU and IOP co-processor. These are serial DMA channels where both CPUs can send commands and establish communication through an RPC protocol.
  • Subsystem Interface 2(SIF2) used for backwards compatibility with PS1 games and debugging.

Performance

  • Floating Point Performance: 6.2 GFLOPS (single precision 32-bit floating point)
    • FPU 0.64 GFLOPS
    • VU0 2.44 GFLOPS
    • VU1 3.08 GFLOPS (with Internal 0.64 GFLOPS EFU)
  • Tri-Strip Geometric transformation (VU0+VU1): 150 million vertices per second[16]
    • 3D CG Geometric transformation with raw 3D perspective operations (VU0+VU1): 66-80+ million vertices per second[11]
    • 3D CG Geometric transformations at peak bones/movements/effects (textures)/lights (VU0+VU1, parallel or series): 15–20 million vertices per second[16]
    • Lighting: 38Million Polygons/sec
    • Fog: 36Million Polygons/sec
    • Curved Surface Generation (Bezier): 16Million Polygons/sec
    • Image Processing Performance: 150Million Pixels/sec
    • Actual real-world polygons (per frame): 500-650k at 30fps, 250-325k at 60fps
  • Instructions per second: 6,000 MIPS (million instructions per second)[17]

System memory

Graphics processing unit

  • Graphics processing unit: GS Core: Parallel Rendering Processor with embedded DRAM "Graphics Synthesizer" (GS) clocked at 147.456 MHz
  • PCRTC Circuit.
    • Pixel pipelines: 16 without any texture mapping units(TMU) however half of pixel pipelines can perform texturing so fillrate is either 16 pixels per clock with untextured 2400 mpixels or 8 pixels per clock with 1200 megapixels with bilinear texturing, and 1200 megatexels (bilinear).
    • Video output resolution: Variable from 256 x 224 to 1920 x 1080[18]
    • 4 MB of embedded DRAM as video memory (an additional 32 MB of main memory can be used as video memory for off-screen textures); 48 gigabytes per second peak bandwidth
      • Texture buffer bandwidth: 9.6 GB/s
      • Frame buffer bandwidth: 38.4 GB/s
    • DRAM Bus width: 2560-bit (composed of three independent buses: 1024-bit write, 1024-bit read, 512-bit read/write)
    • Pixel configuration: RGB: Alpha:Z Buffer (24:8, 15:1 for RGB, 16, 24, or 32-bit Z buffer)
    • Display Colour Depth: 32 bit (RGBA: 8 bits each)
    • Dedicated connection to: Main CPU and VU1
    • Overall pixel fillrate: 16×147 = 2.352 Gpixel/s (rounded to 2.4 Gpixel/s)
    • 1.2 Giga Pixel per Second (with Z buffer, Alpha and Texture)
      • Pixel fillrate: with no texture, flat shaded 2.4 (75,000,000 32pixel raster triangles)
      • Pixel fillrate: with 1 full texture (Diffuse Map), Gouraud shaded 1.2 (37,750,000 32-bit pixel raster triangles)
      • Pixel fillrate: with 2 full textures (Diffuse map + specular or alpha or other), Gouraud shaded 0.6 (18,750,000 32-bit pixel raster triangles)
      • Texture fillrate: 1,2 Gtexels/s
      • Sprite Drawing Rate: 18.75 Million (8 x 8 Pixels)
      • Particle Drawing Rate: 150 Million /sec
      • Polygon Drawing Rate: 75 Million /sec (small polygon)
    • 50 Million /sec (48 Pixel quad with Z and A)
    • 30 Million /sec (50 Pixel triangle with Z and A)
    • 25 Million /sec (48 Pixel quad with Z, A and T)
    • VESA (maximum 1280 x 1024 pixels)
      • 3 rendering paths(Path 1, 2 and 3)
      • GS effects include: Read-Write textures, Emboss Bump Mapping, Dot3 Bump Mapping(Normal Mapping),[19] multiple-light sources, per-vertex lighting, Volumetric Fog, Mipmapping, LOD, Spherical Harmonic Lighting,[20] High Dynamic Range(HDR) Rendering, Motion Blur, Heat Haze, Bloom, Depth of Field, Shadow Volumes, Shadow Mapping, Lightmapping, Environment Mapping, Render to Texture, Alpha Blending, Alpha Test, Destination Alpha Test, Depth Test, Scissor Test, Transparency effects, framebuffer effects, post-processing effects, Perspective-Correct Texture Mapping, Edge-AAx2 (poly sorting required),[11] Bilinear, Trilinear texture filtering, Multi-pass, Palletizing (4-bit = 6:1 ratio, 8-bit = 3:1), NURBS, Bezier Curves, Bezier Surfaces, B-Splines, Offscreen Drawing, Framebuffer Mask, Flat Shading, Gouraud Shading, Cel Shading, Dithering, Texture Swizzling.
    • Multi-pass rendering ability
      • Four passes = 300 Mpixel/s (300 Mpixels/s divided by 32 pixels = 9,375,000 triangles/s lost every four passes)[21]

Audio

  • Audio: "SPU1+SPU2" (SPU1 is actually the CPU clocked at 8 MHz and SPU2 is PS1 SPU)
    • Sound Memory: 2 MB
    • Number of voices: 48 hardware channels of ADPCM on SPU2 plus software-mixed definable, programmable channels
    • Sampling Frequency: 44.1 kHz or 48 kHz (selectable)
    • PCM audio source
    • Digital effects include:
    • Pitch Modulation
    • Envelope
    • Looping
    • Digital Reverb
    • Load up to 512K of sampled waveforms
    • Supports MIDI Instruments
    • Output: Dolby Digital 5.1 Surround sound, DTS (Full motion video only), later games achieved analog 5.1 surround during gameplay through Dolby Pro Logic II

I/O processor

  • Input Output Processor (IOP)
    • I/O Memory: 2 MB
    • CPU Core: Original PlayStation CPU (MIPS R3000A clocked at 33.8688 MHz or 37.5 MHz+PS1 GTE and MDEC for backwards compatibility with PS1 games)
    • Automatically underclocked to 33.8688 MHz to achieve hardware backwards compatibility with original PlayStation format games.
    • Sub Bus: 32-bit
    • Connection to: SPU and CD/DVD controller.

Connectivity

    • 2 proprietary PlayStation controller ports (250 kHz clock for PS1 and 500 kHz for PS2 controllers)
    • 2 proprietary Memory Card slots using MagicGate encryption (250 kHz for PS1 cards, up to 2 MHz for PS2 cards)
    • 2 USB 1.1 ports with an OHCI-compatible controller
    • AV Multi Out (Composite video, S-Video, RGBS (SCART), RGsB (VGA connector), YPBPR(component), and D-Terminal)
    • RFU DC Out
    • S/PDIF Digital Out
    • Expansion Bay for 3.5" HDD and Network Adaptor (required for HDD, SCPH-300xx to 500xx only)[22]
    • PC Card slot for Network Adaptor (PC Card type) and External Hard Disk Drive (SCPH-10000, SCPH-15000, SCPH-18000 models)[23]
    • Emotion Engine (EE) includes an on-chip Serial I/O port(SIO) used internally by the EE's kernel to output debugging and messages and to start the kernel debugger.
    • Ethernet port (Slim only)
    • i.LINK (also known as FireWire) (SCPH-10000 to 3900x only)[24]
    • Infrared remote control port (SCPH-500xx and newer)[25]

^† VGA connector is only available for progressive-scan supporting games, homebrew-enabled systems, and Linux for PlayStation 2, and requires a monitor that supports RGsB, or "sync on green," signals.

Optical disc drive

  • Disc Drive type: proprietary interface through a custom micro-controller + DSP chip. 24x speed CD-ROM, 4x speed DVD-ROM — Region-locked with copy protection.
  • Supported Disc Media: PlayStation 2 format CD-ROM, PlayStation format CD-ROM, CD-DA, PlayStation 2 format DVD-ROM, DVD Video. DVD5 (Single-layer, 4.7 GB) and DVD9 (Dual-layer, 8.5 GB) supported. Later models starting with SCPH-500xx are DVD+RW and DVD-RW compatible.

See also

References

  1. http://www.theguardian.com/technology/2013/dec/12/ps4-and-xbox-one-so-why-arent-they-backwards-compatible
  2. Lua error in package.lua at line 80: module 'strict' not found.
  3. Lua error in package.lua at line 80: module 'strict' not found.
  4. http://users.ece.gatech.edu/lanterma/mpg/ece4893lec_ps2.pdf
  5. http://www.ps2fantasy.com/hardware/ps2/system.php
  6. http://www.angelfire.com/electronic2/mariotan/
  7. http://users.beagle.com.au/jmk222/d-ps.html
  8. http://www.docstoc.com/docs/73439402/Inside-PlayStation-2
  9. John L. Hennessy and David A. Patterson. "Computer Architecture: A Quantitative Approach, Third Edition". ISBN 1-55860-724-2
  10. Keith Diefendorff. "Sony's Emotionally Charged Chip". Microprocessor Report, Volume 13, Number 5, April 19, 1999. Microdesign Resources.
  11. 11.0 11.1 11.2 Lua error in package.lua at line 80: module 'strict' not found.
  12. Lua error in package.lua at line 80: module 'strict' not found.
  13. http://users.ece.gatech.edu/lanterma/mpg/ece4893lec_ps2.pdf
  14. http://galileo.dmi.unict.it/utenti/emanuele-f/posts/ps2dev/docs/Procedural%20Rendering%20on%20PlayStation%202.pdf
  15. Lua error in package.lua at line 80: module 'strict' not found.
  16. 16.0 16.1 Lua error in package.lua at line 80: module 'strict' not found.
  17. http://www.frc.ri.cmu.edu/~hpm/book97/ch3/processor.list.txt
  18. http://psx-scene.com/forums/f291/gs-mode-selector-development-feedback-61808/#post457673
  19. http://lukasz.dk/files/ps2_normalmapping.pdf
  20. http://slidegur.com/doc/3412625/practical-implementation-of-sh-lighting-and-hdr-rendering
  21. Lua error in package.lua at line 80: module 'strict' not found.
  22. Lua error in package.lua at line 80: module 'strict' not found.
  23. Lua error in package.lua at line 80: module 'strict' not found.
  24. Lua error in package.lua at line 80: module 'strict' not found.
  25. Lua error in package.lua at line 80: module 'strict' not found.