[go: up one dir, main page]

KR100581662B1 - Common engine for computing multiple hash functions with different algorithms - Google Patents

Common engine for computing multiple hash functions with different algorithms Download PDF

Info

Publication number
KR100581662B1
KR100581662B1 KR1020050080532A KR20050080532A KR100581662B1 KR 100581662 B1 KR100581662 B1 KR 100581662B1 KR 1020050080532 A KR1020050080532 A KR 1020050080532A KR 20050080532 A KR20050080532 A KR 20050080532A KR 100581662 B1 KR100581662 B1 KR 100581662B1
Authority
KR
South Korea
Prior art keywords
intermediate value
function
hash
common
calculating
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
KR1020050080532A
Other languages
Korean (ko)
Inventor
김원희
Original Assignee
주식회사 칩스앤미디어
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 주식회사 칩스앤미디어 filed Critical 주식회사 칩스앤미디어
Priority to KR1020050080532A priority Critical patent/KR100581662B1/en
Application granted granted Critical
Publication of KR100581662B1 publication Critical patent/KR100581662B1/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/06Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols the encryption apparatus using shift registers or memories for block-wise or stream coding, e.g. DES systems or RC4; Hash functions; Pseudorandom sequence generators
    • H04L9/0643Hash functions, e.g. MD5, SHA, HMAC or f9 MAC
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/14Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols using a plurality of keys or algorithms

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Power Engineering (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

본 발명은 함수 연산 엔진에 관한 것으로서, 더욱 상세하게는 알고리즘이 다른 복수의 해쉬 함수를 연산할 수 있는 하드웨어로 구현된 해쉬 함수 연산 엔진에 관한 것이다. 본 발명에 따른 함수 연산 엔진은 알고리즘이 다른 적어도 둘 이상의 해쉬 함수 연산에 필요한 중간값을 공유하거나, 알고리즘이 서로 다른 적어도 둘 이상의 해쉬 함수를 연산하기 위하여 구비되는 연산회로에서 공통되는 회로를 공유할 수 있다. 따라서, 알고리즘의 구조가 유사한 복수의 해쉬 함수를 처리하기 위한 회로에서, 동일한 하드웨어 구성요소를 공유할 수 있도록 설계함으로써, 함수 처리에 필요한 하드웨어를 줄일 수 있다.The present invention relates to a function calculation engine, and more particularly, to a hash function calculation engine implemented in hardware capable of computing a plurality of hash functions different algorithms. The function calculation engine according to the present invention may share a common value in a calculation circuit in which algorithms are provided for computing at least two or more hash functions, which are different from each other, or algorithms for calculating at least two or more hash functions. have. Therefore, in a circuit for processing a plurality of hash functions with similar algorithm structures, the hardware required for the function processing can be reduced by designing to share the same hardware components.

해쉬 함수, 해쉬 엔진, SHA-1, HAS, 공통 엔진 Hash Function, Hash Engine, SHA-1, HAS, Common Engine

Description

알고리즘이 다른 복수의 해쉬 함수 연산을 위한 공통엔진{Common engine for plural Hash functions having different algorithms}Common engine for plural Hash functions having different algorithms

본 명세서에 첨부되는 다음의 도면들은 본 발명의 바람직한 실시예를 예시하는 것이며, 후술하는 발명의 상세한 설명과 함께 본 발명의 기술사상을 더욱 이해쉬키는 역할을 하는 것이므로, 본 발명은 그러한 도면에 기재된 사항에만 한정되어 해석되어서는 아니된다.The following drawings, which are attached to this specification, illustrate the preferred embodiments of the present invention, and together with the detailed description of the invention that serves to further understand the spirit of the present invention, the present invention is described in such drawings. It should not be construed as limited to matters.

도 1은 종래기술에 따른 해쉬 함수 연산 엔진을 개략적으로 도시한 도면이다. 1 is a view schematically showing a hash function calculation engine according to the prior art.

도 2는 종래기술에 따른 복수의 해쉬 함수 처리부를 구비한 함수 연산 엔진의 구성도이다. 2 is a block diagram of a function calculation engine having a plurality of hash function processing units according to the prior art.

도 3은 종래기술에 따른 해쉬 함수 연산 엔진에서 복수의 중간값 처리부를 나타내는 도면이다.3 is a diagram illustrating a plurality of intermediate value processing units in the hash function calculation engine according to the related art.

도 4는 본 발명의 일 실시예에 따른 해쉬 함수 연산을 위한 공통엔진의 구성도이다.4 is a block diagram of a common engine for a hash function operation according to an embodiment of the present invention.

도 5는 본 발명의 다른 실시예에 따른 해쉬 함수 연산을 위한 공통엔진의 구성도이다.5 is a configuration diagram of a common engine for a hash function operation according to another embodiment of the present invention.

도 6은 도 4의 해쉬 함수 연산을 위한 공통엔진의 상세 구성도이다. FIG. 6 is a detailed configuration diagram of a common engine for computing the hash function of FIG. 4.

<도면의 주요 참조부호에 대한 설명><Description of main reference numerals in the drawings>

1, 7...입력 버퍼 2, 40, 60, 80...중간값 처리부1, 7 Input buffer 2, 40, 60, 80

210...SHA-1 중간값 처리부 220...HAS 중간값 처리부210 ... SHA-1 intermediate value processing unit 220 ... HAS intermediate value processing unit

310...SHA-1 함수 처리부 320...HAS 함수 처리부310 ... SHA-1 function processor 320 ... HAS function processor

3, 50, 70, 90...함수 연산부 81...저장 블록3, 50, 70, 90 ... Function operator 81 ... Storage block

82...중간값 변수 연산부 83...SHA-1 선택 버퍼82 ... Medium value operator 83 ... SHA-1 selection buffer

84...SHA-1 중간값 연산회로 85...HAS 선택 버퍼84 ... SHA-1 intermediate value calculating circuit 85 ... HAS selection buffer

86...HAS 중간값 연산회로 91...선택회로86 ... HAS intermediate value calculation circuit 91 ... selection circuit

92...함수값 저장 블록 93...함수 선택부92 ... Save function block 93 ... Select function

94...공통함수 연산부 95...차등함수 연산부94.Common function calculator 95 ... Differential function calculator

96...캐리 가산기 97...쉬프터96. Carry adder 97 ... Shifter

98...출력가산기 99...출력 버퍼98 ... Output adder 99 ... Output buffer

본 발명은 해쉬 함수 연산 엔진에 관한 것으로서, 더욱 상세하게는 알고리즘이 다른 복수의 해쉬 함수를 연산할 수 있는 하드웨어로 구현된 해쉬 함수 연산 엔진에 관한 것이다.The present invention relates to a hash function calculation engine, and more particularly, to a hash function calculation engine implemented in hardware capable of computing a plurality of different hash functions.

해쉬라는 개념은 하나의 문자열을 원래의 것을 상징하는 더 짧은 길이의 값이나 키로 변환하는 것을 말한다. 짧은 해쉬값을 사용하여 항목을 찾으면 원래의 값을 이용하여 찾는 것보다 더 빠르기 때문에 데이터베이스 내의 항목들을 검색하는 데 주로 사용되었으며 이러한 해쉬기술을 함수의 형태로 암호화 기술에 적용한 것이 해쉬 알고리즘이다.The idea of a hash is to convert a string into a shorter value or key that symbolizes the original. Finding an item using a short hash value is faster than using an original value to find an item. It is mainly used to search items in the database. The hash algorithm is applied to encryption technology as a function.

이러한, 해쉬 알고리즘은 전자 서명에 많이 사용되며, 대표적인 해쉬 알고리즘으로는 MD(message-digest)4, MD5, SHA(Secure Hash Algorithm)-1, RMD(RACE Integrity Primitives Evaluation message-digest)160, HAS(Hash Algorithm)등이 있다. 여기서, 해쉬 알고리즘은 대부분 MD4에 기반하여 설계되었으므로 구조가 유사하다.Such a hash algorithm is widely used for digital signatures, and typical hash algorithms include message-digest (MD) 4, MD5, Secure Hash Algorithm (SHA) -1, RACE Integrity Primitives Evaluation message-digest (RMD) 160, and HAS (HAS). Hash Algorithm). Here, since the hash algorithm is mostly designed based on MD4, the structure is similar.

한편, 일반적으로 함수를 연산하는 방법은 소프트웨어를 이용하여 구현하는 방법과 하드웨어를 이용하여 구현하는 방법이 있다. 소프트웨어를 이용하여 구현하는 경우 융통성이 뛰어나지만 연산 속도가 떨어지고, 안정성이 떨어진다. On the other hand, generally, a method of calculating a function includes a method implemented using software and a method implemented using hardware. When implemented using software, it is flexible, but computational speed is slow and stability is low.

따라서, 해쉬 함수 연산에는 도 1과 같은 하드웨어 엔진이 사용된다. 하드웨어로 구현된 해쉬 함수 연산 엔진은 입력 데이터를 임시 저장하는 입력 버퍼(1), 입력 버퍼(1)로부터 수신한 중간값을 이용하여 해쉬 함수 처리에 필요한 중간값을 생성하는 중간값 처리부(2) 및 해쉬 함수를 연산하는 함수 처리부(3)를 구비한다. 이러한, 상기 해쉬 함수 연산 엔진의 구조에서 서로 다른 해쉬 함수를 연산할 경우, 각각의 해쉬 함수 연산에 필요한 적어도 둘 이상의 해쉬 함수 연산 엔진이 요구된다. 또한, 서로 다른 알고리즘의 해쉬 함수에는 서로 다른 중간값이 입력된다. 따라서, 서로 다른 해쉬 함수를 연산하기 위해서는 각각의 해쉬 함수에 입력되는 중간값을 연산할 수 있는 적어도 둘 이상의 중간값 처리부가 구비된다.Therefore, the hardware engine shown in FIG. 1 is used for hash function calculation. The hash function calculation engine implemented in hardware includes an input buffer (1) for temporarily storing input data and an intermediate value processing unit (2) for generating an intermediate value for hash function processing using an intermediate value received from the input buffer (1). And a function processing unit 3 for calculating a hash function. In the case of computing different hash functions in the structure of the hash function calculation engine, at least two hash function calculation engines required for each hash function calculation are required. In addition, different intermediate values are input to hash functions of different algorithms. Accordingly, in order to calculate different hash functions, at least two intermediate value processing units capable of calculating intermediate values input to each hash function are provided.

