 
                 Patent Grant
 Patent Grant
                     8189792
 8189792
                    Cryptographic operations such as an Advanced Encryption Standard (AES) operation are typically implemented in software for execution on generic processor hardware. Many processors include datapaths of fixed widths such as 64, 86, or 128 bits. Given limited hardware and instruction support for cryptographic operations, is difficult to efficiently perform such operations on existing processors.
Further, processor floorplans have a wide X dimension and a critical Y dimension with a high aspect ratio. Any increase in the Y dimension adds to the growth of the overall chip. The allocated Y budget is very small and thus there is a need to find a minimal area solution at a good performance for the round operations. The performance has latency and throughput considerations; some modes of the AES algorithm are serial in nature where latency of the operations is an issue, whereas others are parallelizable and throughput is more of an issue. Furthermore, splitting key generation across the dual execution pipes involves many bits of information that must cross back and forth between the pipes, which implies large buses that add to the critical height of the chip.
    
    
    
    
In various embodiments, cryptographic operations can be mapped to a processor having multiple datapaths of a smaller width than a width of the operands used in the cryptographic operation. In this way, such operations can be efficiently performed while using a limited amount of floorplan of a processor.
While the scope of the present invention is not limited in this regard, some embodiments may be directed to parallel datapaths that can be used to perform AES operations and more particularly AES round operations. This also may be in accordance with the Federal Information Processing Standards (FIPS) specification, entitled “Advanced Encryption Standard” (AES), dated Nov. 26, 2001. The AES algorithm operates on a 4×4 array of bytes, termed the state. For encryption, each round of AES (except the last round) consists of four stages: (1) AddRoundKey where each byte of the state is combined with a round key, and each round key is derived from the cipher key using a key schedule; (2) SubBytes, which is a non-linear substitution step where each byte is replaced with another according to a lookup table; (3) ShiftRows, which is a transposition step where each row of the state is shifted cyclically a certain number of steps; and (4) MixColumns which is a mixing operation that operates on the columns of the state, combining the four bytes in each column using a linear transformation.
The final round replaces the MixColumns stage with another instance of AddRoundKey. Decryption is similar and is not described here. The first two steps work on a byte-level of the state. The third step treats the state as consisting of four rows in which no change is made to the first row, the second row is shifted left one column, the third row is shifted left two columns, and in the fourth row, each element is left shifted three columns. An example of such a shift row operation is shown in 
As described, the last step, MixColumns, treats the state as consisting of 4 columns, in which the four bytes of each column of the state are combined using an invertible linear transformation. The MixColumns function takes four bytes as input and outputs four bytes, where each input byte affects all four output bytes. Together with ShiftRows, MixColumns provides diffusion in the cipher. Each column is treated as a polynomial over a GF (28) and is then multiplied modulo x4+1 with a fixed polynomial c(x)=3x3+x2+x+2. The MixColumns step can also be viewed as a matrix multiply in Rijndael's finite field. An example of a mix columns operation is shown in 
Conventional hardware designs find it convenient to implement the AES in terms of columns. A full implementation of the round hardware requires logic for all 4 columns. This gives the highest performance but is very expensive in terms of area. While 2 or 1 columns can be implemented in the hardware, and each round is made into a multi-pass operation, performance can be negatively impacted. A 2-column solution is described herein, although embodiments can be extended to a 1-column implementation.
Constraints in some processor micro-architectures make some partial column approaches very difficult. These constraints include the execution pipeline has to have a fixed latency of four cycles and a throughput of single-cycle. This implies that every cycle a new micro-operation (μop) can be issued to the pipe. A μop can have at most 2 source registers and 1 destination register, which complicates splitting a round operation into 2 μops, since the key has to be sourced as well into the round operations.
In various embodiments, to reduce these problems of area and performance and pipeline constraints, a round operation can be defined in terms of 3 μops and the area for two columns is implemented in hardware; one column per each data-path. In one embodiment, the round operation consists of a Round.upper μop, a Round.lower μop, and a merge μop. The merge μop can be bit-wise exclusive OR (XOR) μop that can execute in parallel on other ports, providing greater throughput performance.
Referring now to 
Referring still to 
While shown with this particular implementation in the embodiment of 
The four columns of the data block (as shown in 
Referring now to Table 1, shown is a scheduling of an AES round operation on the hardware of 
  
    
      
        
        
        
        
        
        
        
        
          
            
          
          
            
          
          
            
            
            
            
            
            
            
          
          
            
          
        
        
          
            
          
        
      
      
        
        
        
        
        
        
        
        
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
            
            
            
            
            
          
          
            
          
        
      
    
  
In this implementation, the round operation can be achieved under scheduling conditions in accordance with an embodiment of the present invention in six cycles of latency per round. Thus the AES 128 encrypt schedule shown in Table 1 should take 10*6=60 cycles; the few extra cycles are due to the trivial round0 operation. Since the PXOR μop is issued in parallel on another port, the throughput is constrained by the three μops issued per round in the AES unit (one related to key generation) which accounts for three cycles per round. Therefore in parallel AES modes (or multi-threaded) a throughput of 30 cycles per AES-128 operation can be realized. This is roughly 10× faster than a software implementation of AES on a processor.
Thus in various embodiments, the AES round operations can be split across two 64b datapaths, using an implementation of 2 AES colunms. Further, a mapping of round operations to micro-operations with the constraints of the pipeline/scheduler to maximize performance/area can thus be realized using an optimal schedule of μops, which can be stored in a microcode read only memory (ROM). In some embodiments, 16 bits of data can be transferred from left to right and right to left for shift row operations using a dedicated 32b bus, e.g., in the input logic.
Embodiments may enable high performance at very high clock speeds, while providing area-efficiency, enabling implementation of a 128-bit algorithm on dual 64-bit execution data-paths with minimal μops and good performance and minimizing the area required on the core. Embodiments can also be extended to a 1-column implementation at lower performance and more area-savings.
In various embodiments, such as in connection with the datapath described above regarding 
  
    
      
        
        
        
          
            
            
          
          
            
            
          
        
        
          
            
            
          
          
            
            
          
          
            
            
          
        
      
    
  
This micro-instruction implements the shuffle of QW data between the two halves of the 128 bit datapath. This μop selects any two pieces of 64 bits each out of the two 128 bit sources (source1 and source2), pointed to by 4 bit immediate data. The result is stored in a destination location, dest.
In one embodiment, source1 and source2 are 128-bit packed elements that can be used to form the result, while destination is the register where the selected elements are stored. The immediate data may be a shuffle_select_modifier which is one of the modifiers described below that is used to specify the source of the immediate data. In turn, the immediate data is used to select which QW elements of source2 and source1 get stored in the destination.
The following code of Table 3 describes the operation performed by this micro-operation.
  
    
      
        
        
          
            
          
          
            
          
        
        
          
            
          
        
      
      
        
        
        
          
            
            
          
        
      
      
        
        
        
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
        
      
      
        
        
        
          
            
            
          
        
      
      
        
        
        
          
            
            
          
        
      
      
        
        
        
          
            
            
          
          
            
            
          
          
            
            
          
          
            
            
          
        
      
      
        
        
        
          
            
            
          
        
      
      
        
        
          
            
          
          
            
          
        
      
    
  
All key-sizes for encryption are performed using a 64-bit shared bus. More specifically, a 32b left to right (L to R) and a 32b right to left (R to L) bus (which may be implemented in input logic 15 of 
As will be described below, all data transfers are done in the very first cycle because the critical path is one XOR3 delay (+some MUX delays for choosing amongst the cases). In some cases, this means that redundant SBox computations are performed in both datapaths to be able to make an early crossing; this comes for nearly free from an area perspective (ignoring power) since there is a minimum of eight SBoxes (four on each side as shown in 
  
Referring now to 
Referring now to 
Note that the 192 bit operations have a flow where there are two μops issued per round to transfer the 128 bits of information. The critical 128/256 cases have just a single μop for the key generation and therefore have very high performance. The μop for swapping that is used in the 192 schedule is a 1-cycle operation and thus a schedule can be generated that has the same latency as all the rest.
Embodiments thus enable high performance at very high clock speeds and are area-efficient. The key scheduler can be completely eliminated from the critical path of the design with this technique. The latencies per round for all key sizes are the same. Further, the shuffle instruction can issue on a parallel ports thereby minimizing any throughput performance loss associated with 192 key generation. Thus embodiments provide a design with the minimal number of wires for the combined key generation and round operations.
Furthermore, embodiments can schedule data movement in each cycle that minimizes the amount of buses (and area) needed for key generation without adding to the critical path. Specifically, early (first cycle) data movements permit maximal sharing of buses between key generation and round operations.
Embodiments may be implemented in many different system types. Referring now to 
Still referring to 
Furthermore, chipset 590 includes an interface 592 to couple chipset 590 with a high performance graphics engine 538 via a P-P interconnect 539. In turn, chipset 590 may be coupled to a first bus 516 via an interface 596. As shown in 
Embodiments may be implemented in code and may be stored on a storage medium having stored thereon instructions which can be used to program a system to perform the instructions. The storage medium may include, but is not limited to, any type of disk including floppy disks, optical disks, compact disk read-only memories (CD-ROMs), compact disk rewritables (CD-RWs), and magneto-optical disks, semiconductor devices such as read-only memories (ROMs), random access memories (RAMs) such as dynamic random access memories (DRAMs), static random access memories (SRAMs), erasable programmable read-only memories (EPROMs), flash memories, electrically erasable programmable read-only memories (EEPROMs), magnetic or optical cards, or any other type of media suitable for storing electronic instructions.
While the present invention has been described with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of this present invention.
| Number | Name | Date | Kind | 
|---|---|---|---|
| 6195756 | Hurd | Feb 2001 | B1 | 
| 6298136 | Den Boer | Oct 2001 | B1 | 
| 6751319 | Luyster | Jun 2004 | B2 | 
| 20030202658 | Verbauwhede | Oct 2003 | A1 | 
| 20050058285 | Stein et al. | Mar 2005 | A1 | 
| 20060002549 | Avasarala et al. | Jan 2006 | A1 | 
| 20060206726 | Wasson et al. | Sep 2006 | A1 | 
| 20070157030 | Feghali et al. | Jul 2007 | A1 | 
| Number | Date | Country | |
|---|---|---|---|
| 20090168999 A1 | Jul 2009 | US |