Research Article Open Access

Efficient Reversible Montgomery Multiplier and Its Application to Hardware Cryptography

Noor Muhammed Nayeem1, Lafifa Jamal2 and Hafiz Md. Hasan Babu1
  • 1 , Afganistan
  • 2 ,
Journal of Computer Science
Volume 5 No. 1, 2009, 49-56

DOI: https://doi.org/10.3844/jcssp.2009.49.56

Submitted On: 16 January 2009 Published On: 31 January 2009

How to Cite: Nayeem, N. M., Jamal, L. & Babu, H. M. H. (2009). Efficient Reversible Montgomery Multiplier and Its Application to Hardware Cryptography . Journal of Computer Science, 5(1), 49-56. https://doi.org/10.3844/jcssp.2009.49.56

Abstract

Problem Statement: Arithmetic Logic Unit (ALU) of a crypto-processor and microchips leak information through power consumption. Although the cryptographic protocols are secured against mathematical attacks, the attackers can break the encryption by measuring the energy consumption. Approach: To thwart attacks, this study proposed the use of reversible logic for designing the ALU of a crypto-processor. Ideally, reversible circuits do not dissipate any energy. If reversible circuits are used, then the attacker would not be able to analyze the power consumption. In order to design the reversible ALU of a crypto-processor, reversible Carry Save Adder (CSA) using Modified TSG (MTSG) gates and architecture of Montgomery multiplier were proposed. For reversible implementation of Montgomery multiplier, efficient reversible multiplexers and sequential circuits such as reversible registers and shift registers were presented. Results: This study showed that modified designs perform better than the existing ones in terms of number of gates, number of garbage outputs and quantum cost. Lower bounds of the proposed designs were established by providing relevant theorems and lemmas. Conclusion: The application of reversible circuit is suitable to the field of hardware cryptography.

  • 1,574 Views
  • 1,799 Downloads
  • 14 Citations

Download

Keywords

  • Montgomery multiplier
  • carry save adder
  • reversible gate
  • shift register