mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	Simplified sha512_32
This commit is contained in:
		
							parent
							
								
									c160ced2d2
								
							
						
					
					
						commit
						d9a1691c83
					
				| @ -31,67 +31,46 @@ module sha512_32 ( | ||||
|    output logic [31:0] result | ||||
| ); | ||||
| 
 | ||||
|    logic [31:0] x[6][6]; | ||||
|    logic [31:0] y[6]; | ||||
|    logic [31:0] x[6][3]; | ||||
|    logic [31:0] y[3]; | ||||
| 
 | ||||
|    // sha512{sig0h/sig0l/sig1h/sig1l/sum0r/sum1r} select shifted operands for 32-bit xor6
 | ||||
| 
 | ||||
|    // sha512sig0h
 | ||||
|    assign x[0][0] = A >> 1; | ||||
|    assign x[0][1] = A >> 7; | ||||
|    assign x[0][2] = A >> 8; | ||||
|    assign x[0][3] = B << 31; | ||||
|    assign x[0][4] = B << 24; | ||||
|    assign x[0][5] = '0;    | ||||
|    assign x[0][0] = {B[0], A[31:1]}; | ||||
|    assign x[0][1] = {B[7:0], A[31:8]};  | ||||
|    assign x[0][2] = {7'b0, A[31:7]}; | ||||
| 
 | ||||
|    // sha512sig0l
 | ||||
|    assign x[1][0] = A >> 1;  | ||||
|    assign x[1][1] = A >> 7;  | ||||
|    assign x[1][2] = A >> 8;  | ||||
|    assign x[1][3] = B << 31; | ||||
|    assign x[1][4] = B << 25; | ||||
|    assign x[1][5] = B << 24; | ||||
|    assign x[1][0] = x[0][0]; | ||||
|    assign x[1][1] = x[0][1];  | ||||
|    assign x[1][2] = {B[6:0], A[31:7]}; | ||||
| 
 | ||||
|    // sha512sig1h
 | ||||
|    assign x[2][0] = A << 3; | ||||
|    assign x[2][1] = A >> 6; | ||||
|    assign x[2][2] = A >> 19; | ||||
|    assign x[2][3] = B >> 29; | ||||
|    assign x[2][4] = B << 13; | ||||
|    assign x[2][5] = '0;       | ||||
|    assign x[2][0] = {A[28:0], B[31:29]}; | ||||
|    assign x[2][1] = {B[18:0], A[31:19]}; | ||||
|    assign x[2][2] = {6'b0, A[31:6]};   | ||||
| 
 | ||||
|    // sha512sig1l
 | ||||
|    assign x[3][0] = A << 3;  | ||||
|    assign x[3][1] = A >> 6;  | ||||
|    assign x[3][2] = A >> 19;  | ||||
|    assign x[3][3] = B >> 29; | ||||
|    assign x[3][4] = B << 26; | ||||
|    assign x[3][5] = B << 13; | ||||
|    assign x[3][0] = x[2][0]; | ||||
|    assign x[3][1] = x[2][1]; | ||||
|    assign x[3][2] = {B[5:0], A[31:6]};     | ||||
| 
 | ||||
|    // sha512sum0r
 | ||||
|    assign x[4][0] = A << 25;  | ||||
|    assign x[4][1] = A << 30;  | ||||
|    assign x[4][2] = A >> 28;  | ||||
|    assign x[4][3] = B >> 7; | ||||
|    assign x[4][4] = B >> 2; | ||||
|    assign x[4][5] = B << 4; | ||||
|    assign x[4][0] = {A[6:0], B[31:7]};  | ||||
|    assign x[4][1] = {A[1:0], B[31:2]}; | ||||
|    assign x[4][2] = {B[27:0], A[31:28]};     | ||||
| 
 | ||||
|    // sha512sum1r
 | ||||
|    assign x[5][0] = A << 23;  | ||||
|    assign x[5][1] = A >> 14;  | ||||
|    assign x[5][2] = A >> 18;  | ||||
|    assign x[5][3] = B >> 9; | ||||
|    assign x[5][4] = B << 18; | ||||
|    assign x[5][5] = B << 14;    | ||||
|    assign x[5][0] = {A[8:0], B[31:9]};  | ||||
|    assign x[5][1] = {B[13:0], A[31:14]}; | ||||
|    assign x[5][2] = {B[17:0], A[31:18]};  | ||||
| 
 | ||||
|    // 32-bit muxes to select inputs to xor6 for sha512
 | ||||
|    assign y[0] = x[ZKNHSelect[2:0]][0];  | ||||
|    assign y[1] = x[ZKNHSelect[2:0]][1];  | ||||
|    assign y[2] = x[ZKNHSelect[2:0]][2]; | ||||
|    assign y[3] = x[ZKNHSelect[2:0]][3];  | ||||
|    assign y[4] = x[ZKNHSelect[2:0]][4];  | ||||
|    assign y[5] = x[ZKNHSelect[2:0]][5];     | ||||
|   | ||||
|    // sha512 32-bit xor6
 | ||||
|    assign result = y[0] ^ y[1] ^ y[2] ^ y[3] ^ y[4] ^ y[5]; | ||||
|    assign result = y[0] ^ y[1] ^ y[2]; | ||||
| endmodule | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user