도 2는 종래기술에 따른 서로 다른 해쉬 함수(SHA-1, HAS)를 연산하기 위하여 복수의 함수 처리부(310, 320)를 구비한 해쉬 함수 연산 엔진의 구성도이다. 도 2를 참조하면, 종래기술에 따라 두 개의 함수를 연산하기 위하여 구현되는 해쉬 함수 연산 엔진은 입력 버퍼(1), SHA-1 함수 처리부(310), SHA-1 중간값 처리부(210), HAS 함수 처리부(320) 및 HAS 중간값 처리부(210)를 구비한다.2 is a configuration diagram of a hash function calculation engine including a plurality of function processing units 310 and 320 to calculate different hash functions SHA-1 and HAS according to the related art. Referring to FIG. 2, a hash function calculation engine implemented to calculate two functions according to the prior art includes an input buffer 1, a SHA-1 function processor 310, a SHA-1 intermediate value processor 210, and a HAS. And a function processor 320 and a HAS median processor 210.

SHA-1 함수 처리부(310)는 SHA-1에 따른 함수를 처리하기 위하여 선택회로(311), 함수값 저장 블록(312), SHA-1 함수 연산부(313), 캐리 가산기(314), 출력 가산기(315) 및 출력 버퍼(316)를 구비하고, HAS 함수 처리부(320)는 HAS에 따른 함수를 처리하기 위하여 선택회로(321), 함수값 저장 블록(322), HAS 함수 연산부(323), 캐리 가산기(324), 출력 가산기(325) 및 출력 버퍼(326)를 구비한다.The SHA-1 function processor 310 performs a selection circuit 311, a function value storage block 312, a SHA-1 function operator 313, a carry adder 314, and an output adder to process a function according to SHA-1. 315 and an output buffer 316, the HAS function processor 320 includes a selection circuit 321, a function value storage block 322, a HAS function operator 323, and carry to process a function according to the HAS. An adder 324, an output adder 325, and an output buffer 326 are provided.

여기서, SHA-1 함수 연산부(313), HAS 함수 연산부(323), SHA-1 중간값 처리부(210) 및 HAS 중간값 처리부(220)를 제외한 다른 구성요소의 하드웨어적 구성은 동일하다. 즉, SHA-1 함수 처리부(310)의 선택회로(311)와 HAS 함수 처리부(320)의 선택회로(321), SHA-1 함수 처리부(310)의 함수값 저장 블록(312)과 HAS 함수 처리부(320)의 함수값 저장 블록(322), SHA-1 함수 처리부(310)의 캐리 가산기(314)와 HAS 함수 처리부(320)의 캐리 가산기(324), SHA-1 함수 처리부(310)의 출력 가산기(315)와 HAS 함수 처리부(320)의 출력 가산기(325) 및 SHA-1 함수 처리부(310)의 출력 버퍼(316)와 HAS 함수 처리부(320)의 출력 버퍼(326)를 구성하는 하드웨어는 서로 동일하다.Here, the hardware configuration of the other components except for the SHA-1 function calculator 313, the HAS function calculator 323, the SHA-1 intermediate value processor 210, and the HAS intermediate value processor 220 are the same. That is, the selection circuit 311 of the SHA-1 function processor 310 and the selection circuit 321 of the HAS function processor 320, the function value storage block 312 and the HAS function processor of the SHA-1 function processor 310. The function value storage block 322 of 320, the carry adder 314 of the SHA-1 function processor 310, the carry adder 324 of the HAS function processor 320, and the output of the SHA-1 function processor 310 The hardware constituting the adder 315, the output adder 325 of the HAS function processor 320, the output buffer 316 of the SHA-1 function processor 310, and the output buffer 326 of the HAS function processor 320 may be used. Same with each other.

따라서, 동일한 하드웨어를 각각의 함수 연산부(SHA-1 함수 연산부(313) 및 HAS 함수 연산부(323))에 마련함으로써, 데이터를 연산하는 하드웨어가 불필요하게 소모된다.Therefore, by providing the same hardware in each function calculating section (SHA-1 function calculating section 313 and HAS function calculating section 323), hardware for calculating data is unnecessarily consumed.

또한, SHA-1 중간값 처리부(210) 및 HAS 중간값 처리부(220)의 상세한 구성을 도시한 도 3을 참조하면, SHA-1 중간값 처리부(210)는 SHA-1 중간값 저장 블록(211), SHA-1 중간값 변수 연산부(212), SHA-1 중간값 선택 버퍼(213) 및 SHA-1 중간값 연산회로(214)를 구비하고, HAS 중간값 처리부(220)는 HAS 중간값 저장 블록(221), HAS 중간값 변수 연산부(222), HAS 중간값 선택 버퍼(223) 및 HAS 중간값 연산회로(224)를 구비한다. SHA-1 중간값 처리부(210)의 A블록과 HAS 중간값 처리부(220)의 C블록은 입력 버퍼에서 입력되는 16개의 동일한 데이터가 저장되는 블록이다. 따라서, 동일한 데이터를 각각 다른 공간의 저장 블록(A블록과 C블록)에 저장함으로써, 데이터를 저장하는 저장 블록이 불필요하게 소모된다.3 illustrates a detailed configuration of the SHA-1 intermediate value processing unit 210 and the HAS intermediate value processing unit 220, the SHA-1 intermediate value processing unit 210 may include a SHA-1 intermediate value storage block 211. ), A SHA-1 intermediate value variable calculation unit 212, a SHA-1 intermediate value selection buffer 213, and a SHA-1 intermediate value calculation circuit 214, and the HAS intermediate value processing unit 220 stores the HAS intermediate value. A block 221, a HAS intermediate value variable calculating unit 222, a HAS intermediate value selecting buffer 223, and a HAS intermediate value calculating circuit 224 are provided. The A block of the SHA-1 intermediate value processing unit 210 and the C block of the HAS intermediate value processing unit 220 are blocks in which 16 identical data input from the input buffer are stored. Therefore, by storing the same data in storage blocks (blocks A and C) of different spaces, storage blocks for storing data are unnecessarily consumed.

전술한 예에서와 같이 적어도 둘 이상의 함수의 알고리즘이 유사한 경우(예컨대, SHA-1 알고리즘과 HAS 알고리즘과 같은 경우), 다수의 동일한 회로가 구비됨으로써, 회로설계에 많은 전기소자의 낭비가 발생한다.If the algorithms of at least two or more functions are similar (eg, such as SHA-1 algorithm and HAS algorithm), as in the above example, a large number of identical circuits are provided, resulting in a waste of a lot of electrical elements in the circuit design.

또한, 함수 처리부에 불필요한 전기소자가 많이 구비됨에 따라 상기 전기소자들의 배치를 위한 설계에 많은 시간과 노력이 요구되고, 다수의 전기소자로 인해 하드웨어의 부피가 증가한다.In addition, as a large number of unnecessary electric elements are provided in the function processor, a lot of time and effort are required for designing the arrangement of the electric elements, and the volume of hardware increases due to the number of electric elements.

본 발명은 상기와 같은 문제점을 해결하기 위한 것으로 알고리즘이 다른 복수의 해쉬 함수 연산에 필요한 하드웨어 구성요소를 공유함으로써, 해쉬 함수 연산 엔진에 구비되는 전기소자의 양을 줄이고, 소형의 해쉬 함수 연산 엔진을 제공하는데 그 목적이 있다. The present invention is to solve the above problems, the algorithm is to share the hardware components necessary for a plurality of different hash function calculation, reducing the amount of electrical elements provided in the hash function calculation engine, and a small hash function calculation engine The purpose is to provide.

상기와 같은 목적을 달성하기 위하여 본 발명의 일 측면에 따른 해쉬 함수 연산을 위한 공통엔진은, 입력되는 데이터를 소정의 비트 단위로 블록을 생성하여 저장하는 입력 버퍼; 알고리즘이 서로 다른 적어도 둘 이상의 해쉬 함수 연산에 필요한 중간값 중에서 공통되는 중간값을 공유하고, 상기 해쉬 함수 연산에 필요한 중간값 변수를 생성하는 중간값 처리부; 및 상기 중간값을 이용하여 상기 해쉬 함수를 연산하는 함수 처리부;를 구비한다.In order to achieve the above object, a common engine for a hash function operation according to an aspect of the present invention, an input buffer for generating and storing a block of the input data in a predetermined bit unit; An intermediate value processing unit for generating an intermediate value variable for the hash function operation and sharing a common intermediate value among intermediate values required for at least two different hash function operations different from each other; And a function processor for calculating the hash function using the intermediate value.

바람직하게, 상기 함수 처리부는 알고리즘이 서로 다른 적어도 둘 이상의 해쉬 함수에서 공통되는 연산자를 공유하여 함수를 연산할 수 있다.Preferably, the function processing unit may operate a function by sharing operators common to at least two or more hash functions having different algorithms.

