Parallel Cryptanalysis

Total Page:16

File Type:pdf, Size:1020Kb

Parallel Cryptanalysis Parallel cryptanalysis Citation for published version (APA): Niederhagen, R. F. (2012). Parallel cryptanalysis. Technische Universiteit Eindhoven. https://doi.org/10.6100/IR731259 DOI: 10.6100/IR731259 Document status and date: Published: 01/01/2012 Document Version: Publisher’s PDF, also known as Version of Record (includes final page, issue and volume numbers) Please check the document version of this publication: • A submitted manuscript is the version of the article upon submission and before peer-review. There can be important differences between the submitted version and the official published version of record. People interested in the research are advised to contact the author for the final version of the publication, or visit the DOI to the publisher's website. • The final author version and the galley proof are versions of the publication after peer review. • The final published version features the final layout of the paper including the volume, issue and page numbers. Link to publication General rights Copyright and moral rights for the publications made accessible in the public portal are retained by the authors and/or other copyright owners and it is a condition of accessing publications that users recognise and abide by the legal requirements associated with these rights. • Users may download and print one copy of any publication from the public portal for the purpose of private study or research. • You may not further distribute the material or use it for any profit-making activity or commercial gain • You may freely distribute the URL identifying the publication in the public portal. If the publication is distributed under the terms of Article 25fa of the Dutch Copyright Act, indicated by the “Taverne” license above, please follow below link for the End User Agreement: www.tue.nl/taverne Take down policy If you believe that this document breaches copyright please contact us at: [email protected] providing details and we will investigate your claim. Download date: 25. Sep. 2021 Parallel Cryptanalysis Ruben Niederhagen Parallel Cryptanalysis PROEFSCHRIFT ter verkrijging van de graad van doctor aan de Technische Universiteit Eindhoven, op gezag van de rector magnificus, prof.dr.ir. C.J. van Duijn, voor een commissie aangewezen door het College voor Promoties in het openbaar te verdedigen op maandag 23 april 2012 om 16.00 uur door Ruben Falko Niederhagen geboren te Aken, Duitsland Dit proefschrift is goedgekeurd door de promotoren: prof.dr. T. Lange en prof.dr. D.J. Bernstein Copromotor: dr. C.-M. Cheng A catalogue record is available from the Eindhoven University of Technology Library. ISBN: 978-90-386-3128-8 Printed by Printservice Technische Universiteit Eindhoven Cover design by Verspaget & Bruinink, Nuenen Public domain Commissie: prof.dr. D.J. Bernstein, promotor (University of Illinois at Chicago) dr. C.-M. Cheng, copromotor (National Taiwan University) prof.dr. A.M. Cohen, chairman prof.dr. R. Bisseling (Utrecht University) prof.dr. T. Lange, promotor prof.dr. W.H.A. Schilders prof.dr. G. Woeginger prof.dr. B.-Y. Yang (Academia Sinica) Acknowledgements I would like to thank my supervisors Daniel J. Bernstein and Tanja Lange as well as my supervisors in Taiwan, Chen-Mou Cheng and Bo-YinYang, for the opportunity to enjoy my PhD studies commuting between the Netherlands and Taiwan. Furthermore, I would like to thank them for their support throughout my studies and the writing of my thesis. I also would like to thank Rob Bisseling, Arjeh Cohen, Wil Schilders, and Gerhard Woeginger for joining my doctorate committee and for their valuable feedback on the draft of my dissertation. Special thanks go to Tung Chou, Andreas Gierlich, and Peter Schwabe for proofreading of the first versions of my thesis and for suggesting corrections and improvements. Finally, I want to thank Stefan Lankes from the Lehrstuhl für Betriebssys- teme (research group for operating systems) at RWTH Aachen University for his support in the first years of my PhD studies. Contents 1 Introduction1 2 Overview of parallel computing3 2.1 Parallel architectures..........................5 2.1.1 Microarchitecture........................5 2.1.2 Instruction set.........................7 2.1.3 System architecture......................8 2.2 Parallel programming......................... 12 2.2.1 Shared memory......................... 12 2.2.2 Message passing........................ 14 2.2.3 Summary............................ 14 2.3 General-purpose GPU programming................. 15 2.3.1 Programming NVIDIA GPUs................. 17 2.3.2 Assembly for NVIDIA GPUs................. 18 3 Parallel implementation of Pollard’s rho method 23 3.1 The ECDLP and the parallel version of Pollard’s rho method... 24 3.2 ECC2K-130 and the iteration function................ 25 3.3 Implementing ECC2K-130 on the Cell processor.......... 26 3.3.1 A Brief Description of the Cell processor........... 27 3.3.2 Approaches for implementing the iteration function..... 29 3.3.3 ECC2K-130 iterations on the Cell processor......... 31 3.3.4 Using DMA transfers to increase the batch size....... 33 3.3.5 Overall results on the Cell processor............. 34 3.4 Implementing ECC2K-130 on a GPU................. 35 3.4.1 The GTX 295 graphics card.................. 36 3.4.2 Approaches for implementing the iteration function..... 38 3.4.3 Polynomial multiplication on the GPU............ 39 3.4.4 ECC2K-130 iterations on the GPU.............. 42 3.4.5 Overall results on the GPU.................. 44 3.5 Performance comparison........................ 45 4 Parallel implementation of the XL algorithm 47 4.1 The XL algorithm........................... 48 4.2 The block Wiedemann algorithm................... 49 4.3 The block Berlekamp–Massey algorithm............... 53 4.3.1 Reducing the cost of the Berlekamp–Massey algorithm... 54 4.3.2 Parallelization of the Berlekamp–Massey algorithm..... 55 4.4 Thomé’s version of the block Berlekamp–Massey algorithm.... 58 4.4.1 Matrix polynomial multiplications.............. 58 4.4.2 Parallelization of Thomé’s Berlekamp–Massey algorithm.. 58 4.5 Implementation of XL......................... 59 4.5.1 Reducing the computational cost of BW1 and BW3.... 60 4.5.2 SIMD vector operations in F16 ................ 60 4.5.3 Exploiting the structure of the Macaulay matrix...... 62 4.5.4 Macaulay matrix multiplication in XL............ 64 4.5.5 Parallel Macaulay matrix multiplication in XL....... 66 4.6 Experimental results.......................... 73 4.6.1 Impact of the block size.................... 74 4.6.2 Performance of the Macaulay matrix multiplication..... 76 4.6.3 Scalability experiments.................... 78 5 Parallel implementation of Wagner’s birthday attack 81 5.1 Wagner’s generalized birthday attack................. 82 5.1.1 Wagner’s tree algorithm.................... 82 5.1.2 Wagner in storage-restricted environments.......... 83 5.2 The FSB hash function........................ 85 5.2.1 Details of the FSB hash function............... 85 5.2.2 Attacking the compression function of FSB48 ........ 87 5.3 Attack strategy............................. 88 5.3.1 How large is a list entry?................... 88 5.3.2 What list size can be handled?................ 89 5.3.3 The strategy.......................... 89 5.4 Implementing the attack........................ 92 5.4.1 Parallelization......................... 92 5.4.2 Efficient implementation.................... 94 5.5 Results.................................. 96 5.5.1 Cost estimates......................... 96 5.5.2 Cost measurements....................... 97 5.5.3 Time-storage tradeoffs..................... 97 5.6 Scalability analysis........................... 98 Bibliography 101 1 Introduction Most of today’s cryptographic primitives are based on computations that are hard to perform for a potential attacker but easy to perform for somebody who is in possession of some secret information, the key, that opens a back door in these hard computations and allows them to be solved in a small amount of time. Each cryptographic primitive should be designed such that the cost of an attack grows exponentially with the problem size, while the computations using the secret key only grow polynomially. To estimate the strength of a cryptographic primitive it is important to know how hard it is to perform the computation without knowledge of the secret back door and to get an understanding of how much money or time the attacker has to spend. Usually a cryptographic primitive allows the cryptographer to choose parameters that make an attack harder at the cost of making the computations using the secret key harder as well. Therefore designing a cryptographic primitive imposes the dilemma of choosing the parameters strong enough to resist an attack up to a certain cost while choosing them small enough to allow usage of the primitive in the real world, e.g. on small computing devices like smart phones. Typically a cryptographic attack requires a tremendous amount of compu- tation—otherwise the cryptographic primitive under attack can be considered broken. Given this tremendous amount of computation, it is likely that there are computations that can be performed in parallel. Therefore, parallel computing systems are a powerful tool for the attacker of a cryptographic system. In contrast to a legitimate user who typically exploits only a small or moderate amount of parallelism, an attacker is often able to launch an attack on a massively parallel system. In practice the amount of parallel computation power available to an
Recommended publications
  • GPU-Based Password Cracking on the Security of Password Hashing Schemes Regarding Advances in Graphics Processing Units
    Radboud University Nijmegen Faculty of Science Kerckhoffs Institute Master of Science Thesis GPU-based Password Cracking On the Security of Password Hashing Schemes regarding Advances in Graphics Processing Units by Martijn Sprengers [email protected] Supervisors: Dr. L. Batina (Radboud University Nijmegen) Ir. S. Hegt (KPMG IT Advisory) Ir. P. Ceelen (KPMG IT Advisory) Thesis number: 646 Final Version Abstract Since users rely on passwords to authenticate themselves to computer systems, ad- versaries attempt to recover those passwords. To prevent such a recovery, various password hashing schemes can be used to store passwords securely. However, recent advances in the graphics processing unit (GPU) hardware challenge the way we have to look at secure password storage. GPU's have proven to be suitable for crypto- graphic operations and provide a significant speedup in performance compared to traditional central processing units (CPU's). This research focuses on the security requirements and properties of prevalent pass- word hashing schemes. Moreover, we present a proof of concept that launches an exhaustive search attack on the MD5-crypt password hashing scheme using modern GPU's. We show that it is possible to achieve a performance of 880 000 hashes per second, using different optimization techniques. Therefore our implementation, executed on a typical GPU, is more than 30 times faster than equally priced CPU hardware. With this performance increase, `complex' passwords with a length of 8 characters are now becoming feasible to crack. In addition, we show that between 50% and 80% of the passwords in a leaked database could be recovered within 2 months of computation time on one Nvidia GeForce 295 GTX.
    [Show full text]
  • MD5 Collisions the Effect on Computer Forensics April 2006
    Paper MD5 Collisions The Effect on Computer Forensics April 2006 ACCESS DATA , ON YOUR RADAR MD5 Collisions: The Impact on Computer Forensics Hash functions are one of the basic building blocks of modern cryptography. They are used for everything from password verification to digital signatures. A hash function has three fundamental properties: • It must be able to easily convert digital information (i.e. a message) into a fixed length hash value. • It must be computationally impossible to derive any information about the input message from just the hash. • It must be computationally impossible to find two files to have the same hash. A collision is when you find two files to have the same hash. The research published by Wang, Feng, Lai and Yu demonstrated that MD5 fails this third requirement since they were able to generate two different messages that have the same hash. In computer forensics hash functions are important because they provide a means of identifying and classifying electronic evidence. Because hash functions play a critical role in evidence authentication, a judge and jury must be able trust the hash values to uniquely identify electronic evidence. A hash function is unreliable when you can find any two messages that have the same hash. Birthday Paradox The easiest method explaining a hash collision is through what is frequently referred to as the Birthday Paradox. How many people one the street would you have to ask before there is greater than 50% probability that one of those people will share your birthday (same day not the same year)? The answer is 183 (i.e.
    [Show full text]
  • Exploiting Hash Collisions, (The Weakest Ones, W/ Identical Prefix) Via Manipulating File Formats
    Exploitingidentical hash prefix collisions Ange Albertini BlackAlps 2017 Switzerland All opinions expressed during this presentation are mine and not endorsed by any of my employers, present or past. DISCLAIMERS This is not a crypto talk. It’s about exploiting hash collisions, (the weakest ones, w/ identical prefix) via manipulating file formats. You may want to watch Marc Stevens’ talk at CRYPTO17. TL;DR Nothing groundbreaking. No new vulnerability. Just a look behind the scenes of Shattered-like research (format-wise) OTOH there are very few talks on the topic AFAIK. This talk is about... MalSha1 2014: Malicious SHA1 - modified SHA1 2017: PoC||GTFO 0x14 - MD5 2015-2017: Shattered - SHA1 MD5:1992-2004 SHA1: 1995-2005 SHA2: 2001-? SHA3: 2015-? Types of collision first, weakest, overlooked ● Identical prefix ○ 2 files starting with same data ● Chosen prefix Sh*t's broken, yo! ○ 2 files starting with different (chosen) data Unicorns ● Second preimage attack ○ Find data to match another data's hash Dragons ● Preimage attack ○ Find data to match hash From here on, hash collision = IPC = Identical Prefix Collision Formal way to present IPCs Collisions for Hash Functions MD4, MD5, HAVAL-128 and RIPEMD. X Wang, D Feng, X Lai, H Yu 2004 Not very “visual”! Determine file structure I play no role Computationin this (exact shape unknown in advance) Craft valid and meaningful files Collisions blocks Impact Better than random-looking blocks? Will it convince anyone to deprecate anything? FTR Shattered took 6500 CPU-Yr and 110 GPU-Yr. (that's a lot
    [Show full text]
  • MD5 Is Weaker Than Weak: Attacks on Concatenated Combiners
    MD5 is Weaker than Weak: Attacks on Concatenated Combiners Florian Mendel, Christian Rechberger, and Martin Schl¨affer Institute for Applied Information Processing and Communications (IAIK) Graz University of Technology, Inffeldgasse 16a, A-8010 Graz, Austria. [email protected] Abstract. We consider a long standing problem in cryptanalysis: at- tacks on hash function combiners. In this paper, we propose the first attack that allows collision attacks on combiners with a runtime below the birthday-bound of the smaller compression function. This answers an open question by Joux posed in 2004. As a concrete example we give such an attack on combiners with the widely used hash function MD5. The cryptanalytic technique we use combines a partial birthday phase with a differential inside-out tech- nique, and may be of independent interest. This potentially reduces the effort for a collision attack on a combiner like MD5jjSHA-1 for the first time. Keywords: hash functions, cryptanalysis, MD5, combiner, differential 1 Introduction The recent spur of cryptanalytic results on popular hash functions like MD5 and SHA-1 [28,30,31] suggests that they are (much) weaker than originally an- ticipated, especially with respect to collision resistance. It seems non-trivial to propose a concrete hash function which inspires long term confidence. Even more so as we seem unable to construct collision resistant primitives from potentially simpler primitives [27]. Hence constructions that allow to hedge bets, like con- catenated combiners, are of great interest. Before we give a preview of our results in the following, we will first review work on combiners. Review of work on combiners.
    [Show full text]
  • A NEW HASH ALGORITHM: Khichidi-1
    A NEW HASH ALGORITHM: Khichidi-1 Abstract This is a technical document describing a new hash algorithm called Khichidi-1 and has been written in response to a Hash competition (SHA-3) called by National Institute of Standards and Technology (NIST), USA. Tata Consultancy Services (TCS) has designed a new secure hash algorithm, Khichidi-1, which can be used to generate a condensed representation of a message called a Message Digest. A group of functions used in the development of Khichidi-1 has been described followed by a detailed explanation of preprocessing approach. Differences between Khichidi-1 and NIST’ SHA-2, the algorithm that is in use widely, have also been highlighted. Analytical proofs, implementations with examples, various attack scenarios, entropy tests, security strength and computational complexity of the algorithm are described as separate sections in this document. Author: Natarajan Vijayarangan, Ph. D © Copyright 2008, Tata Consultancy Services Limited (TCS). All rights reserved. Khichidi-1 Algorithm Preface Our research work describes a new design and analysis of hashing. A hash algorithm takes any message and produces a “fixed length value” in such a way that any two messages are unlikely to have the same fixed length value. This fixed length value is called a hash value / message digest. When two messages have the same hash value, this is known as a collision. A good hashing algorithm minimizes collisions for a given set of likely data inputs. To achieve this, we have started designing and analyzing a hash function that could be used for digital signature technology. Attacks on MD-5, SHA-0 and SHA-1 by Wang et al [25,26] has given a huge impetus to research in designing practical cryptographic hash functions as well as cryptanalysis of existing functions.
    [Show full text]
  • Proceedings of the 5 International Cryptology and Information Security
    Proceedings of the 5th International Cryptology and Information Security Conference 2016 31st May – 2nd June 2016 Kota Kinabalu, Malaysia Published by Institute for Mathematical Research (INSPEM) Universiti Putra Malaysia 43400 UPM Serdang Selangor Darul Ehsan c Institute for Mathematical Research (INSPEM), 2016 All rights reserved. No part of this book may be reproduced in any form without permission in writing from the publisher, except by a reviewer who wishes to quote brief passages in a review written for inclusion in a magazine or newspaper. First Print 2016 Perpustakaan Negara Malaysia Cataloguing – in – Publication Data Proceedings of the 5th International Cryptology and Information Security (5th.: 2016: Kota Kinabalu) CONFERENCE PROCEEDINGS CRYPTOLOGY 2016: Proceedings of The 5th Interna- tional Cryptology and Information Security Conference 2016 31st May – 2nd June 2016, Kota Kinabalu, Sabah, MALAYSIA / Editors: Amir Hamzah Abd Ghafar, Goi Bok Min, Hailiza Kamarulhaili, Heng Swee Huay, Moesfa Soeheila Mohamad, Mohamad Rushdan Md. Said, Muhammad Rezal Kamel Ariffin. ISBN 9789834406950 1. Cryptography- - Malaysia - - Congresses. 2. Computer security - - Malaysia- - Congresses. I. Amir Hamzah Abd Ghafar II. Goi Bok Min. III. Hailiza Kamarulhaili. IV. Heng Swee Huay. V. Moesfa Soeheila Mohamad. VI. Mohamad Rushdan Md. Said. VII. Muhammad Rezal Kamel Ariffin. Title.005.8072 Proceedings of the 5th International Cryptology and Information Security Conference 2016 (CRYPTOLOGY2016) OPENING REMARKS First and foremost, I would like to thank the Malaysian Society for Cryptology Research (MSCR) in collabo- ration with CyberSecurity Malaysia together with uni- versities: UMS, UPM, and USM, Sabah’s Ministry of Resource Development & Information Technology and Sabah’s State Computer Service Department for their continuous efforts and commitment to host this premier event, the International Cryptology and Information Se- curity Conference for the fifth time.
    [Show full text]
  • Attacks on and Advances in Secure Hash Algorithms
    IAENG International Journal of Computer Science, 43:3, IJCS_43_3_08 ______________________________________________________________________________________ Attacks on and Advances in Secure Hash Algorithms Neha Kishore, Member IAENG, and Bhanu Kapoor service but is a collection of various services. These services Abstract— In today’s information-based society, encryption include: authentication, access control, data confidentiality, along with the techniques for authentication and integrity are non-repudiation, and data integrity[1]. A system has to key to the security of information. Cryptographic hashing ensure one or more of these depending upon the security algorithms, such as the Secure Hashing Algorithms (SHA), are an integral part of the solution to the information security requirements for a particular system. For example, in problem. This paper presents the state of art hashing addition to the encryption of the data, we may also need algorithms including the security challenges for these hashing authentication and data integrity checks for most of the algorithms. It also covers the latest research on parallel situations in the dynamic context [2]. The development of implementations of these cryptographic algorithms. We present cryptographic hashing algorithms, to ensure authentication an analysis of serial and parallel implementations of these and data integrity services as part of ensuring information algorithms, both in hardware and in software, including an analysis of the performance and the level of protection offered security, has been an active area of research. against attacks on the algorithms. For ensuring data integrity, SHA-1[1] and MD5[1] are the most common hashing algorithms being used in various Index Terms—Cryptographic Hash Function, Parallel types of applications.
    [Show full text]
  • On Probabilities of Hash Value Matches
    Printer - please drop in Elsevier (tree) logo Computers 8 Security Vol. 17, No.2, pp. 171- 174, 1998 0 1998 Elsevier Science Limited All rights reserved. Printed in Great Britain 0167-4048/98 $19.00 On Probabilities of Hash Value Matches Mohammad Peyraviana, Allen Roginskya, Ajay Kshemkalyanib alBM Corporation, Research Triangle Park, NC 27709, USA bECECS Detlartment. University of Cincinnati, Cincinnati, OH 45221, USAL ’ ‘ _ Hash functions are used in authentication and cryptography, as hash function is said to be collision resistant if it is hard well as for the efficient storage and retrieval of data using hashed to find two input strings that map to the same hash keys. Hash functions are susceptible to undesirable collisions. To design or choose an appropriate hash function for an application, value.The problem of constructing fast hash functions it is essential to estimate the probabilities with which these colli- that also have low collision rates is studied in [S]. Key- sions can occur. In this paper we consider two problems: one of to-address transformation techniques for file access evaluating the probability of no collision at all and one of finding and their performance have been studied in [8]. Given a bound for the probability of a collision with a particular hash k, the number of hashed values that have been used in value. The quality of these estimates under various values of the parameters is also discussed. a hashing scheme in which input strings are mapped to random values, the expected number of locations Keywords: hash functions, security, cryptography, indexing, databases that must be looked at until an empty hashed value is found is formulated in [lo].
    [Show full text]
  • Lab 1: Classical Cryptanalysis and Attacking Cryptographic Hashes
    CS 588 Released January 24, 2016. Last updated January 24, 2017. Network Security Lab 1: Classical Cryptanalysis and Attacking Cryptographic Hashes Lab 1: Classical Cryptanalysis and Attacking Cryptographic Hashes This lab is due on February 7, 2016 at 11:59PM, following the submission checklist below. Late submissions will be penalized according to course policy. Your writeup MUST include the following information: 1. List of collaborators (on all parts of the project, not just the writeup) 2. List of references used (online material, course nodes, textbooks, wikipedia,...) 3. Number of late days used on this assignment 4. Total number of late days used thus far in the entire semester If any of this information is missing, at least 20% of the points for the assignment will automatically be deducted from your assignment. See also discussion on plagiarism and the collaboration policy on the course syllabus. While we provide you with the tools to run this lab at any platform (Windows, Linux and Mac OS), I strongly recommend working at a Linux or Mac OS machine as it will make things considerably easier for you. The instructions given for the rest of the description of the lab are therefore explicitly for this case (unless otherwise noted). Administration: This lab will be administered by Sophia Yakoubov. Introduction In Section1 of this lab, you will break two classical ciphers: the substitution cipher and the Vigenere cipher. In the rest of the lab, you will investigate vulnerabilities in widely used cryptographic hash functions, including length-extension attacks and collision vulnerabilities. In Section2, we will guide you through attacking the authentication capability of an imaginary server API.
    [Show full text]
  • Design and Analysis of Hash Functions What Is a Hash Function?
    Design and analysis of hash functions Coding and Crypto Course October 20, 2011 Benne de Weger, TU/e what is a hash function? • h : {0,1}* {0,1}n (general: h : S {{,}0,1}n for some set S) • input: bit string m of arbitrary length – length may be 0 – in practice a very large bound on the length is imposed, such as 264 (≈ 2.1 million TB) – input often called the message • output: bit string h(m) of fixed length n – e.g. n = 128, 160, 224, 256, 384, 512 – compression – output often called hash value, message digest, fingerprint • h(m) is easy to compute from m • no secret information, no key October 20, 2011 1 1 non-cryptographic hash functions • hash table – index on database keys – use: efficient storage and lookup of data • checksum – Example: CRC – Cyclic Redundancy Check • CRC32 uses polynomial division with remainder • initialize: – p = 1 0000 0100 1100 0001 0001 1101 1011 0111 – append 32 zeroes to m • repeat until length (counting from first 1-bit) ≤ 32: – left-align p to leftmost nonzero bit of m – XOR p into m – use: error detection • but only of unintended errors! • non-cryptographic – extremely fast – not secure at all October 20, 2011 2 hash collision • m1, m2 are a collision for h if h(m1) = h(m2) while m1 ≠ m2 I owe you € 100 I owe you € 5000 different documents • there exist a lot of identical hash collisions = – pigeonhole principle collision (a.k.a. Schubladensatz) October 20, 2011 3 2 preimage • given h0, then m is a preimage of h0 if h(m) = h0 X October 20, 2011 4 second preimage • given m0, then m is a second preimage of m0 if h(m) = h(m0 ) while m ≠ m0 ? X October 20, 2011 5 3 cryptographic hash function requirements • collision resistance: it should be computationally infeasible to find a collision m1, m2 for h – i.e.
    [Show full text]
  • The Second Cryptographic Hash Workshop
    Workshop Report The Second Cryptographic Hash Workshop University of California, Santa Barbara August 24-25, 2006 Report prepared by James Nechvatal and Shu-jen Chang Information Technology Laboratory, National Institute of Standards and Technology, Gaithersburg, MD 20899 Available online: http://csrc.nist.gov/groups/ST/hash/documents/SecondHashWshop_2006_Report.pdf 1. Introduction The Second Cryptographic Hash Workshop was held on Aug. 24-25, 2006, at University of California, Santa Barbara, in conjunction with Crypto 2006. 210 members of the global cryptographic community attended the workshop. The workshop was organized to encourage hash function research and discuss hash function development strategy. 2. Workshop Program The workshop program consisted of a day and a half of presentations of papers that were submitted to the workshop and panel discussion sessions. The main topics of the workshop included survey of hash function applications, new structures and designs of hash functions, cryptanalysis and attack tools, and development strategy of new hash functions. The program is available at http://csrc.nist.gov/groups/ST/hash/second_workshop.html . This report only briefly summarizes the presentations, because the above web site for the program includes links to the speakers' slides and papers. The main ideas of the discussion sessions, however, are described in considerable detail; in fact, the panelists and attendees are often paraphrased very closely, to minimize misinterpretation. Their statements are not necessarily presented in the order that they occurred, in order to organize them according to NIST's questions for each session. 3. Session Summary Session 1: Papers - New Structures of Hash Functions Session 1 included three talks dealing with new structures of hash functions.
    [Show full text]
  • Hashing Credit Card Numbers: Unsafe Application Practices 1 Copyright © 2007 Integrigy Corporation   INTEGRIGY
    INTEGRIGY February 27, 2007 Security Analysis Hashing Credit Card Numbers: Unsafe Application Practices OVERVIEW Cryptographic hash functions seem to be an ideal method for protecting and securely storing credit card numbers in ecommerce and payment applications [1]. A hash function generates a secure, one-way digital fingerprint that is irreversible and meets frequent business requirements for searching and matching of card numbers. However, due to the predictability of credit card numbers and common business requirements in processing credit cards, ecommerce and payment applications may implement such hashing of card numbers in an unsafe manner that allows an attacker to obtain a large percentage of card numbers by brute forcing compromised hashes in a matter of hours. This paper is an analysis of actual application practices for storing of credit card number hashes and a review of brute force attack methods against such hashes. The concepts presented in this paper have been broadly described prior by Kurt Seifried in 2001 [2], John Deters in 2002 [3], Branden Williams in 2006 [4], and many others, nevertheless some ecommerce and payment applications store credit card numbers in unsafe and easily brute forced ways. The impetus for this paper was identification of this issue during multiple application security assessments. The objective is to highlight the weakness of common credit card hashing techniques and to educate application architects and programmers on the issues of storing credit card numbers as hashes. PCI, CARD NUMBERS, AND BUSINESS REQUIREMENTS 1. P AYMENT CARD INDUSTRY DATA S ECURITY S TANDARD PCI DSS Requirement 3.4 – Render [credit card numbers], at minimum, unreadable anywhere it is stored (including data on portable digital media, backup media, in logs, and data received from or stored by wireless networks) by using any of the following approaches: .
    [Show full text]