http://bugs.winehq.org/show_bug.cgi?id=30719
Bug #: 30719 Summary: SmartFTP 4.0 crashes on startup (crypt32 CertCreateSelfSignCertificate failure) Product: Wine Version: 1.5.4 Platform: x86 OS/Version: Linux Status: NEW Severity: normal Priority: P2 Component: crypt32 AssignedTo: wine-bugs@winehq.org ReportedBy: focht@gmx.net Classification: Unclassified
Hello,
split off from bug 13487
--- snip --- 0024:Call crypt32.CertStrToNameW(00010001,0015c5ec L"CN=SmartFTP Client",00000003,00000000,00000000,0032f9dc,00000000) ret=00723b8e 0024:trace:crypt:CertStrToNameW (00010001, L"CN=SmartFTP Client", 00000003, (nil), (nil), 0x32f9dc, (nil)) 0024:trace:crypt:CRYPT_KeynameKeeperFromTokenW Keyname is L"CN" 0024:trace:crypt:CryptFindOIDInfo (2, 0x32f8b4, 5) 0024:trace:crypt:CryptFindOIDInfo CRYPT_OID_INFO_NAME_KEY: L"CN" ... 0024:trace:crypt:CRYPT_GetNextValueW (L"SmartFTP Client", L"+,;\r\n", 0x32f8ac, (nil)) 0024:trace:crypt:CRYPT_ValueToRDN OID "2.5.4.3", value L"SmartFTP Client" ... 0024:trace:crypt:CryptEncodeObjectEx returning 1 ... 0024:Ret crypt32.CertStrToNameW() retval=00000001 ret=00723bf4 ... 0024:Call advapi32.CryptAcquireContextW(0032f9e0,0129d130 L"{51BD5987-103F-42DD-9AC0-E7C13D2B7491}",00841f90 L"Microsoft Enhanced Cryptographic Provider v1.0",00000001,00000008) ret=00723dfc 0024:trace:crypt:CryptAcquireContextW (0x32f9e0, L"{51BD5987-103F-42DD-9AC0-E7C13D2B7491}", L"Microsoft Enhanced Cryptographic Provider v1.0", 1, 00000008) 0024:Call rsaenh.CPAcquireContext(00162608,001626e8 "{51BD5987-103F-42DD-9AC0-E7C13D2B7491}",00000008,00162688) ret=7ea3fd12 0024:trace:crypt:RSAENH_CPAcquireContext (phProv=0x162608, pszContainer="{51BD5987-103F-42DD-9AC0-E7C13D2B7491}", dwFlags=00000008, pVTable=0x162688) 0024:Call advapi32.RegOpenKeyExA(80000001,0032f4d8 "Software\Wine\Crypto\RSA\{51BD5987-103F-42DD-9AC0-E7C13D2B7491}",00000000,00020019,0032f620) ret=7d482083 ... 0024:Ret rsaenh.CPAcquireContext() retval=00000001 ret=7ea3fd12 0024:Ret advapi32.CryptAcquireContextW() retval=00000001 ret=00723dfc 0024:Call advapi32.CryptGenKey(001625f8,00000001,04000001,0032f9f0) ret=00723eb3 0024:trace:crypt:CryptGenKey (0x1625f8, 1, 04000001, 0x32f9f0) 0024:Call rsaenh.CPGenKey(00000003,00000001,04000001,0015c988) ret=7ea41b3d 0024:trace:crypt:RSAENH_CPGenKey (hProv=00000003, aiAlgid=1, dwFlags=04000001, phKey=0x15c988) 0024:trace:crypt:new_key alg = "RSA_KEYX", dwKeyLen = 1024 ... 0024:Call crypt32.CertCreateSelfSignCertificate(001625f8,0032fa2c,00000000,0032fa10,00000000,00000000,0032fa54,00000000) ret=0072405a 0024:trace:crypt:CertCreateSelfSignCertificate (001625f8, 0x32fa2c, 00000000, 0x32fa10, (nil), (nil), (nil), (nil)) 0024:Ret crypt32.CertCreateSelfSignCertificate() retval=00000000 ret=0072405a 0024:Call KERNEL32.GetLastError() ret=004096e6 0024:Ret KERNEL32.GetLastError() retval=00000057 ret=004096e6 ... 0024:CALL MSVCR100._CxxThrowException(<unknown, check return>) ret=78812829 0024:Call KERNEL32.RaiseException(e06d7363,00000001,00000003,0032f990) ret=78ac872d 0024:trace:seh:raise_exception code=e06d7363 flags=1 addr=0x7b8393ff ip=7b8393ff tid=0024 0024:trace:seh:raise_exception info[0]=19930520 0024:trace:seh:raise_exception info[1]=0032f9b4 0024:trace:seh:raise_exception info[2]=78874578 0024:trace:seh:raise_exception eax=7b826429 ebx=7b8b06b0 ecx=19930520 edx=0032f894 esi=0032f97c edi=0032f8f0 0024:trace:seh:raise_exception ebp=0032f8d8 esp=0032f874 cs=0023 ds=002b es=002b fs=0063 gs=006b flags=00000283 ... --- snip ---
$ du -sh SFTPMSI.exe 15M SFTPMSI.exe
$ sha1sum SFTPMSI.exe b4d672c3fc0ca279790b8927e9d57930a1bbbb60 SFTPMSI.exe
$ wine --version wine-1.5.4-185-g6c51c1b
Regards
http://bugs.winehq.org/show_bug.cgi?id=30719
Anastasius Focht focht@gmx.net changed:
What |Removed |Added ---------------------------------------------------------------------------- Keywords| |download URL| |http://www.smartftp.com/
http://bugs.winehq.org/show_bug.cgi?id=30719
--- Comment #1 from Juan Lang juan.lang@gmail.com 2012-05-18 17:35:23 CDT --- Created attachment 40221 --> http://bugs.winehq.org/attachment.cgi?id=40221 Patch: Don't fail if HCRYPTPROV and PCRYPT_KEY_PROV_INFO parameters are both non-NULL
Thanks AF. Does this patch help? The app still crashes for me, and for whatever reason I don't get a backtrace here.
http://bugs.winehq.org/show_bug.cgi?id=30719
--- Comment #2 from Juan Lang juan.lang@gmail.com 2012-05-18 17:55:13 CDT --- (In reply to comment #1)
Thanks AF. Does this patch help? The app still crashes for me, and for whatever reason I don't get a backtrace here.
Answering my own question: no, it doesn't. I looked through my own seh,relay log and now I see instead:
--- snip --- 0009:Call advapi32.CryptGenKey(001711e8,00000001,04000001,0032fa20) ret=00723eb3 0009:Call rsaenh.CPGenKey(00000003,00000001,04000001,00171470) ret=7eb3cb1a --- snip ---
--- snip --- 0009:Ret rsaenh.CPGenKey() retval=00000001 ret=7eb3cb1a 0009:Ret advapi32.CryptGenKey() retval=00000001 ret=00723eb3 0009:Call KERNEL32.FileTimeToSystemTime(0032fa18,0032fa84) ret=0072401a 0009:Ret KERNEL32.FileTimeToSystemTime() retval=00000001 ret=0072401a 0009:Call crypt32.CertCreateSelfSignCertificate(001711e8,0032fa5c,00000000,0032fa40,00000000,00000000,0032fa84,00000000) ret=0072405a 0009:Call advapi32.CryptGetUserKey(001711e8,00000002,0032f70c) ret=7edbcaee 0009:Call rsaenh.CPGetUserKey(00000003,00000002,00171488) ret=7eb3c9db 0009:Ret rsaenh.CPGetUserKey() retval=00000000 ret=7eb3c9db 0009:Ret advapi32.CryptGetUserKey() retval=00000000 ret=7edbcaee 0009:Call ntdll.RtlAllocateHeap(00110000,00000000,00000000) ret=7edc78d6 0009:Ret ntdll.RtlAllocateHeap() retval=00171480 ret=7edc78d6 0009:Call advapi32.CryptGetUserKey(001711e8,00000002,0032f70c) ret=7edbcaee 0009:Call rsaenh.CPGetUserKey(00000003,00000002,00174b30) ret=7eb3c9db 0009:Ret rsaenh.CPGetUserKey() retval=00000000 ret=7eb3c9db 0009:Ret advapi32.CryptGetUserKey() retval=00000000 ret=7edbcaee 0009:Call ntdll.RtlFreeHeap(00110000,00000000,00171480) ret=7edc7866 0009:Ret ntdll.RtlFreeHeap() retval=00000001 ret=7edc7866 0009:Ret crypt32.CertCreateSelfSignCertificate() retval=00000000 ret=0072405a 0009:Call KERNEL32.GetLastError() ret=004096e6 0009:Ret KERNEL32.GetLastError() retval=8009000d ret=004096e6 0009:Call KERNEL32.RaiseException(e06d7363,00000001,00000003,0032f9c0) ret=78ac872d --- snip ---
In other words, the app generates an AT_KEYEXCHANGE key, but when it calls CertCreateSelfSignCertificate, it specifies the AT_SIGNATURE key, leading to a failure of NTE_NO_KEY. I'll have to have a closer look.
http://bugs.winehq.org/show_bug.cgi?id=30719
--- Comment #3 from Juan Lang juan.lang@gmail.com 2012-05-30 16:30:01 CDT --- Patches sent. The functional ones are: http://www.winehq.org/pipermail/wine-patches/2012-May/114643.html (This is the same as the patch attached here.) http://www.winehq.org/pipermail/wine-patches/2012-May/114647.html
http://bugs.winehq.org/show_bug.cgi?id=30719
Juan Lang juan.lang@gmail.com changed:
What |Removed |Added ---------------------------------------------------------------------------- Fixed by SHA1| |f86ab49be2a3f8ce778fb6ed5fa | |3e91e9ccfad75 Status|NEW |RESOLVED Resolution| |FIXED
--- Comment #4 from Juan Lang juan.lang@gmail.com 2012-05-31 13:41:07 CDT --- Fixed.
http://bugs.winehq.org/show_bug.cgi?id=30719
Alexandre Julliard julliard@winehq.org changed:
What |Removed |Added ---------------------------------------------------------------------------- Status|RESOLVED |CLOSED
--- Comment #5 from Alexandre Julliard julliard@winehq.org 2012-06-08 15:28:07 CDT --- Closing bugs fixed in 1.5.6.
http://bugs.winehq.org/show_bug.cgi?id=30719
Alexandre Julliard julliard@winehq.org changed:
What |Removed |Added ---------------------------------------------------------------------------- Target Milestone|--- |1.4.x
http://bugs.winehq.org/show_bug.cgi?id=30719
Alexandre Julliard julliard@winehq.org changed:
What |Removed |Added ---------------------------------------------------------------------------- Target Milestone|1.4.x |---
https://bugs.winehq.org/show_bug.cgi?id=30719
Anastasius Focht focht@gmx.net changed:
What |Removed |Added ---------------------------------------------------------------------------- URL|http://www.smartftp.com/ |https://web.archive.org/web | |/20210724115127/https://ido | |wnload.idg.pl/zx/vol2/w95/f | |tp/smartftp/4.0.1245/SFTPMS | |I32.exe?md5=6wxHQVYScmFEMPx | |AO8bIbw&expires=1627128058
--- Comment #6 from Anastasius Focht focht@gmx.net --- Hello folks,
adding stable download via Internet Archive for documentation.
https://web.archive.org/web/20210724115127/https://idownload.idg.pl/zx/vol2/...
$ sha1sum SFTPMSI32.exe b4d672c3fc0ca279790b8927e9d57930a1bbbb60 SFTPMSI32.exe
$ du -sh SFTPMSI32.exe 15M SFTPMSI32.exe
Regards