본 발명의 다른 측면에 따른 해쉬 함수 연산을 위한 공통엔진은, 입력되는 데이터를 소정의 비트 단위로 블록을 생성하여 저장하는 입력 버퍼; 알고리즘이 서로 다른 적어도 둘 이상의 해쉬 함수 연산에 필요한 중간값 변수를 생성하고 저장하는 중간값 처리부; 및 알고리즘이 서로 다른 적어도 둘 이상의 해쉬 함수에서 공통되는 연산자를 공유하여 해쉬 함수를 연산하는 함수 처리부;를 구비한다.In accordance with another aspect of the present invention, a common engine for a hash function calculation may include: an input buffer configured to generate and store blocks of input data in predetermined bit units; An intermediate value processing unit for generating and storing intermediate value variables required for at least two hash function operations different from each other; And a function processing unit that calculates a hash function by sharing operators common to at least two hash functions having different algorithms.

바람직하게, 상기 중간값 처리부는 알고리즘이 서로 다른 적어도 둘 이상의 해쉬 함수에서 공통되는 중간값을 공유할 수 있다.Preferably, the median processing unit may share a median common between at least two hash functions with different algorithms.

이하, 첨부된 도면을 참조하여 본 발명의 바람직한 실시예를 상세히 설명하기로 한다. 이에 앞서, 본 명세서 및 청구범위에 사용된 용어나 단어는 통상적이거 나 사전적인 의미로 한정해서 해석되어서는 아니되며, 발명자는 그 자신의 발명을 가장 최선의 방법으로 설명하기 위해 용어의 개념을 적절하게 정의할 수 있다는 원칙에 입각하여 본 발명의 기술적 사상에 부합하는 의미와 개념으로 해석되어야만 한다. 따라서, 본 명세서에 기재된 실시예와 도면에 도시된 구성은 본 발명의 가장 바람직한 일 실시예에 불과할 뿐이고 본 발명의 기술적 사상을 모두 대변하는 것은 아니므로, 본 출원시점에 있어서 이들을 대체할 수 있는 다양한 균등물과 변형예들이 있을 수 있음을 이해하여야 한다. 각 도면에 도시된 참조부호 중 동일한 참조부호는 동일한 부재를 나타낸다.Hereinafter, exemplary embodiments of the present invention will be described in detail with reference to the accompanying drawings. Prior to this, the terms or words used in this specification and claims should not be construed as having a conventional or dictionary meaning, and the inventors should properly introduce the concept of terms in order to best explain their invention. It should be interpreted as meanings and concepts in accordance with the technical spirit of the present invention based on the principle that it can be defined. Therefore, the embodiments described in the specification and the drawings shown in the drawings are only the most preferred embodiment of the present invention and do not represent all of the technical idea of the present invention, various modifications that can be replaced at the time of the present application It should be understood that there may be equivalents and variations. The same reference numerals among the reference numerals shown in each drawing represent the same members.

도 4는 본 발명의 일 실시예에 따른 함수 연산 엔진의 구성도이다. 본 발명의 일 실시예에서는 알고리즘이 서로 유사한 해쉬 함수(SHA-1, HAS)를 연산하기 위하여 동일한 중간값을 저장하는 저장블록을 공유하는 중간값 처리부를 포함하는 함수 연산 엔진을 예시한다. 4 is a block diagram of a function calculation engine according to an embodiment of the present invention. In one embodiment of the present invention, the algorithm illustrates a function calculation engine including an intermediate value processing unit that shares a storage block storing the same intermediate value in order to calculate similar hash functions SHA-1 and HAS.

도 4를 참조하면, 본 발명의 일 실시예에 따른 함수 연산 엔진은 입력 버퍼(7), 중간값 처리부(40) 및 함수 처리부(50)를 구비한다.Referring to FIG. 4, the function calculation engine according to an exemplary embodiment of the present invention includes an input buffer 7, an intermediate value processor 40, and a function processor 50.

입력 버퍼(7)는 중간값 생성에 필요한 512비트의 패딩(padding)된 데이터와 SHA-1 함수와 HAS 함수를 처리하기 위한 160비트의 초기값을 저장한다.The input buffer 7 stores 512 bits of padded data for generating intermediate values and an initial value of 160 bits for processing the SHA-1 function and the HAS function.

중간값 처리부(40)는 함수연산에 필요한 중간값(Wn)을 연산하여 함수처리부(50)로 전송하기 위하여 저장 블록(41), 중간값 변수 연산부(42), SHA-1 선택 버퍼(43), SHA-1 중간값 연산회로(44), HAS 선택 버퍼(45) 및 HAS 중간값 연산회로(46)를 구비한다.The intermediate value processing unit 40 stores the storage block 41, the intermediate value variable calculating unit 42, and the SHA-1 selection buffer 43 to calculate the intermediate value Wn necessary for the function operation and transmit the intermediate value Wn to the function processing unit 50. And the SHA-1 intermediate value calculating circuit 44, the HAS selection buffer 45, and the HAS intermediate value calculating circuit 46.

저장 블록(41)은 입력 버퍼(7)로부터 전송받은 16개의 중간값(Wn)과 SHA-1 중간값 연산회로(44) 및 HAS 중간값 연산회로(46)가 연산하여 전송하는 중간값(Wn)을 저장한다. 공통블록에는 입력 버퍼(7)로부터 전송받은 16개의 중간값(Wn)이 저장되고, SHA-1 블록에는 SHA-1 중간값 연산회로(44)로부터 수신하는 중간값(Wn)이 저장되고, HAS 블록에는 HAS 중간값 연산회로(46)로부터 수신한 중간값(Wn)이 저장된다.The storage block 41 stores 16 intermediate values Wn received from the input buffer 7 and intermediate values Wn calculated and transmitted by the SHA-1 intermediate value calculating circuit 44 and the HAS intermediate value calculating circuit 46. Save). Sixteen intermediate values Wn received from the input buffer 7 are stored in the common block, and intermediate values Wn received from the SHA-1 intermediate value calculation circuit 44 are stored in the SHA-1 block, and HAS The block stores the intermediate value Wn received from the HAS intermediate value calculating circuit 46.

