MOSQUITO
In cryptography, MOSQUITO was a stream cipher algorithm designed by Joan Daemen and Paris Kitsos. They submitted it to the eSTREAM project, which was a part of eCRYPT. While presenting it in a document published in 2005, they explained some of their design intentions:
Self-synchronizing stream encryption can be performed by using a block cipher in CFB mode. However, for single-bit self-synchronizing stream encryption, this is very inefficient. Therefore we believe that it would be useful to design a dedicated self-synchronizing stream cipher that is efficient in hardware.[1]
It was subsequently broken by Antoine Joux and Frédéric Muller in 2006, who had this to say in their conference paper:
All the dedicated Self-Synchronizing Stream Ciphers (SSSC) of the KNOT-MOSQUITO family are subject to differential chosen ciphertext attacks. Our results, combined with previous results on HBB, KNOT and SSS show that it is extremely difficult to design a SSSC resistant against chosen-ciphertext attacks.[2]
A tweaked version named MOUSTIQUE was proposed[3] which made it to Phase 3 of the eSTREAM evaluation process as the only self-synchronizing cipher remaining, where it was noted that "in reaching the third phase of eSTREAM all the algorithms in this book have made a significant advance in the development of stream ciphers.[4]
However, MOUSTIQUE was subsequently broken by Käsper et al., leaving the design of a secure and efficient self-synchronizing stream cipher as an open research problem.[5]
Specifications
The MOSQUITO cipher has eight registers of varying lengths, let's call the register CCSR -, the first register -, second - and so on up to the seventh register -. We will designate the i-th position of register j as follows: . Register lengths:
CCSR — 128 bits;
- — 53 bits;
- — 12 bits;
- — 3 bits.
The essence of the cipher operation is to calculate, for each clock cycle, the bits of any of the registers (except CCSR) based on some combination of bits of the previous register. The CCSR register works as a shift register: the register elements are shifted, and a bit of the encrypted text (from the cipher output) is written to the zero position of the CCSR register. Let us denote by the rule by which the bit in the i-th position in register j is calculated. Then:
- , где ;
- , где и , if the subscript of any element on the right side of the equality becomes greater than 53, then this element is replaced by 0;
- , где ;
- , где ;
and finally the keystream bit .
It is worth noting that the calculation of register bits is performed using combinational logic, and the shift, naturally, using register logic, which means that in order to prevent incorrect operation of the pipeline, when the bits from the register do not have time to be processed by combinational logic, it is necessary that the function , implementing the calculations was relatively simple..
References
- ^ Daemen, Joan; Kitsos, Paris (April 29, 2005). "Submission to ECRYPT call for stream ciphers: the self-synchronizing stream cipher Mosquito" (PDF). cr.yp.to. Retrieved March 1, 2025.
- ^ Joux, Antoine; Muller, Frédéric (2006). Robshaw, Matthew (ed.). "Chosen-Ciphertext Attacks Against MOSQUITO". Fast Software Encryption. Berlin, Heidelberg: Springer: 390–404. doi:10.1007/11799313_25. ISBN 978-3-540-36598-3.
- ^ Daemen, Joan; Kitsos, Paris (19 June 2008). "The Self-synchronizing Stream Cipher: Moustique". In Robshaw, Matthew; Billet, Olivier (eds.). New Stream Cipher Designs: The eSTREAM Finalists. Springer Berlin, Heidelberg. pp. 210–223. doi:10.1007/978-3-540-68351-3_16. ISBN 978-3-540-68351-3.
- ^ Robshaw, Matthew; Billet, Olivier, eds. (19 June 2008). "The eSTREAM Project". New Stream Cipher Designs: The eSTREAM Finalists. Springer Berlin, Heidelberg. pp. 1–6. doi:10.1007/978-3-540-68351-3_1. ISBN 978-3-540-68351-3.
- ^ Käsper, Emilia; Rijmen, Vincent; Bjørstad, Tor E.; Rechberger, Christian; Robshaw, Matt; Sekar, Gautham (31 May 2008). Vaudenay, Serge (ed.). Progress in Cryptology - AFRICACRYPT 2008: First International Conference on Cryptology in Africa, Casablanca, Morocco, June 11-14, 2008, Proceedings. Lecture Notes in Computer Science. Springer Berlin, Heidelberg. pp. 246–257. doi:10.1007/978-3-540-68164-9_17. ISBN 978-3-540-68164-9. ISSN 0302-9743.
