Verification Central

 

Decoding SAS 24G: New Encoding and Features

SAS follows its own version of Moore’s law, doubling the speed every few years. Keeping up with the tradition, SAS 24G (Gen-5) was recently introduced. Let’s decode, how the effective speed has been doubled to 24G, though signaling rate remains at 22.5G. This has been achieved through a more efficient 128b/150b encoding scheme to realize a usable data rate of 24G while retaining compatibility with 6G and 12G. Additional features were also introduced to improve the overall protocol efficiency. Some of the newly added features include binary primitives, primitive parameters, SMP open priority, inter-expander fairness arbitration enhancements, … etc. In this blog we will look into some of the new features, and will continue to delve into more details in the upcoming blogs on SAS.

128b/150b Encoding

The support for Gen-5 is not merely a speed bump from earlier Gen-4; but also utilizes a whole new encoding scheme. SAS-4 utilizes 128b/150b encoding scheme that is aimed at providing better link efficiency at speeds 22.5G and higher. To preserve backward compatibility with earlier generations, the 128b/150b encoding is utilized when the physical link operates at Gen-5 or higher (SAS Packet mode). Traditional 8b/10b encoding scheme is used when the physical link operates at Gen-4 or lower speeds (SAS Dword mode).

The 128b/150b encoding process encodes four dwords into 150 bits, whereas the 8b/10b encoding method would have resulted in 160-bits for the same four dwords (lesser number of bits to transmit!). Unlike 8b/10b encoding, the 128b/150b encoding allows for correction of transmission errors at the receiver. In this new encoding scheme, the information is transferred in the form of ‘SPL packets’ which are 150-bit blocks transmitted serially on the wire.  Each block contains:

  1. 2-bit SPL Packet Header
  2. 128-bit SPL Packet Payload Descriptor
  3. 20-bit Forward Error Correction(FEC) Information
SPL Packet
SPL Packet

SPL Packet Header

The SPL Packet Header field defines the format of the packet payload descriptor i.e. the type of segment contained in the packet payload.

SPL Packet Payload Descriptor

The Packet Payload descriptor contains a scrambled idle segment, idle dword segment, SPL frame segment or a primitive segment. A simple way to think of packet payload descriptor would be that it is a collection of four dwords of identical type (primitive or data dwords).

  • A scrambled idle segment contains four data dwords set to zero. A scrambled idle segment is a deletable SPL packet.
  • An idle dword segment contains four scrambled idle dwords and is transmitted outside a frame.
  • A frame segment contains four data dwords that are part of a frame. This can be a SSP frame segment, SMP frame segment, STP frame segment or an address frame segment. The CRC is placed in the final SPL packet of the frame. As all packets are 4-dword aligned, pad words are used to fill any unfilled slots between the CRC and end of the SPL frame segment.
  • A primitive segment contains an extended binary primitive or four dwords that are primitives/binary primitives (and, associated primitive parameter, if any). We’ll see more on binary primitives and primitive parameters in subsequent blogs.

Forward Error Correction

The 128b150b encoding scheme also equips the receivers with the ability to correct transmission errors. This is made possible with the Forward Error Correction information embedded in each SPL packet. A Reed Solomon code is used for this purpose. For the computation of FEC, a 26-symbol message M(x) is constructed using the 2-bit Packet header and 128-bit packet payload. Each symbol is 5-bits wide (26 symbols x 5 bits = 130 bits). The parity check symbols P(x) is then calculated over this message M(x). The computed parity P(x) is embedded in the original message and transmitted. The selected Reed Solomon code allows correction of up to 2 symbol errors.

We will look into Binary primitives and Primitive parameters in the upcoming blogs. Stay tuned!

Synopsys recently announced the availability of industry’s first VIP to support SAS 24G.
To know more about Synopsys storage VIP, please visit http://synopsys.com/vip
Also read our recent blogs on storage.
Evolution of Storage Protocols: SCSI to SAS
Industry’s First SAS 24G Verification IP for Enterprise Storage Systems

Authored by Srinivas Vijayaragavan and Pooja Gupta.