중간값 변수 연산부(42)는 n번째 단계의 함수를 처리하는데 필요한 중간값 계산에 요구되는 중간값 변수(Wn')를 연산하여 SHA-1 선택 버퍼(43) 및 HAS 선택 버퍼(45)로 전송한다.The intermediate value variable calculating section 42 calculates the intermediate value variable Wn 'required for calculating the intermediate value required to process the function of the nth step and transmits it to the SHA-1 selection buffer 43 and the HAS selection buffer 45. do.

한편, 알고리즘이 다른 함수는 동일한 단계에서 서로 다른 중간값(Wn)을 요구하므로, 이에 대한 중간값 변수(Wn')를 각각의 알고리즘에 적용하여 연산한다. 따라서, 동일한 단계에서 SHA-1 선택 버퍼(43) 및 HAS 선택 버퍼(45)로 전송되는 중간값 변수(Wn')는 서로 다를 수 있다.On the other hand, since functions with different algorithms require different median values Wn at the same step, the median variable Wn 'is applied to each algorithm. Therefore, in the same step, the median variable Wn 'transmitted to the SHA-1 selection buffer 43 and the HAS selection buffer 45 may be different.

SHA-1 선택 버퍼(43)는 중간값 변수 연산부(42)로부터 n번째 단계의 SHA-1 함수를 처리하는데 필요한 중간값 변수(Wn')를 수신하고, 상기 변수(Wn')에 대응하는 중간값(Wn)을 저장 블록(41)으로부터 추출하여 SHA-1 중간값 연산회로(44)로 전송한다.The SHA-1 selection buffer 43 receives the intermediate value variable Wn 'necessary for processing the SHA-1 function of the nth step from the intermediate value variable calculating section 42, and the intermediate value corresponding to the variable Wn' is received. The value Wn is extracted from the storage block 41 and sent to the SHA-1 intermediate value computing circuit 44.

SHA-1 중간값 연산회로(44)는 SHA-1 선택 버퍼(43)로부터 전송받은 중간값 변수(Wn')를 소정의 중간값 연산식에 적용하여 중간값(Wn)을 생성하고, 상기 생성된 중간값(Wn)을 n번째 단계에 대응하는 블록에 저장한다.The SHA-1 intermediate value calculating circuit 44 applies the intermediate value variable Wn 'received from the SHA-1 selection buffer 43 to a predetermined intermediate value formula to generate the intermediate value Wn. The intermediate value Wn is stored in the block corresponding to the nth step.

HAS 선택 버퍼(45)는 중간값 변수 연산부(42)로부터 n번째 단계의 HAS 함수를 처리하는데 필요한 중간값 변수(Wn')를 수신하고, 상기 변수(Wn')에 대응하는 중간값(Wn)을 저장 블록(41)으로부터 추출하여 HAS 중간값 연산회로(46)로 전송한다.The HAS selection buffer 45 receives the intermediate value variable Wn 'necessary for processing the HAS function of the nth step from the intermediate value variable calculating section 42, and the intermediate value Wn corresponding to the variable Wn'. Is extracted from the storage block 41 and transmitted to the HAS intermediate value calculating circuit 46.

여기서, SHA-1 함수 연산은 총 80단계로 구성되며, 80단계의 연산을 수행하기 위하여 입력 버퍼(1)로부터 수신한 16개의 중간값(Wn)과 SHA-1 중간값 연산회로(84)로부터 생성되는 64개의 중간값(Wn)을 합쳐 총 80개의 중간값(Wn)을 필요로 한다. 따라서, 전체 80단계 중 1~16단계의 함수연산에 필요한 중간값(Wn)은 입력 버퍼(7)에서 입력된 512비트를 32비트로 나누어 생성되는 16개의 데이터를 사용하고, 17단계부터 80단계의 함수연산에 필요한 중간값(Wn)은 수학식 1에 따라 연산하여 생성되는 64개의 데이터를 사용한다. 따라서, SHA-1 중간값 연산회로(44)는 수학식 1을 연산하는 회로를 구비하며, SHA-1 중간값 변수 연산부(42)는 중간값 연산에 필요한 변수((n-3), (n-8), (n-14), (n-16))를 연산하는 회로를 구비한다.Here, the SHA-1 function calculation is composed of a total of 80 steps, from the 16 intermediate values Wn received from the input buffer 1 and the SHA-1 intermediate value calculation circuit 84 to perform the 80 steps of operations. A total of 64 median values (Wn) generated are required for a total of 80 median values (Wn). Therefore, the intermediate value (Wn) required for the function calculation of steps 1 to 16 of the 80 steps uses 16 data generated by dividing the 512 bits inputted from the input buffer 7 into 32 bits. The intermediate value Wn required for the function calculation uses 64 data generated by calculating according to Equation (1). Accordingly, the SHA-1 intermediate value calculating circuit 44 includes a circuit for calculating Equation 1, and the SHA-1 intermediate value calculating unit 42 includes variables ((n-3) and (n -8), (n-14), and (n-16)).

Wn=ROLT(W(n-3) XOR W(n-8) XOR W(n-14) XOR W(n-13)) (16≤n≤79, n=단계)Wn = ROLT (W (n-3) XOR W (n-8) XOR W (n-14) XOR W (n-13)) (16≤n≤79, n = step)

(ROLT는 1비트 서큘러 레프트 쉬프트 연산, XOR은 비트의 배타 논리합)(ROLT is 1 bit circular left shift operation, XOR is exclusive OR of bits)

HAS 선택 버퍼(45)는 중간값 변수 연산부(42)로부터 n번째 단계의 HAS 함수를 처리하는데 필요한 중간값 변수(Wn')를 수신하고, 상기 변수(Wn')에 대응하는 중간값(Wn)을 저장 블록(41)으로부터 추출하여 HAS 중간값 연산회로(46)로 전송한다.The HAS selection buffer 45 receives the intermediate value variable Wn 'necessary for processing the HAS function of the nth step from the intermediate value variable calculating section 42, and the intermediate value Wn corresponding to the variable Wn'. Is extracted from the storage block 41 and transmitted to the HAS intermediate value calculating circuit 46.

HAS 중간값 연산회로(46)는 HAS 선택 버퍼(45)로부터 전송받은 중간값 변수(Wn')를 소정의 중간값 연산식에 적용하여 중간값(Wn)을 생성하고, 상기 생성된 중간값(Wn)을 n번째 단계에 대응하는 블록에 저장한다.The HAS intermediate value calculating circuit 46 applies the intermediate value variable Wn 'received from the HAS selection buffer 45 to a predetermined intermediate value formula to generate the intermediate value Wn, and generates the intermediate value Wn. Wn) is stored in the block corresponding to the nth step.

HAS 함수 연산은 20단계를 4번 반복하여 총 80단계로 구성되며, 20단계의 연산을 수행하기 위하여 입력 버퍼(1)로부터 수신한 16개와 HAS 중간값 연산회로(46)로부터 생성되는 4개를 합쳐 총 20개의 중간값(Wn)을 필요로 한다. 따라서, HAS 중간값 연산회로(46)는 수학식 2를 연산하는 회로를 구비하며, 중간값 변수 연산부(42)는 중간값 연산에 필요한 변수(Wn')를 수학식 2에 기초하여 선택한다.HAS function calculation consists of 80 steps by repeating 20 steps 4 times, and 16 received from input buffer 1 and 4 generated from HAS intermediate value calculation circuit 46 to perform 20 steps of operations. In total, a total of 20 median values (Wn) are required. Therefore, the HAS intermediate value calculating circuit 46 includes a circuit for calculating the equation (2), and the intermediate value variable calculating section 42 selects the variable Wn 'necessary for the intermediate value calculation based on the equation (2).

W16=W3 XOR W6 XOR W9 XOR W12W16 = W3 XOR W6 XOR W9 XOR W12

W17=W15 XOR W2 XOR W5 XOR W8W17 = W15 XOR W2 XOR W5 XOR W8

W18=W11 XOR W14 XOR W1 XOR W4W18 = W11 XOR W14 XOR W1 XOR W4

W19=W7 XOR W10 XOR W13 XOR W0W19 = W7 XOR W10 XOR W13 XOR W0

따라서, 저장 블록(41)의 공통블록에는 입력 버퍼(1)로부터 전송받은 16개의 중간값(Wn)을 저장하기 위한 16개의 블록이 구비되고, SHA-1 블록에는 SHA-1 중간값 연산회로(44)로부터 수신하는 64개의 중간값(Wn)을 저장하기 위한 64개의 블록이 구비된다. 또한, HAS 블록에는 HAS 중간값 연산회로(46)로부터 수신하는 4개의 중간값(Wn)을 저장하기 위한 4개의 블록이 구비된다.Therefore, the common block of the storage block 41 is provided with 16 blocks for storing 16 intermediate values Wn received from the input buffer 1, and the SHA-1 block includes the SHA-1 intermediate value calculation circuit ( 64 blocks for storing 64 intermediate values Wn received from 44 are provided. In addition, the HAS block is provided with four blocks for storing four intermediate values Wn received from the HAS intermediate value calculating circuit 46.

함수 처리부(50)는 저장 블록(41)으로부터 중간값을 수신하여 SHA-1 함수 또는 HAS 함수에 적용하고, 함수에 상응하는 연산을 통해 결과값을 출력한다.The function processing unit 50 receives the intermediate value from the storage block 41 and applies it to the SHA-1 function or the HAS function, and outputs a result value through an operation corresponding to the function.

여기서, SHA-1은 80단계를 4라운드로 나누어 각각의 라운드는 20단계로 설정하고, 각 단계는 표 1의 함수와 상수에 기초하여 연산된다. HAS 알고리즘도 SHA-1 알고리즘에서와 같이 80단계를 4라운드로 나누며, 각각의 라운드는 20단계로 구성된다. 각 단계는 표 2의 함수와 상수에 기초하여 연산된다.Here, SHA-1 divides 80 steps into 4 rounds and sets each round to 20 steps, and each step is calculated based on the functions and constants of Table 1. As in the SHA-1 algorithm, the HAS algorithm divides 80 steps into four rounds, and each round consists of 20 steps. Each step is calculated based on the functions and constants in Table 2.

라운드round 단계step 함수function 상수a constant 1One 0≤n≤19 0≤n≤19 F0(B,C,D)=(B and C) or (!B and D)F0 (B, C, D) = (B and C) or (! B and D) K0=00000000K0 = 00000000 22 20≤n≤3920≤n≤39 F1(B,C,D)=B XOR C XOR DF1 (B, C, D) = B XOR C XOR D K1=5a827999K1 = 5a827999 33 40≤n≤5940≤n≤59 F2(B,C,D)=C XOR (B or !Z)F2 (B, C, D) = C XOR (B or! Z) K2=6ed9eba1K2 = 6ed9eba1 44 60≤n≤7960≤n≤79 F3(B,C,D)=B XOR C XOR DF3 (B, C, D) = B XOR C XOR D k3=8f1bbcdck3 = 8f1bbcdc

라운드round 단계step 함수function 상수a constant 1One 0≤n≤19 0≤n≤19 F0(B,C,D)=(B and C) or (!B and D)F0 (B, C, D) = (B and C) or (! B and D) K0=5a827999K0 = 5a827999 22 20≤n≤3920≤n≤39 F1(B,C,D)=B XOR C XOR DF1 (B, C, D) = B XOR C XOR D K1=6ed9eba1K1 = 6ed9eba1 33 40≤n≤5940≤n≤59 F2(B,C,D)=(B and C) or (B and D) or (C and D)F2 (B, C, D) = (B and C) or (B and D) or (C and D) K2=8f1bbcdcK2 = 8f1bbcdc 44 60≤n≤7960≤n≤79 F3(B,C,D)=B XOR C XOR DF3 (B, C, D) = B XOR C XOR D K3=ca62c1d6K3 = ca62c1d6

SHA-1 알고리즘과 HAS 알고리즘은 함수의 구조가 동일하고, 알고리즘에 사용되는 함수는 3라운드를 제외한 나머지(1, 2, 4라운드) 함수(F0(B,C,D), F1(B,C,D), F3(B,C,D))는 모두 동일하다. 따라서, 함수 처리부(50)가 상기 두 함수(SHA-1, HAS)를 처리함에 있어서, 상기 두 함수에서 1, 2, 4라운드에 공통으로 사용되는 연산자를 공유하는 것이 바람직하다.The SHA-1 algorithm and the HAS algorithm have the same structure, and the functions used in the algorithm are the functions (F0 (B, C, D), F1 (B, C) except the third round (1, 2, 4 rounds). , D) and F3 (B, C, D)) are all the same. Therefore, when the function processing unit 50 processes the two functions SHA-1 and HAS, it is preferable to share the operators commonly used in the first, second and fourth rounds of the two functions.

도 5는 본 발명의 다른 실시예에 따른 함수 연산 엔진의 구성도이다. 본 발명의 다른 실시예에서는 알고리즘이 서로 유사한 해쉬 함수(SHA-1, HAS)의 연산에 있어서, 공통으로 사용되는 연산자를 공유하여 상기 두 함수(SHA-1, HAS)를 연산하는 함수 처리부(70)를 포함하는 함수 연산 엔진을 예시한다. 도 5를 참조하면, 본 발명의 다른 실시예에 따른 함수 연산 엔진은 입력 버퍼(7), 중간값 처리부(60) 및 함수 처리부(70)를 구비한다.5 is a configuration diagram of a function calculation engine according to another embodiment of the present invention. In another embodiment of the present invention, in the calculation of hash functions SHA-1 and HAS similar to each other, a function processor 70 for calculating the two functions SHA-1 and HAS by sharing operators commonly used. An example of a function calculation engine is included. Referring to FIG. 5, the function calculation engine according to another embodiment of the present invention includes an input buffer 7, an intermediate value processor 60, and a function processor 70.

입력 버퍼(7)는 중간값 생성에 필요한 512비트의 패딩(padding)된 데이터와 SHA-1 함수와 HAS 함수를 처리하기 위한 160비트의 초기값을 저장한다.The input buffer 7 stores 512 bits of padded data for generating intermediate values and an initial value of 160 bits for processing the SHA-1 function and the HAS function.

중간값 처리부(60)는 수학식 1 및 수학식 2에 기초하여 SHA-1함수와 HAS함수 연산에 필요한 중간값을 각각 연산하여 함수처리부(70)로 전송한다.The intermediate value processor 60 calculates the intermediate values required for the SHA-1 function and the HAS function based on Equation 1 and Equation 2, and transmits the intermediate values to the function processor 70.

중간값 처리부(60)는 알고리즘이 서로 유사한 해쉬 함수(SHA-1, HAS)에서 공통되는 중간값(Wn)을 저장하는 저장영역을 공유할 수 있도록 구비되는 것이 바람직하다. 비록 본 발명의 실시예에서 중간값 처리부(60)는 적어도 둘 이상의 함수에서 공통되는 중간값(Wn)을 저장하는 저장영역을 공유하는 것을 예시하였으나, 본 발명에서 이를 한정하는 것은 아니며, 예컨대, 함수 처리에 필요한 중간값(Wn)을 연산하고, 저장할 수 있는 통상의 회로가 될 수도 있다.The intermediate value processing unit 60 is preferably provided so that the algorithm can share a storage area for storing the intermediate value Wn common in the hash functions SHA-1 and HAS similar to each other. Although the median processing unit 60 in the embodiment of the present invention illustrates sharing a storage area for storing the median value Wn common to at least two or more functions, the present invention is not limited thereto. It may be a conventional circuit which can calculate and store the intermediate value Wn necessary for processing.

함수 처리부(70)는 초기값과 중간값을 정해진 함수 연산회로에 적용하여 함수값을 연산한다. 함수처리부(70)는 알고리즘이 다른 복수의 함수를 연산하기 위하여 선택회로(71), 함수값 저장 블록(72), 함수 선택부(73), 공통함수 연산부(74), 차등함수 연산부(75), 캐리 가산기(76), 출력 가산기(77) 및 출력 버퍼(78)를 구비한다.The function processor 70 calculates a function value by applying the initial value and the intermediate value to a predetermined function calculation circuit. The function processing unit 70 includes a selection circuit 71, a function value storage block 72, a function selection unit 73, a common function operation unit 74, and a differential function operation unit 75 to calculate a plurality of functions having different algorithms. And a carry adder 76, an output adder 77, and an output buffer 78.

선택회로(71)는 함수 연산의 반복에 따른 제어신호를 수신하여 이에 대응하는 신호를 선택하여 함수값 저장 블록(72)으로 전송한다. The selection circuit 71 receives the control signal according to the repetition of the function operation, selects a signal corresponding thereto, and transmits the selected signal to the function value storage block 72.

함수값 저장 블록(72)은 초기값과 함수 연산의 반복에 따라 생성되는 함수값을 32비트로 블록화하여 저장한다.The function value storage block 72 blocks and stores the function value generated according to the repetition of the initial value and the function operation in 32 bits.

공통함수 연산부(74)는 함수값 저장 블록(72)에 32비트로 블록화되어 저장되는 함수값에서 SHA-1함수와 HAS 함수에서 공통되는 1, 2, 4라운드의 연산을 수행하는 함수에 적용한다.The common function calculating unit 74 is applied to a function that performs operations of 1, 2, and 4 rounds that are common to the SHA-1 function and the HAS function in a function value which is blocked and stored in 32 bits in the function value storage block 72.

차등함수 연산부(75)는 SHA-1 함수 연산부(751)와 HAS 함수 연산부(752)를 구비하며, 상기 두 함수(SHA-1 함수, HAS 함수)의 연산에 있어서, 서로 다른 부분의 연산을 처리한다. 즉, SHA-1 함수 연산부(751)는 상기 표 1에 나타난 3라운드의 연산을 처리하고, HAS 함수 연산부(752)는 상기 표 2에 나타난 3라운드의 연산을 처리한다.The differential function calculating unit 75 includes a SHA-1 function calculating unit 751 and a HAS function calculating unit 752, and processes operations of different parts in the operation of the two functions (SHA-1 function, HAS function). do. That is, the SHA-1 function operator 751 processes the three round operations shown in Table 1, and the HAS function operator 752 processes the three round operations shown in Table 2.

캐리 가산기(76)는 중간값 처리부로부터 수신하는 중간값(Wn), 공통함수 연산부(74) 또는 차등함수 연산부(75)에서 연산된 함수값 및 함수값 저장 블록(72)에 저장되는 데이터를 수신하여 SHA-1 함수 또는 HAS 함수에 적용하여 가산하고, 가산된 데이터는 선택회로(71)로 전송된다.The carry adder 76 receives the intermediate value Wn received from the intermediate value processing unit, the function value calculated by the common function calculating unit 74 or the differential function calculating unit 75 and the data stored in the function value storing block 72. The data is added to the SHA-1 function or the HAS function, and the added data is transmitted to the selection circuit 71.

출력가산기(77)는 입력 버퍼(7)에서 소정의 비트로 블록화된 초기값에 함수값 저장 블록(72)에 저장되는 블록화된 함수값을 가산하여 출력 버퍼(78)로 전송하고, 출력 버퍼(78)는 출력가산기(77)의 출력신호를 버퍼링한다.The output adder 77 adds the blocked function value stored in the function value storage block 72 to the initial value blocked by the predetermined bit in the input buffer 7 and transmits it to the output buffer 78, and output buffer 78 ) Buffers the output signal of the output adder 77.

이하, 도 6을 참조하여 본 발명의 일 실시예에 따른 해쉬 함수 연산 엔진의 작동을 SHA-1 함수 연산을 중심으로 설명한다.Hereinafter, the operation of the hash function calculation engine according to an embodiment of the present invention will be described with reference to SHA-1 function calculation.

입력 버퍼(7)는 512비트로 패딩(padding)된 데이터를 32비트씩 분할하여 16개의 중간값을 생성하여 저장 블록(81)의 공통블록에 저장한다. The input buffer 7 divides the padded data into 512 bits by 32 bits to generate 16 intermediate values, and stores the intermediate values in the common block of the storage block 81.

중간값 변수 연산부(82)는 SHA-1 함수 연산 처리 신호를 수신하여 SHA-1 함수에 대응하는 중간값 변수(Wn')를 연산한다. 0~15단계의 중간값은 공통블록에 저장된 16개의 중간값(Wn)을 사용하므로 중간값 연산은 16단계의 중간값(W16) ~ 79단계의 중간값(W79)의 연산에 필요한 중간값 변수(Wn'; (n-3), (n-8), (n-14), (n-16))를 차례대로 연산한다. The median variable calculator 82 receives the SHA-1 function calculation processing signal and calculates the median variable Wn 'corresponding to the SHA-1 function. Since the intermediate values in steps 0 to 15 use 16 intermediate values (Wn) stored in the common block, the intermediate value calculation is required for the intermediate value calculation for the intermediate values (W16) in steps 16 to 79 (W79). Calculate (Wn '; (n-3), (n-8), (n-14), (n-16)) in that order.

중간값 변수 연산부(82)에서 연산된 중간값 변수(Wn')는 SHA-1 중간값 선택버퍼(83)로 전송되고, 이를 수신한 중간값 선택버퍼(83)는 저장블록(81)으로부터 상기 중간값 변수(Wn')에 대응하는 중간값(Wn)을 추출하여 저장한다. SHA-1 중간값 선택버퍼(83)에 저장된 중간값(Wn)은 SHA-1 중간값 연산회로(84)로 전송되어 상기 수학식 1에 상응하는 연산회로를 통해 연산 처리된다. 연산 처리된 중간값(Wn)은 저장블록(81)의 SHA-1블록으로 저장된다.The intermediate value variable Wn 'calculated by the intermediate value variable calculating unit 82 is transmitted to the SHA-1 intermediate value selection buffer 83, and the intermediate value selection buffer 83 receives the intermediate value selection buffer 83 from the storage block 81. The median value Wn corresponding to the median variable Wn 'is extracted and stored. The intermediate value Wn stored in the SHA-1 intermediate value selection buffer 83 is transmitted to the SHA-1 intermediate value calculation circuit 84 and processed by the calculation circuit corresponding to Equation 1 above. The calculated intermediate value Wn is stored in the SHA-1 block of the storage block 81.

예컨대, 16단계의 중간값(W16)을 연산하기 위해서는 (n-3), (n-8), (n-14), (n-16)의 변수가 필요하므로 중간값 변수 연산부(82)는 n=16을 대입하여 13, 12, 2, 3을 연산한다. 연산된 중간값 변수(W16'; 13, 12, 2, 0)는 중간값 선택버퍼(83)로 전송되고, 중간값 선택버퍼(83)는 저장블록(81) 내의 공통블록의 W13, W12, W2, W3을 추출하여 임시 저장한다. W13, W12, W2, W3은 SHA-1 중간값 연산회로(84)에 전송되어 수학식 1의 연산을 통해 16번째 중간값(W16)을 생성하고, 생성된 16번째 중간값(W16)은 저장블록(81)의 SHA-1블록에 저장된다.For example, in order to calculate the intermediate value W16 in step 16, the variables of (n-3), (n-8), (n-14), and (n-16) are required. Calculate 13, 12, 2, 3 by substituting n = 16. The calculated intermediate value variable W16 '13, 12, 2, 0 is transferred to the intermediate value selection buffer 83, and the intermediate value selection buffer 83 is W13, W12, of the common block in the storage block 81; Extract W2 and W3 and temporarily store them. W13, W12, W2, and W3 are transmitted to the SHA-1 intermediate value calculating circuit 84 to generate the 16th intermediate value W16 through the operation of Equation 1, and the generated 16th intermediate value W16 is stored. It is stored in the SHA-1 block of the block 81.

중간값 연산에 있어서, 중간값 변수 연산부(82)가 HAS 함수 연산 처리 신호를 수신하는 경우를 살펴보면, 0~15단계의 중간값(Wn)은 공통블록에 저장된 16개의 중간값(Wn)을 공통으로 사용하므로 HAS 함수 연산에 필요한 중간값은 16단계의 중간값(W16) ~ 19단계의 중간값(W19)이 필요하다. HAS 함수의 경우 4개의 중간값(Wn)만을 생성하면 되므로 중간값 변수 연산부(82)는 중간값 연산에 필요한 중간값 변수(Wn')의 연산을 수행하지 않고, 각 단계에 대응하는 중간값 연산에 필요한 중간값 변수를 저장한다. 따라서, 중간값 변수 연산부(82)가 각 단계에 대응하는 중간값(Wn) 연산에 필요한 중간값 변수(Wn')를 선택하여 HAS 중간값 선택버퍼(85)에 전송하고, HAS 중간값 선택버퍼(85)는 상기 중간값 변수(Wn)에 대응하는 중간값을 저장한다. HAS 중간값 연산회로(86)는 HAS 중간값 선택버퍼(85)에 저장된 중간값(Wn)을 상기 수학식 2에 대응하는 연산회로를 통해 중간값(Wn)을 생성하여 저장블록(81)의 HAS 블록에 저장한다. In the intermediate value calculation, when the intermediate value variable calculation unit 82 receives a HAS function calculation processing signal, the intermediate value Wn in steps 0 to 15 is common to 16 intermediate values Wn stored in the common block. Therefore, the median value required for HAS function calculation requires the median value of 16 steps (W16) to the median value of 19 steps (W19). In the case of the HAS function, since only four intermediate values Wn need to be generated, the intermediate value variable calculating unit 82 does not perform the operation of the intermediate value variable Wn 'necessary for the intermediate value operation, and calculates the intermediate value corresponding to each step. Save the median variables needed for. Therefore, the intermediate value variable calculating unit 82 selects the intermediate value variable Wn 'necessary for the intermediate value Wn operation corresponding to each step, and transmits the intermediate value variable Wn' to the HAS intermediate value selection buffer 85 and the HAS intermediate value selection buffer. 85 stores an intermediate value corresponding to the intermediate value Wn. The HAS intermediate value calculation circuit 86 generates the intermediate value Wn from the intermediate value Wn stored in the HAS intermediate value selection buffer 85 through a calculation circuit corresponding to Equation 2 above to generate the intermediate value Wn of the storage block 81. Store in HAS block.

한편, 입력 버퍼(7)에 32비트씩 5개로 분할된 160비트의 초기값은 선택회로(91)로 전송되고, 선택회로(91)는 함수 연산 처리 신호를 수신하여 초기값을 함수값 저장 블록(92)으로 전송한다. 이때, 초기값은 5개의 블록(A, B, C, D, E)으로 분할되어 저장된다. 5개의 블록으로 나뉘어 저장된 초기값 중 함수 연산에 필요한 B, C, D블록의 초기값은 공통함수 연산부(94) 및 차등 함수 연산부(95)로 전송된다. 함수 선택부(93)는 SHA-1 함수 또는 HAS 함수 연산의 단계를 확인하고, 이에 대응하는 함수 연산 신호를 전송한다. SHA-1 함수의 초기값을 수신하여 연산하는 단계를 예시하고 있으므로 함수의 연산은 SHA-1 함수의 0번째 단계이다. SHA-1 함수와 HAS 함수는 3라운드의 단계를 제외하고 모두 동일한 함수를 사용하여 연산하므로 함수 선택부(93)는 공통함수 연산부(94)에 작동신호를 전송한다. 이에 따라, 공통함수 연산부(94)는 표 1의 F0(B,C,D)에 대응하는 연산을 수행하고, 연산 결과를 출력한다.On the other hand, the 160-bit initial value divided into five 32-bits in the input buffer 7 is transmitted to the selection circuit 91, and the selection circuit 91 receives a function calculation processing signal and converts the initial value to a function value storage block. Transmit to 92. At this time, the initial value is divided into five blocks (A, B, C, D, E) and stored. The initial values of the B, C, and D blocks required for the function calculation among the initial values divided into five blocks are transmitted to the common function calculator 94 and the differential function calculator 95. The function selector 93 checks the steps of the SHA-1 function or the HAS function operation and transmits a function operation signal corresponding thereto. The operation of the function is the 0th step of the SHA-1 function because it illustrates the operation of receiving the initial value of the SHA-1 function. Since both the SHA-1 function and the HAS function operate using the same function except for the third round, the function selector 93 transmits an operation signal to the common function operator 94. Accordingly, the common function calculating unit 94 performs an operation corresponding to F0 (B, C, D) in Table 1, and outputs an operation result.

한편, 제 1쉬프터(971)는 함수값 저장블록(92)의 A블록에 저장된 데이터를 5비트 서큘러 레프트(circular left) 연산하여 제 1캐리 가산기(961)로 전송한다. 제 1캐리 가산기는 공통함수 연산부(94)로부터 수신한 데이터에 제 1쉬프터(971)로부터 수신한 데이터를 가산하여 제 2캐리 가산기(962)로 전송한다. 제 2캐리 가산기(962)는 제 1캐리 가산기(961)로부터 수신한 데이터에 함수값 저장블록(92)의 E블록으로부터 수신한 데이터를 가산하여 제 3캐리 가산기(963)로 전송한다. 제 3캐리 가산기(963)는 제 2캐리 가산기(962)로부터 수신한 데이터에 중간값 저장블록(81)의 0번째 중간값을 수신하여 가산하고, 결과값을 제 4캐리 가산기(964)로 전송한다. 제 4캐리 가산기(964)는 제 3캐리 가산기(963)로부터 수신한 데이터에 상기 표 1의 상수값이 저장된 상수블록(966)으로부터 K0값을 수신하여 가산하고, 그 결과를 캐리 전달 가산기(965)로 전송한다. 캐리 전달 가산기(965)는 제 4캐리 가산기(964)로부터 수신한 데이터를 선택회로(91)의 최상위 비트에 위치한 선택기(a)로 전송한다.Meanwhile, the first shifter 971 performs a 5-bit circular left operation on the data stored in the A block of the function value storage block 92 and transmits the data to the first carry adder 961. The first carry adder adds the data received from the first shifter 971 to the data received from the common function calculator 94 and transmits the received data to the second carry adder 962. The second carry adder 962 adds the data received from the E block of the function value storage block 92 to the data received from the first carry adder 961 and transmits the received data to the third carry adder 963. The third carry adder 963 receives and adds the 0th intermediate value of the intermediate value storage block 81 to the data received from the second carry adder 962 and transmits the result value to the fourth carry adder 964. do. The fourth carry adder 964 receives the K0 value from the constant block 966 in which the constant values of Table 1 are stored and adds the data received from the third carry adder 963, and adds the result to the carry transfer adder 965. To send). The carry delivery adder 965 transmits the data received from the fourth carry adder 964 to the selector a located at the most significant bit of the selection circuit 91.

한편, 함수값 저장블록(92)의 A블록에 저장된 초기값은 선택회로(91)의 최상위 비트로부터 두 번째에 위치한 선택기(b)로 전송되고, 함수값 저장블록(92)의 A블록에 저장된 초기값은 30비트 서큘러 레프트 연산되어 최상위 비트로부터 세 번째에 위치한 선택기(c)로 전송된다. 또한, 함수값 저장블록(92)의 C블록에 저장된 초기값은 선택회로(91)의 최상위 비트로부터 네 번째에 위치한 선택기(d)로 전송되고, 함수값 저장블록(92)의 D블록에 저장된 초기값은 최하위 비트에 위치한 선택기(e)로 전송된다.On the other hand, the initial value stored in the A block of the function value storage block 92 is transmitted to the selector (b) located second from the most significant bit of the selection circuit 91, and stored in the A block of the function value storage block 92. The initial value is a 30 bit circular left operation and sent to selector c located third from the most significant bit. Further, the initial value stored in the C block of the function value storage block 92 is transmitted to the selector d located fourth from the most significant bit of the selection circuit 91, and stored in the D block of the function value storage block 92. The initial value is sent to the selector e located at the least significant bit.

또한, 함수값 저장블록(92)에 5개(A, B, C, D, E)로 블록화되어 저장되는 데이터는 출력가산기(98)에 구비되는 5개의 가산기(add0, add1, add2, add3, add4)에 차례로 전송되어 초기값에 가산된다.In addition, the data stored in blocks of five (A, B, C, D, E) in the function value storage block 92 is stored in the five adders (add0, add1, add2, add3, are sent to add4) in order and added to the initial value.

입력 버퍼(7)로부터 입력된 초기값은 전술한 과정을 반복하여 수행하여 총 80단계의 연산을 반복하고, 연산된 결과는 출력가산기(98)를 통해 계속 가산되며, 가산된 결과는 출력버퍼(99)를 통해 160비트의 신호로 버퍼링한다.The initial value input from the input buffer 7 is performed by repeating the above-described process to repeat the operation of a total of 80 steps, and the calculated result is continuously added through the output adder 98, and the added result is output buffer ( 99) to buffer 160-bit signals.

한편, 연산의 반복에 있어서, SHA-1의 3라운드(표 1 참조)를 연산하는 경우, 함수 선택부(93)는 SHA-1 함수 연산부(951)를 작동시키고, HAS의 3라운드(표 2 참조)를 연산하는 경우, HAS 함수 연산부를 작동시켜 각각의 알고리즘에 대응하는 함수를 연산한다. 또한, HAS를 연산하는 경우 제 1쉬프터(971) 대신 제 3쉬프터(973), 제 2쉬프터(972) 대신 제 4쉬프터(974)를 사용한다. 이때, 제 3쉬프터(973)는 함수 선택부(93)로부터 각 단계의 정보를 입력받아 표 3에 도시된 비트 수 만큼의 서큘러 레프트 연산을 수행하며, 20단계의 연산을 4라운드 반복하여 연산한다. 또한, 제 4쉬프터(974)는 함수 선택부(93)로부터 각 단계의 정보를 입력받아 표 4에 도시된 비트 수 만큼의 서큘러 레프트 연산을 수행On the other hand, in the repetition of the operation, when calculating the third round of SHA-1 (see Table 1), the function selector 93 operates the SHA-1 function calculating unit 951 and the third round of the HAS (Table 2). Operation), the HAS function operation unit is operated to calculate a function corresponding to each algorithm. In addition, when calculating the HAS, a third shifter 973 and a fourth shifter 974 are used instead of the first shifter 971 and the second shifter 972. At this time, the third shifter 973 receives the information of each step from the function selector 93 and performs circular left operation by the number of bits shown in Table 3, and performs the operation of 20 steps by repeating four rounds. . In addition, the fourth shifter 974 receives information of each step from the function selector 93 and performs the circular left operation by the number of bits shown in Table 4.

