28.02.2014 Views

SHA1 decoder EDA385

SHA1 decoder EDA385

SHA1 decoder EDA385

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

Initialize hash value for this chunk:<br />

a = h0<br />

b = h1<br />

c = h2<br />

d = h3<br />

e = h4<br />

//Main loop:<br />

for i from 0 to 79<br />

if 0 ≤ i ≤ 19 then<br />

f = (b and c) or ((not b) and d)<br />

k = 0x5A827999<br />

else if 20 ≤ i ≤ 39<br />

f = b xor c xor d<br />

k = 0x6ED9EBA1<br />

else if 40 ≤ i ≤ 59<br />

f = (b and c) or (b and d) or (c and d)<br />

k = 0x8F1BBCDC<br />

else if 60 ≤ i ≤ 79<br />

f = b xor c xor d<br />

k = 0xCA62C1D6<br />

temp = (a leftrotate 5) + f + e + k + w[i]<br />

e = d<br />

d = c<br />

c = b leftrotate 30<br />

b = a<br />

a = temp<br />

//Produce the final hash value (big-endian):<br />

digest = hash = a append b append c append d append e<br />

3.2 The brute forcer<br />

The two main parts of the brute force related hardware are the string generator<br />

and the actual hardware accelerated <strong>SHA1</strong>-hasher. First, the normal and optimized<br />

version of the <strong>SHA1</strong>-hasher will be explained, then the string generator.<br />

The <strong>SHA1</strong> algorithm can be split into two distinct parts; reading and computing<br />

w-values, and the main loop actually computing the hash. W-values are<br />

named after the w-variable in the pseudocode above, where the initial 16 w-<br />

values are parts of the pre-processed input string. The implementation has also<br />

been split into two dierent hardware cores, explained in more detail below.<br />

3.2.1 W-value generator<br />

This core is in an idle state until a start signal is clocked in with value high,<br />

which triggers the core to start reading 32-bit values on an in-port. These values<br />

represent w[0] to w[15], and one value will be read each clock cycle. After the<br />

5

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!