2014-06-29 00:04:49 +04:00
|
|
|
|
|
|
|
#include <winpr/crt.h>
|
|
|
|
#include <winpr/print.h>
|
Winpr/openssl: Fix digests initialization in multi-thread
SSL functions like OpenSSL_add_all_digests should be invoked at very beginning as they are not MT safe.
If not we might meet double free exception as following:
#0 0x00007f23ddd71c37 in raise () from /lib/x86_64-linux-gnu/libc.so.6
#1 0x00007f23ddd75028 in abort () from /lib/x86_64-linux-gnu/libc.so.6
#2 0x00007f23dddae2a4 in ?? () from /lib/x86_64-linux-gnu/libc.so.6
#3 0x00007f23dddba55e in ?? () from /lib/x86_64-linux-gnu/libc.so.6
#4 0x00007f23dc6ecfcd in CRYPTO_free () from /lib/x86_64-linux-gnu/libcrypto.so.1.0.0
#5 0x00007f23dc6ef8d1 in OBJ_NAME_add () from /lib/x86_64-linux-gnu/libcrypto.so.1.0.0
#6 0x00007f23dc77dcd8 in EVP_add_digest () from /lib/x86_64-linux-gnu/libcrypto.so.1.0.0
#7 0x00007f23dc782321 in OpenSSL_add_all_digests () from /lib/x86_64-linux-gnu/libcrypto.so.1.0.0
#8 0x00007f23c781da28 in winpr_openssl_get_evp_md (md=4) at /home/zihao/workspace/zihao_FreeRDP/winpr/libwinpr/crypto/hash.c:52
#9 0x00007f23c781dccb in winpr_Digest_Init (ctx=0x7f22d064d470, md=<optimized out>) at /home/zihao/workspace/zihao_FreeRDP/winpr/libwinpr/crypto/hash.c:344
#10 0x00007f23d486139b in security_salted_mac_signature (rdp=0x7f23859f5a20, data=0x7f238542d4fb "\004\204\022\004", length=4743, encryption=<optimized out>, output=0x7
at /home/zihao/workspace/zihao_FreeRDP/libfreerdp/core/security.c:378
#11 0x00007f23d488d73f in fastpath_send_update_pdu (fastpath=<optimized out>, updateCode=4 '\004', s=0x7f23859f5f40, skipCompression=true)
at /home/zihao/workspace/zihao_FreeRDP/libfreerdp/core/fastpath.c:1076
#12 0x00007f23d4891c4f in update_send_surface_frame_bits (context=0x7f23859f5540, cmd=0x7f22b2ffcc80, first=true, last=true, frameId=6)
at /home/zihao/workspace/zihao_FreeRDP/libfreerdp/core/update.c:1041
Related reports: https://rt.openssl.org/Ticket/Display.html?id=2216&user=guest&pass=guest
2016-12-26 17:21:36 +03:00
|
|
|
#include <winpr/ssl.h>
|
2014-06-29 00:04:49 +04:00
|
|
|
|
2014-06-30 17:40:24 +04:00
|
|
|
#include <freerdp/assistance.h>
|
2014-06-29 00:04:49 +04:00
|
|
|
|
2015-06-24 11:02:30 +03:00
|
|
|
const char TEST_MSRC_INCIDENT_PASSWORD_TYPE1[] = "Password1";
|
2014-06-29 00:04:49 +04:00
|
|
|
|
2015-06-24 11:02:30 +03:00
|
|
|
static const char TEST_MSRC_INCIDENT_FILE_TYPE1[] =
|
2014-06-29 20:36:28 +04:00
|
|
|
"<?xml version=\"1.0\" encoding=\"Unicode\" ?>"
|
|
|
|
"<UPLOADINFO TYPE=\"Escalated\">"
|
|
|
|
"<UPLOADDATA "
|
|
|
|
"USERNAME=\"Administrator\" "
|
|
|
|
"RCTICKET=\"65538,1,10.0.3.105:3389;winxpsp3.contoso3.com:3389,*,"
|
|
|
|
"rb+v0oPmEISmi8N2zK/vuhgul/ABqlDt6wW0VxMyxK8=,*,*,IuaRySSbPDNna4+2mKcsKxsbJFI=\""
|
|
|
|
"RCTICKETENCRYPTED=\"1\" "
|
|
|
|
"DtStart=\"1314905741\" "
|
|
|
|
"DtLength=\"180\" "
|
|
|
|
"PassStub=\"RT=0PvIndan52*\" "
|
|
|
|
"L=\"0\" />"
|
|
|
|
"</UPLOADINFO>";
|
|
|
|
|
2014-06-30 02:48:37 +04:00
|
|
|
const BYTE TEST_MSRC_INCIDENT_EXPERT_BLOB_TYPE1[32] =
|
|
|
|
"\x3C\x9C\xAE\x0B\xCE\x7A\xB1\x5C\x8A\xAC\x01\xD6\x76\x04\x5E\xDF"
|
|
|
|
"\x3F\xFA\xF0\x92\xE2\xDE\x36\x8A\x20\x17\xE6\x8A\x0D\xED\x7C\x90";
|
|
|
|
|
2015-06-24 11:02:30 +03:00
|
|
|
const char TEST_MSRC_INCIDENT_PASSWORD_TYPE2[] = "48BJQ853X3B4";
|
2014-06-29 20:36:28 +04:00
|
|
|
|
2015-06-24 11:02:30 +03:00
|
|
|
static const char TEST_MSRC_INCIDENT_FILE_TYPE2[] =
|
2014-06-29 00:04:49 +04:00
|
|
|
"<?xml version=\"1.0\"?>"
|
|
|
|
"<UPLOADINFO TYPE=\"Escalated\">"
|
|
|
|
"<UPLOADDATA USERNAME=\"awake\" "
|
|
|
|
"LHTICKET=\""
|
|
|
|
"20FCC407AA53E95F8505AB56D485D26835064B03AF86CDA326248FD304626AD4"
|
|
|
|
"DBDBDFFE0C473228EFFF7A1E6CEB445BBEC429294BB6616BBB600854438DDFB5"
|
|
|
|
"82FC377CF65A2060EB3221647643C9B29BF5EC320856180B34D1BE9827A528C7"
|
|
|
|
"E8F0DCD53C8D38F974160FEE317458FAC9DBDBA7B972D21DF3BC5B1AF0E01878"
|
|
|
|
"65F07A3B915618C03E6EAF843FC1185770A1208C29C836DBCA5A040CB276D3C4"
|
|
|
|
"1DDE2FA8CA9627E5E74FA750A92C0E01AD6C3D1000A5B1479DEB899BF5BCD402"
|
|
|
|
"CE3BB3BF104CE0286C3F985AA711943C88C5EEEEE86F35B63F68883A90ADBCFD"
|
|
|
|
"CBBAE3EAB993EFD9148E1A21D092CE9498695943946236D65D20B4A38D724C61"
|
|
|
|
"72319E38E19C04E98EBC03F56A4A190E971F8EAEBFE6B415A3A2D8F35F7BF785"
|
|
|
|
"26B9BFAAB48D11BDD6C905EFE503D2265678E1EAD2F2F124E570667F04103180"
|
|
|
|
"2F63587276C14E6A5AB436CE234F722CE7C9B5D244508F14C012E84A49FE6992"
|
|
|
|
"3F30320ABB3641F1EFA66205F3EA709E7E1C3E6874BB9642486FB96D2730CDF4"
|
|
|
|
"514AA738167F00FC13B2978AED1D6678413FDF62008B03DD729E36173BE02742"
|
|
|
|
"B69CAD44938512D0F56335394759338AF6ADBCF39CE829116D97435085D05BB5"
|
|
|
|
"9320A134698050DCDBE01305A6B4712FD6BD48958BD2DC497498FF35CAECC9A8"
|
|
|
|
"2C97FD1A5B5EC4BAF5FFB75A1471B765C465B35A7C950019066BB219B391C6E9"
|
|
|
|
"8AE8FD2038E774F36F226D9FB9A38BCC313785612165D1EF69D19E2B9CF6E0F7"
|
|
|
|
"FE1ECCF00AB81F9E8B626363CA82FAC719A3B7D243325C9D6042B2488EC95B80"
|
|
|
|
"A31273FF9B72FBBB86F946E6D3DF8816BE4533F0B547C8BC028309EA9784C1E6\" "
|
|
|
|
"RCTICKET=\"65538,1,192.168.1.200:49230;169.254.6.170:49231,*,"
|
|
|
|
"+ULZ6ifjoCa6cGPMLQiGHRPwkg6VyJqGwxMnO6GcelwUh9a6/FBq3It5ADSndmLL,"
|
|
|
|
"*,*,BNRjdu97DyczQSRuMRrDWoue+HA=\" "
|
|
|
|
"PassStub=\"WB^6HsrIaFmEpi\" "
|
|
|
|
"RCTICKETENCRYPTED=\"1\" "
|
|
|
|
"DtStart=\"1403972263\" "
|
|
|
|
"DtLength=\"14400\" "
|
|
|
|
"L=\"0\"/>"
|
|
|
|
"</UPLOADINFO>";
|
|
|
|
|
2014-06-30 04:38:33 +04:00
|
|
|
/**
|
|
|
|
* Decrypted Connection String 2:
|
|
|
|
*
|
|
|
|
* <E>
|
|
|
|
* <A KH="BNRjdu97DyczQSRuMRrDWoue+HA=" ID="+ULZ6ifjoCa6cGPMLQiGHRPwkg6VyJqGwxMnO6GcelwUh9a6/FBq3It5ADSndmLL"/>
|
|
|
|
* <C>
|
|
|
|
* <T ID="1" SID="0">
|
|
|
|
* <L P="49228" N="fe80::1032:53d9:5a01:909b%3"/>
|
|
|
|
* <L P="49229" N="fe80::3d8f:9b2d:6b4e:6aa%6"/>
|
|
|
|
* <L P="49230" N="192.168.1.200"/>
|
|
|
|
* <L P="49231" N="169.254.6.170"/>
|
|
|
|
* </T>
|
|
|
|
* </C>
|
|
|
|
* </E>
|
|
|
|
*/
|
|
|
|
|
2014-06-29 20:36:28 +04:00
|
|
|
int test_msrsc_incident_file_type1()
|
|
|
|
{
|
|
|
|
int status;
|
2014-06-30 20:51:27 +04:00
|
|
|
char* pass;
|
|
|
|
char* expertBlob;
|
2014-06-29 20:36:28 +04:00
|
|
|
rdpAssistanceFile* file;
|
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
file = freerdp_assistance_file_new();
|
2014-06-29 20:36:28 +04:00
|
|
|
|
2015-06-17 23:08:02 +03:00
|
|
|
if (!file)
|
|
|
|
return -1;
|
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
status = freerdp_assistance_parse_file_buffer(file,
|
2014-06-29 20:36:28 +04:00
|
|
|
TEST_MSRC_INCIDENT_FILE_TYPE1, sizeof(TEST_MSRC_INCIDENT_FILE_TYPE1));
|
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
printf("freerdp_assistance_parse_file_buffer: %d\n", status);
|
2014-06-29 20:36:28 +04:00
|
|
|
|
|
|
|
if (status < 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
printf("Username: %s\n", file->Username);
|
|
|
|
printf("LHTicket: %s\n", file->LHTicket);
|
|
|
|
printf("RCTicket: %s\n", file->RCTicket);
|
2016-12-14 00:47:08 +03:00
|
|
|
printf("RCTicketEncrypted: %"PRId32"\n", file->RCTicketEncrypted);
|
2014-06-29 20:36:28 +04:00
|
|
|
printf("PassStub: %s\n", file->PassStub);
|
2016-12-14 00:47:08 +03:00
|
|
|
printf("DtStart: %"PRIu32"\n", file->DtStart);
|
|
|
|
printf("DtLength: %"PRIu32"\n", file->DtLength);
|
|
|
|
printf("LowSpeed: %"PRId32"\n", file->LowSpeed);
|
2014-06-29 20:36:28 +04:00
|
|
|
|
|
|
|
printf("RASessionId: %s\n", file->RASessionId);
|
|
|
|
printf("RASpecificParams: %s\n", file->RASpecificParams);
|
|
|
|
printf("MachineAddress: %s\n", file->MachineAddress);
|
2016-12-14 00:47:08 +03:00
|
|
|
printf("MachinePort: %"PRIu32"\n", file->MachinePort);
|
2014-06-29 20:36:28 +04:00
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
status = freerdp_assistance_decrypt(file, TEST_MSRC_INCIDENT_PASSWORD_TYPE1);
|
2014-06-29 20:36:28 +04:00
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
printf("freerdp_assistance_decrypt: %d\n", status);
|
2014-06-29 20:36:28 +04:00
|
|
|
|
|
|
|
if (status < 0)
|
|
|
|
return -1;
|
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
pass = freerdp_assistance_bin_to_hex_string(file->EncryptedPassStub, file->EncryptedPassStubLength);
|
|
|
|
|
|
|
|
if (!pass)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
expertBlob = freerdp_assistance_construct_expert_blob("Edgar Olougouna", pass);
|
|
|
|
|
|
|
|
freerdp_assistance_file_free(file);
|
|
|
|
|
|
|
|
free(pass);
|
|
|
|
free(expertBlob);
|
2014-06-29 20:36:28 +04:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int test_msrsc_incident_file_type2()
|
2014-06-29 00:04:49 +04:00
|
|
|
{
|
|
|
|
int status;
|
|
|
|
rdpAssistanceFile* file;
|
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
file = freerdp_assistance_file_new();
|
2014-06-29 00:04:49 +04:00
|
|
|
|
2015-06-17 23:08:02 +03:00
|
|
|
if (!file)
|
|
|
|
return -1;
|
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
status = freerdp_assistance_parse_file_buffer(file,
|
2014-06-29 20:36:28 +04:00
|
|
|
TEST_MSRC_INCIDENT_FILE_TYPE2, sizeof(TEST_MSRC_INCIDENT_FILE_TYPE2));
|
2014-06-29 00:04:49 +04:00
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
printf("freerdp_assistance_parse_file_buffer: %d\n", status);
|
2014-06-29 00:04:49 +04:00
|
|
|
|
|
|
|
if (status < 0)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
printf("Username: %s\n", file->Username);
|
|
|
|
printf("LHTicket: %s\n", file->LHTicket);
|
|
|
|
printf("RCTicket: %s\n", file->RCTicket);
|
2016-12-14 00:47:08 +03:00
|
|
|
printf("RCTicketEncrypted: %"PRId32"\n", file->RCTicketEncrypted);
|
2014-06-29 00:04:49 +04:00
|
|
|
printf("PassStub: %s\n", file->PassStub);
|
2016-12-14 00:47:08 +03:00
|
|
|
printf("DtStart: %"PRIu32"\n", file->DtStart);
|
|
|
|
printf("DtLength: %"PRIu32"\n", file->DtLength);
|
|
|
|
printf("LowSpeed: %"PRId32"\n", file->LowSpeed);
|
2014-06-29 00:04:49 +04:00
|
|
|
|
2014-06-29 01:03:16 +04:00
|
|
|
printf("RASessionId: %s\n", file->RASessionId);
|
|
|
|
printf("RASpecificParams: %s\n", file->RASpecificParams);
|
|
|
|
printf("MachineAddress: %s\n", file->MachineAddress);
|
2016-12-14 00:47:08 +03:00
|
|
|
printf("MachinePort: %"PRIu32"\n", file->MachinePort);
|
2014-06-29 01:03:16 +04:00
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
status = freerdp_assistance_decrypt(file, TEST_MSRC_INCIDENT_PASSWORD_TYPE2);
|
2014-06-29 00:04:49 +04:00
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
printf("freerdp_assistance_decrypt: %d\n", status);
|
2014-06-29 00:04:49 +04:00
|
|
|
|
|
|
|
if (status < 0)
|
|
|
|
return -1;
|
|
|
|
|
2014-06-30 04:38:33 +04:00
|
|
|
printf("ConnectionString2: %s\n", file->ConnectionString2);
|
|
|
|
|
2014-06-30 20:51:27 +04:00
|
|
|
freerdp_assistance_file_free(file);
|
2014-06-29 00:04:49 +04:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2014-06-30 17:40:24 +04:00
|
|
|
int TestCommonAssistance(int argc, char* argv[])
|
2014-06-29 20:36:28 +04:00
|
|
|
{
|
Winpr/openssl: Fix digests initialization in multi-thread
SSL functions like OpenSSL_add_all_digests should be invoked at very beginning as they are not MT safe.
If not we might meet double free exception as following:
#0 0x00007f23ddd71c37 in raise () from /lib/x86_64-linux-gnu/libc.so.6
#1 0x00007f23ddd75028 in abort () from /lib/x86_64-linux-gnu/libc.so.6
#2 0x00007f23dddae2a4 in ?? () from /lib/x86_64-linux-gnu/libc.so.6
#3 0x00007f23dddba55e in ?? () from /lib/x86_64-linux-gnu/libc.so.6
#4 0x00007f23dc6ecfcd in CRYPTO_free () from /lib/x86_64-linux-gnu/libcrypto.so.1.0.0
#5 0x00007f23dc6ef8d1 in OBJ_NAME_add () from /lib/x86_64-linux-gnu/libcrypto.so.1.0.0
#6 0x00007f23dc77dcd8 in EVP_add_digest () from /lib/x86_64-linux-gnu/libcrypto.so.1.0.0
#7 0x00007f23dc782321 in OpenSSL_add_all_digests () from /lib/x86_64-linux-gnu/libcrypto.so.1.0.0
#8 0x00007f23c781da28 in winpr_openssl_get_evp_md (md=4) at /home/zihao/workspace/zihao_FreeRDP/winpr/libwinpr/crypto/hash.c:52
#9 0x00007f23c781dccb in winpr_Digest_Init (ctx=0x7f22d064d470, md=<optimized out>) at /home/zihao/workspace/zihao_FreeRDP/winpr/libwinpr/crypto/hash.c:344
#10 0x00007f23d486139b in security_salted_mac_signature (rdp=0x7f23859f5a20, data=0x7f238542d4fb "\004\204\022\004", length=4743, encryption=<optimized out>, output=0x7
at /home/zihao/workspace/zihao_FreeRDP/libfreerdp/core/security.c:378
#11 0x00007f23d488d73f in fastpath_send_update_pdu (fastpath=<optimized out>, updateCode=4 '\004', s=0x7f23859f5f40, skipCompression=true)
at /home/zihao/workspace/zihao_FreeRDP/libfreerdp/core/fastpath.c:1076
#12 0x00007f23d4891c4f in update_send_surface_frame_bits (context=0x7f23859f5540, cmd=0x7f22b2ffcc80, first=true, last=true, frameId=6)
at /home/zihao/workspace/zihao_FreeRDP/libfreerdp/core/update.c:1041
Related reports: https://rt.openssl.org/Ticket/Display.html?id=2216&user=guest&pass=guest
2016-12-26 17:21:36 +03:00
|
|
|
winpr_InitializeSSL(WINPR_SSL_INIT_DEFAULT);
|
|
|
|
|
2015-06-17 23:08:02 +03:00
|
|
|
if (test_msrsc_incident_file_type1() != 0)
|
|
|
|
{
|
|
|
|
printf("test_msrsc_incident_file_type1 failed\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2014-06-29 20:36:28 +04:00
|
|
|
|
2015-06-17 23:08:02 +03:00
|
|
|
if (test_msrsc_incident_file_type2() != 0)
|
|
|
|
{
|
|
|
|
printf("test_msrsc_incident_file_type1 failed\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2014-06-29 20:36:28 +04:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|