단계step 1단계Stage 1 2단계Tier 2 3단계Tier 3 4단계4 steps 5단계5 steps 6단계6 steps 7단계7 steps 8단계8 levels 9단계9 steps 10단계10 steps 비트beat 55 1111 77 1515 66 1313 88 1414 77 1212 단계step 11단계11 steps 12단계12 steps 13단계Step 13 14단계Step 14 15단계Step 15 16단계16 steps 17단계Step 17 18단계18 steps 19단계Step 19 20단계20 steps 비트beat 99 1111 88 1515 66 1212 99 1414 55 1313

라운드round 단계step 비트beat 1One 0≤n≤19 0≤n≤19 1010 22 20≤n≤3920≤n≤39 1717 33 40≤n≤5940≤n≤59 2525 44 60≤n≤7960≤n≤79 3030

이상에서 본 발명은 비록 한정된 실시예와 도면에 의해 설명되었으나, 본 발명은 이것에 의해 한정되지 않으며 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자에 의해 본 발명의 기술사상과 아래에 기재될 특허청구범위의 균등범위 내에서 다양한 수정 및 변형이 가능함은 물론이다.Although the present invention has been described above by means of limited embodiments and drawings, the present invention is not limited thereto and will be described below by the person skilled in the art to which the present invention pertains. Of course, various modifications and variations are possible within the scope of the claims.

