Date: Wed, 14 Jan 2015 00:20:19 -0800 From: 'Gleb Kurtsou' <gleb@freebsd.org> To: rozhuk.im@gmail.com Cc: freebsd-hackers@freebsd.org, freebsd-geom@FreeBSD.org, 'Adam Nowacki' <nowakpl@platinum.linux.pl> Subject: Re: ChaCha8/12/20 and GEOM ELI tests Message-ID: <20150114082019.GA3669@reks> In-Reply-To: <54b601ec.0515980a.0c9c.47e1@mx.google.com> References: <54b33bfa.e31b980a.3e5d.ffffc823@mx.google.com> <54B4AE55.9090205@platinum.linux.pl> <54b5d299.4914980a.61cd.43a6@mx.google.com> <20150114041708.GA3189@reks> <54b601ec.0515980a.0c9c.47e1@mx.google.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On (14/01/2015 08:43), rozhuk.im@gmail.com wrote: > > On (14/01/2015 05:21), rozhuk.im@gmail.com wrote: > > > > Maybe faster but a stream cipher is unusable for disk encryption - > > > > iv is derived from sector number and doesn't change. Being able to > > > > write a known plaintext and read resulting ciphertext allows you to > > > > recover the cipher stream and decrypt any past or future data > > stored > > > > on that sector. > > > > > > Depends on the capabilities of the attacker. > > > > > > To be able to continuously read encrypted sectors for data collection > > > is too much. > > > > I disagree. It's the most basic attack scenario. Assuming attacker was > > able to get access to encrypted disk once, odds are high it may happen > > again. > > From different types of threats, there are various means of protection. > AES-XTC more universal solution, encryption ChaSha more specialized. > Each solution has its pluses and minuses. "various means of protection" is rather confusing. It's either acceptable for disk encryption or not. > AES too slow for me, and options when someone magically going to read my encrypted disk excluded. > In my particular case. It's widely accepted threat model (as was also mentioned elsewhere). So it's rather your particular use case that has magic vibe to it. > I think there will a lot of cases when you need the maximum speed of encryption and all the other factors are not important or unlikely. > > For example, the value of the data may be too low to take the time to decrypt, and the data can be very much and you want to write them down quickly. > > > > > Ability to read encrypted sectors has a transmission network, for > > example when the container=disk is stored somewhere in the cloud. > > > > > > In many cases, the attacker gets Encrypted disk along with other > > equipment, often in the off state. > > > Without encryption keys and the ability to write / read through the > > GELI. > > > > > > I do not see any weaknesses stream ciphers in cases when the attacker > > is not able to access the disk when it is mounted in the GEOM GELI. > > > > > > Another possibility is the use of ChaCha (without XTS) - encryption > > > swap file: there every time a new key is generated, besides the speed > > > is particularly important. > > > > Stream cipher (or similarly functioning block cipher mode) should not > > be used for disk encryption. IMHO swap encryption hardly justifies > > adding insecure encryption mode to geli. Fast swap is certainly nice to > > have, but rather remains a snake oil, system will remain trashed due to > > swapping no matter how fast swap is. > > Can you describe what is weak encryption swap with ChaCha? Stream cipher, as is, is not acceptable for disk encryption. I think we all agree on that. It remains secure as soon as the same key stream is not used twice. By writing data to the same sector one breaks this requirement. I'm not objecting that there is a possibility of building swap encryption on top of stream cipher, but that is likely not to be trivial and would require careful design review. Although I don't see how block device "encrypted" with stream cipher can be secure under assumption that attacker has access to the disk. > > > These aspects of the application must necessarily be reflected in the > > documentation. > > > > > > > > > There are objections to add ChaCha and XChaCha (without XTS) in GEOM > > GELI? > > > > I strongly object. > > Adam Nowacki already explained why XTS can not be used with ChaCha, I realized my mistake. > Now talking about ChaCha/XChaCha without(!!!) XTS. Badly broken for me :) BTW You may want to get rid of SHA in g_eli_crypto_ivgen() for ChaCha in pursue for yet higher performance. As far as I remember Salsa20 has this nice property of letting one start encryption from arbitrary offset in the stream, I assumed that you are using the same in ChaCha for geli. Although having looked at the code it is not that obvious what is going on. There is a method to set iv being used, but not to change counter (stream offset). Is that intentional? Do we reset key for each geli sector to be encrypted? P.S. My objection should only be considered merely my personal opinion. You might have better luck contacting security team directly.
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20150114082019.GA3669>