SHA256
[SHA256] FF() 구성 모듈 - (1): RR, Sigma0, Sigma1
Transform() 함수 내부에서 동작하는 여러 모듈들.. RR(Rotate Right) * RTL // rotate right module calc_RR( input wire [8*8-1:0] x, input wire [4:0]n, output wire [8*8-1:0] calc_x ); assign calc_x = (x>>n) | (x13) | (x13) | (x13 : 0000_0000_0000_0000__0000_0000_0000_0000__0000_0000_0000_0000__0000_0000_0000_0000 x
[SHA256][Verilog HDL] 코드 만들기
해시함수인 SHA-256을 Verilog HDL 언어로 만들어보려 한다. 참고한 코드는 c언어로, 코드를 해석한 글을 보고 싶으면 아래 글로 이동하면 된다.👇 [SHA-256] 코드 및 알고리즘 분석 - (1) 이전 포스팅 글에서는 SHA-256이 무엇인지 간단히 알아보았다. 이번에는 KISA에서 제공한 SHA-256의 C/C++ 코드를 분석하겠다. (전체 코드는 KSIA에서 다운로드할 수 있습니다.) 1. 헤더 파일 여러 가지의 s00m.tistory.com 전체적인 구성 위의 포스팅에서도 말하였지만, 다시 한번 설명하자면 SHA-256은 크게 3가지 단계로 이루어진다. Init(): 초기값 설정 Process(): 평문 메시지를 512bit 크기씩 블록으로 나누어 Transform() 압축함수 실행 ..
[SHA-256] 코드 실행 및 해시값 비교 방법
앞서 KISA에서 제공한 SHA-256의 C 코드와 알고리즘을 분석하였다. 이번에는 해당 코드가 올바르게 작동되는지 확인하기 위해서 코드를 실행해보겠다. (전체 코드는 KSIA에서 다운로드할 수 있습니다.) 👇코드에 대해서 자세히 알고싶다면? 아래의 주소로~ [SHA-256] 코드 및 알고리즘 분석 - (1) 이전 포스팅 글에서는 SHA-256이 무엇인지 간단히 알아보았다. 이번에는 KISA에서 제공한 SHA-256의 C/C++ 코드를 분석하겠다. (전체 코드는 KSIA에서 다운로드할 수 있습니다.) 1. 헤더 파일 여러 가지의 s00m.tistory.com 1. 실행코드 #include "KISA_SHA256.h" #include #include int main() { unsigned char buff..
[SHA-256] 코드 및 알고리즘 분석 - (5)
SHA256_Transform() 함수의 알고리즘에 대해서 이전 포스팅에서 분석하였다. 이번에는 FIPS-180 문서를 통해 더욱 자세히 분석해보려 한다. 먼저 알아둘 것이 있다면 for문을 제외하고는 알고리즘 모양이 같다. 0. 기호 SHA-256 해시 계산 알고리즘에서 사용될 함수 및 수식에 대해서 정의하고 시작하겠다. ROTR: rotate right shift SHR: right shift $Ch\left ( x,y,z \right ) = \left ( x\wedge y \right )\oplus \left ( \bar{x}\wedge z \right )$ $Maj\left ( x,y,z \right ) = \left ( x\wedge y \right )\oplus \left ( x\wedge z..