상술한 바와 같이, 본 발명의 해쉬 함수 연산을 위한 공통엔진에 따르면, 알고리즘의 구조가 유사한 복수의 함수를 처리하기 위하여 동일한 하드웨어 구성요소를 공유하는 해쉬 함수 연산 엔진을 설계함으로써, 함수 처리에 불필요한 전기소자를 줄일 수 있다.As described above, according to the common engine for hash function calculation of the present invention, by designing a hash function calculation engine that shares the same hardware components in order to process a plurality of functions having a similar structure of the algorithm, it is unnecessary to the function processing The device can be reduced.

Claims (8)

입력되는 데이터를 소정의 비트 단위로 블록을 생성하여 저장하는 입력 버퍼;An input buffer for generating and storing blocks of input data in predetermined bit units; 알고리즘이 서로 다른 복수의 해쉬 함수 연산에 필요한 중간값을 저장하되 공통되는 중간값은 공유하고, 공통되지 않는 중간값의 생성에 필요한 중간값 변수를 생성하는 중간값 처리부; 및 An intermediate value processing unit for storing intermediate values required for a plurality of different hash function calculations, but sharing common intermediate values and generating intermediate values for generating non-common intermediate values; And 상기 해쉬 함수 연산에 필요한 중간값을 이용하여 상기 알고리즘이 서로 다른 복수의 해쉬 함수를 연산하되, 동일한 연산은 함수를 공유하여 통합 연산하고 서로 다른 연산은 각 해쉬 함수마다 개별 연산하는 함수 처리부;를 구비하는 것을 특징으로 하는 해쉬 함수 연산을 위한 공통엔진.A function processing unit configured to calculate a plurality of hash functions different from each other by using an intermediate value necessary for the hash function operation, the same operation sharing a function, and a different operation for each hash function separately; Common engine for hash function operation, characterized in that. 삭제delete 제1항에 있어서, 상기 중간값 처리부는The method of claim 1, wherein the intermediate value processing unit 상기 입력 버퍼에서 입력되는 중간값 및 연산을 통해 생성되는 중간값을 저장하는 저장 블록;A storage block for storing an intermediate value input from the input buffer and an intermediate value generated through an operation; 중간값 생성에 필요한 중간값 변수를 연산하는 중간값 변수 연산부;An intermediate value variable calculating unit for calculating an intermediate value necessary for generating an intermediate value; 상기 중간값 변수 연산부로부터 전송받은 값에 상응하는 중간값을 상기 저장 블록으로부터 추출하여 저장하는 복수의 중간값 선택 버퍼; 및A plurality of intermediate value selection buffers for extracting and storing an intermediate value corresponding to the value received from the intermediate value variable calculator from the storage block; And 상기 중간값 선택 버퍼에 저장된 값을 사용하여 새로운 중간값을 생성하고, 상기 생성된 중간값을 상기 저장 블록에 전송하는 복수의 중간값 연산회로;를 구비하는 것을 특징으로 하는 해쉬 함수 연산을 위한 공통엔진.And a plurality of intermediate value calculating circuits for generating a new intermediate value using the value stored in the intermediate value selection buffer and transmitting the generated intermediate value to the storage block. engine. 제1항 또는 제3항에 있어서, 상기 함수 처리부는The method of claim 1 or 3, wherein the function processing unit 알고리즘이 서로 다른 복수의 해쉬 함수에서 공통되는 부분의 함수를 연산하는 공통함수 연산부;A common function calculation unit for calculating a function of a part common to a plurality of hash functions having different algorithms; 알고리즘이 서로 다른 복수의 상기 해쉬 함수에서 서로 다른 부분의 함수를 연산하는 복수의 차등함수 연산부; 및A plurality of differential function calculators for calculating functions of different parts of the plurality of hash functions having different algorithms; And 해쉬 함수 연산 단계를 확인하여 공통함수 연산부 또는 차등함수 연산부의 작동을 선택하는 함수 선택부;를 구비하는 것을 특징으로 하는 해쉬 함수 연산을 위한 공통엔진.And a function selector which checks the hash function operation step and selects an operation of the common function operation unit or the differential function operation unit. 입력되는 데이터를 소정의 비트 단위로 블록을 생성하여 저장하는 입력 버퍼;An input buffer for generating and storing blocks of input data in predetermined bit units; 알고리즘이 서로 다른 복수의 해쉬 함수 연산에 필요한 중간값 변수를 생성하고 저장하는 중간값 처리부; 및An intermediate value processing unit for generating and storing intermediate value variables required for a plurality of hash function calculations having different algorithms; And 상기 알고리즘이 서로 다른 복수의 해쉬 함수를 연산하되, 동일한 연산은 함수를 공유하여 통합 연산하고 서로 다른 연산은 각 해쉬 함수마다 개별 연산하는 함수 처리부;를 구비하는 것을 특징으로 하는 해쉬 함수 연산을 위한 공통엔진.The algorithm operates on a plurality of different hash functions, the same operation is a shared operation, the integrated operation, and the different operation function processing unit for a separate operation for each hash function; common for a hash function operation engine. 제5항에 있어서, 상기 중간값 처리부는The method of claim 5, wherein the intermediate value processing unit 알고리즘이 서로 다른 복수의 해쉬 함수에서 공통되는 중간값을 공유하는 것을 특징으로 하는 해쉬 함수 연산을 위한 공통엔진.Common engine for hash function operation, characterized in that the algorithms share a common intermediate value in a plurality of different hash functions. 제5항에 있어서, 상기 중간값 처리부는The method of claim 5, wherein the intermediate value processing unit 상기 입력 버퍼에서 입력되는 중간값 및 연산에 의해 생성되는 중간값을 저장하는 저장 블록;A storage block for storing an intermediate value input from the input buffer and an intermediate value generated by an operation; 중간값 생성에 필요한 중간값 변수를 연산하는 중간값 변수 연산부;An intermediate value variable calculating unit for calculating an intermediate value necessary for generating an intermediate value; 상기 중간값 변수 연산부로부터 전송받은 중간값 변수에 상응하는 중간값을 상기 저장 블록으로부터 추출하여 저장하는 복수의 중간값 선택 버퍼; 및A plurality of intermediate value selection buffers for extracting and storing an intermediate value corresponding to the intermediate value variable received from the intermediate value variable calculator from the storage block; And 상기 중간값 선택 버퍼에 저장된 값을 사용하여 새로운 중간값을 생성하고, 상기 생성된 중간값을 상기 저장 블록에 전송하는 복수의 중간값 연산회로;를 구비하는 것을 특징으로 하는 해쉬 함수 연산을 위한 공통엔진.And a plurality of intermediate value calculating circuits for generating a new intermediate value using the value stored in the intermediate value selection buffer and transmitting the generated intermediate value to the storage block. engine. 제5항에 있어서, 상기 함수 처리부는The method of claim 5, wherein the function processing unit 알고리즘이 서로 다른 복수의 해쉬 함수에서 공통되는 부분의 함수를 연산하는 공통함수 연산부;A common function calculation unit for calculating a function of a part common to a plurality of hash functions having different algorithms; 알고리즘이 서로 다른 복수의 상기 해쉬 함수에서 서로 다른 부분의 함수를 연산하는 복수의 차등함수 연산부; 및A plurality of differential function calculators for calculating functions of different parts of the plurality of hash functions having different algorithms; And 해쉬 함수 연산 단계를 확인하여 공통함수 연산부 또는 차등함수 연산부의 작동을 선택하는 함수 선택부;를 구비하는 것을 특징으로 하는 해쉬 함수 연산을 위한 공통엔진.And a function selector which checks the hash function operation step and selects an operation of the common function operation unit or the differential function operation unit.
KR1020050080532A 2005-08-31 2005-08-31 Common engine for computing multiple hash functions with different algorithms Expired - Fee Related KR100581662B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020050080532A KR100581662B1 (en) 2005-08-31 2005-08-31 Common engine for computing multiple hash functions with different algorithms

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020050080532A KR100581662B1 (en) 2005-08-31 2005-08-31 Common engine for computing multiple hash functions with different algorithms

