On Thu, Sep 16, 2021 at 8:42 PM austin clifton <austin.clif...@otoy.com> wrote: > > I have an issue which I believe may be a bug. I followed the instructions > from the "Bug Report" page on the cryptopp wiki and all tests in cryptest.exe > are passing, so figured I should post here first and make sure it isn't a > build related issue. > > I built cryptopp 8.5.0 as a static library, x64 multi-threaded debug (\MTd) > using Visual Studio 2019 v16.10.0, on Windows 10 Pro v10.0.19043, using the > .sln file provided with the cryptopp source code. > > I used two different machines for this test. One is the machine I built the > cryptopp library with. Both are running the same version of Windows 10. One > machine has a Ryzen 3700X, the other has an i7-990X. The Ryzen supports AVX, > the i7 does not. > > I am VERY rarely finding that files encrypted with the chacha cipher by these > two machines have differing sha256 hashes. If I do a hex diff against the > files, there is a single flipped bit at 0x1EBB4 (0xD8 vs 0xD9). > > I am able to reproduce this consistently with a specific key, nonce, and > input file, after test encrypting ~50GB of 1MB garbage files on each machine. > > If I disable AVX when building cryptlib by defining CRYPTOPP_DISABLE_AVX and > CRYPTOPP_DISABLE_AVX2, the machine with the Ryzen will encrypt the file the > same as the i7. > > Source code for a minimal reproducible example is here: > https://github.com/austin-clifton/cryptopp-chacha-asm-test/blob/main/src/main.cpp#L208 > > That repository includes a ready-to-build test case with Visual Studio, minus > a built cryptlib.lib which should be added to libs/debug/ before building.
Austin, I fetched main.cpp and run_459_file_76.bin from your GitHub. I compiled the library with: CXXFLAGS="-DNDEBUG -g2 -O3 -std=c++17" make I compiled/linked main.cpp with: g++ -DNDEBUG -g2 -O3 -fPIC -pthread -std=c++17 -I. main.cxx ./libcryptopp.a -o main.exe Running the program on a AMD Ryzen 3 3200U and AMD A6-9220e, this is the result. $ ./main.exe sha256: 0FC0FADCDF82770086C9DA8513A16FC785620D7B1C187CDD828E433EB0979847 encsha: 6FBEE484EE64A2AB02235DDF29CA0B61EE3B811D227C2729836D3BD6161C9B18 Is this correct? I have one Windows machine for testing. It is a Core i5. Sorry I don't have a good test environment. Jeff -- You received this message because you are subscribed to the Google Groups "Crypto++ Users" group. To unsubscribe from this group and stop receiving emails from it, send an email to cryptopp-users+unsubscr...@googlegroups.com. To view this discussion on the web visit https://groups.google.com/d/msgid/cryptopp-users/CAH8yC8k5HNWTq7%2BOx6d27gNh5YwKyi0kxxwDAvMf6QczPcsqhQ%40mail.gmail.com.