OCB mode

OCB mode (Offset Codebook Mode) is an authenticated encryption mode of operation for cryptographic block ciphers.[1][2] OCB mode was designed by Phillip Rogaway, who credits Mihir Bellare, John Black, and Ted Krovetz with assistance and comments on the designs. It is based on the authenticated encryption mode IAPM due to Charanjit S. Jutla. Its version OCB2 has proven insecure, while the original OCB1 as well as OCB3 from 2011 are still considered secure.

Encryption and authentication

OCB mode was designed to provide both message authentication and privacy. It is essentially a scheme for integrating a Message Authentication Code (MAC) into the operation of a block cipher. In this way, OCB mode avoids the need to use two systems: a MAC for authentication and encryption for privacy. This results in lower computational cost compared to using separate encryption and authentication functions.

There are three versions of OCB: OCB1, OCB2 and OCB3. OCB1 was published in 2001. OCB2 improves on OCB1 by allowing associated data to be included with the message (providing AEAD) that is, data that are not encrypted but should be authenticated and a new method for generating a sequence of offsets. OCB2 was first published in 2003, originally named AEM (Authenticated-Encryption Mode, or Advanced Encryption Mode) and was shown to be completely insecure in 2019 (see § Attacks below). OCB3, published in 2011, changes again the way offsets are computed and introduces minor performance improvements.

OCB mode is listed as an optional method in the IEEE 802.11 wireless security standard as an alternative to CCM. OCB2 is standardized in ISO/IEC 19772:2009[3] and a modified OCB3 in RFC 7253.[4] The RFC encodes the tag length into the internally formatted nonce.

Performance

OCB performance overhead is minimal compared to classical, non-authenticating modes like CBC. OCB requires one block cipher operation per block of encrypted and authenticated message, and one block cipher operation per block of associated data. There is also one extra block cipher operation required at the end of process.

For comparison, CCM mode offering similar functionality requires twice as many block cipher operations per message block (associated data requires one, as in OCB).

Patents

Two U.S. patents have been issued for OCB mode.[5] However, a special exemption is granted allowing OCB mode to be used in software licensed under the GNU General Public License without cost, as well as for any non-commercial, non-governmental application. This constraint has hindered approval by the US Federal Govt (NIST).[6]

Since the authors have only applied for patent protection in the U.S., the algorithm is free to use in software not developed and not sold inside the U.S.[7]

By January 2013, the author has granted a free license for any open source license certified by the Open Source Initiative.[8]

Attacks

Niels Ferguson pointed out collision attacks on OCB, which limits the amount of data that can be securely processed under a single key to about 280 terabytes.[9][10]

In October 2018, Inoue and Minematsu presented an existential forgery attack against OCB2 that requires only a single prior encryption query and almost no computational power or storage.[11] The attack does not extend to OCB1 or OCB3, and it requires that the associated data field of the forged ciphertext be empty. Poettering[12] and Iwata[13] improved the forgery attack to a full plaintext recovery attack just a couple of days later. The four authors later produced a joint report.[14]

gollark: MOOOO!
gollark: `(10/62)^5` - 10 is the number of numeric digits, 62 the total number of code-able characters, and codes are 5 chars long, so the chance of getting a single digit must be multiplied by itself 5 times for an all-number.
gollark: 0.01091544768% of codes are all-number, I *think*.
gollark: I wonder why people put `DM me` in their IOU trades in <#334633989115609098>.
gollark: My green grew up! Finally, I can use that really useful BSA, `Earthquake`.

See also

References

  1. Ted Krovetz, Phillip Rogaway (July 23, 2012). "The OCB Authenticated-Encryption Algorithm". Retrieved May 28, 2012.
  2. Phillip Rogaway. "OCB Mode". Retrieved May 28, 2012.
  3. "ISO/IEC 19772:2009 Information technology -- Security techniques -- Authenticated encryption". ISO. 2009-02-12. Retrieved May 28, 2012.
  4. "The OCB Authenticated-Encryption Algorithm". IETF. 2014.
  5. Phillip Rogaway. "OCB FAQ - Is OCB Patented". Retrieved May 28, 2012.
  6. https://csrc.nist.gov/projects/computer-security-objects-register/algorithm-registration#AES
  7. Phillip Rogaway (29 March 2005). "OCB: Offer Letter". Retrieved May 28, 2012.
  8. Phillip Rogaway (9 January 2013). "OCB: free licenses".
  9. Niels Ferguson (2002-02-11). "Collision attacks on OCB" (PDF).
  10. Phillip Rogaway (2015-02-27). "OCB: Background".
  11. Akiko Inoue and Kazuhiko Minematsu (2018-10-26). "Cryptanalysis of OCB2".
  12. Bertram Poettering (2018-11-08). "Breaking the confidentiality of OCB2".
  13. Tetsu Iwata (2018-11-11). "Plaintext Recovery Attack of OCB2".
  14. "Cryptanalysis of OCB2: Attacks on Authenticity and Confidentiality". 2019-03-19.
This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.