Publications (1)

Publication Number Publication Date
KR100581662B1 true KR100581662B1 (en) 2006-05-22

Family

ID=37181738

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020050080532A Expired - Fee Related KR100581662B1 (en) 2005-08-31 2005-08-31 Common engine for computing multiple hash functions with different algorithms

Country Status (1)

Country Link
KR (1) KR100581662B1 (en)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8086864B2 (en) 2007-07-09 2011-12-27 Electronics And Telecommunications Research Institute Low power HMAC encryption apparatus
US8275126B2 (en) 2008-12-08 2012-09-25 Electronics And Telecommunications Research Institute Apparatus and method for hash cryptography
CN113794567A (en) * 2021-09-13 2021-12-14 上海致居信息科技有限公司 Synthesis acceleration method and device of SHA256 Hash algorithm zero-knowledge proof circuit
CN116318629A (en) * 2023-03-15 2023-06-23 湖南国科微电子股份有限公司 Data encryption device

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2001080483A2 (en) 2000-04-13 2001-10-25 Broadcom Corporation Authentication engine architecture and method
US20020191791A1 (en) 2001-06-13 2002-12-19 Anand Satish N. Apparatus and method for a hash processing system using multiple hash storage areas
KR20030004771A (en) * 2001-07-06 2003-01-15 최준림 Word generation circuit used in the Secure Hash Algorithm-1
KR20030081348A (en) * 2000-12-13 2003-10-17 인피네온 테크놀로지스 아게 Cryptographic processor

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2001080483A2 (en) 2000-04-13 2001-10-25 Broadcom Corporation Authentication engine architecture and method
KR20030081348A (en) * 2000-12-13 2003-10-17 인피네온 테크놀로지스 아게 Cryptographic processor
US20020191791A1 (en) 2001-06-13 2002-12-19 Anand Satish N. Apparatus and method for a hash processing system using multiple hash storage areas
KR20030004771A (en) * 2001-07-06 2003-01-15 최준림 Word generation circuit used in the Secure Hash Algorithm-1

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
1020030004771
1020050080532 - 579531

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8086864B2 (en) 2007-07-09 2011-12-27 Electronics And Telecommunications Research Institute Low power HMAC encryption apparatus
US8275126B2 (en) 2008-12-08 2012-09-25 Electronics And Telecommunications Research Institute Apparatus and method for hash cryptography
CN113794567A (en) * 2021-09-13 2021-12-14 上海致居信息科技有限公司 Synthesis acceleration method and device of SHA256 Hash algorithm zero-knowledge proof circuit
CN113794567B (en) * 2021-09-13 2024-04-05 上海致居信息科技有限公司 Synthetic acceleration method and device for SHA256 hash algorithm zero knowledge proof circuit
CN116318629A (en) * 2023-03-15 2023-06-23 湖南国科微电子股份有限公司 Data encryption device

