Skip Navigation Links.


Follow Us

Follow LnT_Infotech on Twitter  L&T Infotech on Facebook   L&T Infotech on Flickr   L&T Infotech on LinkedIn   L&T Infotech on YouTube

Polls

What do you understand by L&T Infotech’s branding statement: Business-to-IT Connect?




Print Print   Email this Page Email   Suggestions  Suggestions  Share Share   

Secure Hash Algorithm (SHA) was standardized by NIST in 2002 and published in FIPS 180-2. It is listed among the NSA Suite B list of secure algorithms. SHA-256 is a message digest algorithm that operates on 512-bit block using a compression function and generates a 256-bit hash output. The upper limit check of input text (2 64 – 1) is not part of the logic.
See the Pin diagram, Timing Waveform for SHA-256 first message block and Timing Waveform for SHA-256 last message block.

SHA-256 IP core is divided into main module and core module. The main module performs padding and counting of messages. The core module performs the compression operation. For a single 512-bit block it takes 67 cycles to generate a 256-bit hash output. It accepts hexadecimal input data of 32-bit width. The IP Core has been cross-verified with a C-model using a Verilog PLI test environment.

SHA-256 is a commonly used hash algorithm, which finds its applications in data storage, pseudorandom number generation, signature/verification during data transfer, etc.

Specifications
Implementation Results for V4
  • 892 slices, Performance: 90.5MHz
  • No Block RAMs, 297 IOBss
  • 67 clock cycles for a 512-bit block
  • Throughput: 691.58 Mbps

Design Attributes
  • modular design
  • Fully synchronous,design
  • Single clock

Product Package
  • RTL code
  • Detailed design document
  • Verification environment
  • Test cases
  • Synthesis environment/scripts

Documentation
  • Design Guide
  • Synthesis Guide

Availability: Now
Language: Verilog HDL
Synthesis : Synplify Pro, Xilinx ISE, DC
Simulation : Verilog-NC, VCS, MTI
Technology : 0.18u ASIC or better, FPGA

Features:
  • Compliant with FIPS 180-2 standard
  • Accepts 32-bit input text in hexadecimal format
  • Generates 256-bit hash output
  • Fully Verified using NIST test vectors
  • Fully functional and synthesizable Verilog HDL core available