Similar Documents

Publication Publication Date Title
Lee et al. Correlation manipulating circuits for stochastic computing
JP3014391B2 (en) Cryptography and cryptographic processor for implementing the method
US6510446B1 (en) Floating point calculation method and unit efficiently representing floating point data as integer and semiconductor integrated circuit device provided with the same
EP1471420A2 (en) Montgomery modular multiplier and method thereof using carry save addition
Imaña et al. Efficient hardware arithmetic for inverted binary ring-lwe based post-quantum cryptography
US7590917B2 (en) Parameter generation for interleavers
Gowthaman et al. Performance study of enhanced SHA-256 algorithm
CN113254072B (en) Data processor, data processing method, chip, computer device, and medium
Shrestha et al. High-speed and hardware-efficient successive cancellation polar-decoder
Birgani et al. Area-time-efficient scalable schoolbook polynomial multiplier for lattice-based cryptography
KR100581662B1 (en) Common engine for computing multiple hash functions with different algorithms
Sun et al. Design and optimized implementation of the SHA-2 (256, 384, 512) hash algorithms
US20110176673A1 (en) Encrypting apparatus
US7437657B2 (en) High speed add-compare-select processing
Piestrak Design of multi-residue generators using shared logic
JPWO2015173870A1 (en) Information processing system, information processing method, and program
Wei Fast signed-digit arithmetic circuits for residue number systems
KR100578721B1 (en) Method for generating n-bit cyclic redundancy check using JoR logic and parallel cyclic redundancy check generator
KR20040043582A (en) System And Methord For Generating Parallel Cyclic Redundancy Codes
EP1202488A2 (en) Encryption sub-key generation circuit
US6526427B1 (en) Method of mask calculation for generation of shifted pseudo-noise (PN) sequence
KR100417793B1 (en) Word generation circuit used in the Secure Hash Algorithm-1
Sathyabhama et al. Area and power efficient carry select adder using 8T full adder
US8707224B2 (en) Method of optimizing combinational circuits
Vijayakumari et al. Genetic algorithm based design of combinational logic circuits using Reed Muller blocks

Legal Events

Date Code Title Description
A201 Request for examination
PA0109 Patent application

St.27 status event code: A-0-1-A10-A12-nap-PA0109

PA0201 Request for examination

St.27 status event code: A-1-2-D10-D11-exm-PA0201

A302 Request for accelerated examination
PA0302 Request for accelerated examination

St.27 status event code: A-1-2-D10-D17-exm-PA0302

St.27 status event code: A-1-2-D10-D16-exm-PA0302

D13-X000 Search requested

St.27 status event code: A-1-2-D10-D13-srh-X000

D14-X000 Search report completed

St.27 status event code: A-1-2-D10-D14-srh-X000

E902 Notification of reason for refusal
PE0902 Notice of grounds for rejection

St.27 status event code: A-1-2-D10-D21-exm-PE0902

E13-X000 Pre-grant limitation requested

St.27 status event code: A-2-3-E10-E13-lim-X000

P11-X000 Amendment of application requested

St.27 status event code: A-2-2-P10-P11-nap-X000

P13-X000 Application amended

St.27 status event code: A-2-2-P10-P13-nap-X000

E701 Decision to grant or registration of patent right
PE0701 Decision of registration

St.27 status event code: A-1-2-D10-D22-exm-PE0701

GRNT Written decision to grant
PR0701 Registration of establishment

St.27 status event code: A-2-4-F10-F11-exm-PR0701

PR1002 Payment of registration fee

St.27 status event code: A-2-2-U10-U11-oth-PR1002

Fee payment year number: 1

PG1601 Publication of registration

St.27 status event code: A-4-4-Q10-Q13-nap-PG1601

R18-X000 Changes to party contact information recorded

St.27 status event code: A-5-5-R10-R18-oth-X000

PN2301 Change of applicant

St.27 status event code: A-5-5-R10-R11-asn-PN2301

R18-X000 Changes to party contact information recorded

St.27 status event code: A-5-5-R10-R18-oth-X000

PR1001 Payment of annual fee

St.27 status event code: A-4-4-U10-U11-oth-PR1001

Fee payment year number: 4

P14-X000 Amendment of ip right document requested

St.27 status event code: A-5-5-P10-P14-nap-X000

P16-X000 Ip right document amended

St.27 status event code: A-5-5-P10-P16-nap-X000

Q16-X000 A copy of ip right certificate issued

St.27 status event code: A-4-4-Q10-Q16-nap-X000

PR1001 Payment of annual fee

St.27 status event code: A-4-4-U10-U11-oth-PR1001

Fee payment year number: 5

R18-X000 Changes to party contact information recorded

St.27 status event code: A-5-5-R10-R18-oth-X000

PR1001 Payment of annual fee

St.27 status event code: A-4-4-U10-U11-oth-PR1001

Fee payment year number: 6

R18-X000 Changes to party contact information recorded

St.27 status event code: A-5-5-R10-R18-oth-X000

FPAY Annual fee payment

Payment date: 20120612

Year of fee payment: 7

PR1001 Payment of annual fee

St.27 status event code: A-4-4-U10-U11-oth-PR1001

Fee payment year number: 7

FPAY Annual fee payment

Payment date: 20130510

Year of fee payment: 8

PR1001 Payment of annual fee

St.27 status event code: A-4-4-U10-U11-oth-PR1001

Fee payment year number: 8

LAPS Lapse due to unpaid annual fee
PC1903 Unpaid annual fee

St.27 status event code: A-4-4-U10-U13-oth-PC1903

Not in force date: 20140513

Payment event data comment text: Termination Category : DEFAULT_OF_REGISTRATION_FEE

PC1903 Unpaid annual fee

St.27 status event code: N-4-6-H10-H13-oth-PC1903

Ip right cessation event data comment text: Termination Category : DEFAULT_OF_REGISTRATION_FEE

Not in force date: 20140513

P22-X000 Classification modified

St.27 status event code: A-4-4-P10-P22-nap-X000

R18-X000 Changes to party contact information recorded

St.27 status event code: A-5-5-R10-R18-oth-X000