Merge pull request #10763 from akallabeth/fix-our-mistakes
Fix some mistakes
This commit is contained in:
commit
5ad826a503
@ -74,6 +74,7 @@ Checks: >
|
|||||||
-readability-misleading-indentation,
|
-readability-misleading-indentation,
|
||||||
-readability-qualified-auto,
|
-readability-qualified-auto,
|
||||||
-readability-suspicious-call-argument,
|
-readability-suspicious-call-argument,
|
||||||
|
-readability-string-compare,
|
||||||
-readability-uppercase-literal-suffix,
|
-readability-uppercase-literal-suffix,
|
||||||
-performance-no-int-to-ptr,
|
-performance-no-int-to-ptr,
|
||||||
-performance-avoid-endl
|
-performance-avoid-endl
|
||||||
|
@ -174,9 +174,9 @@ static DWORD WINAPI audin_alsa_thread_func(LPVOID arg)
|
|||||||
|
|
||||||
if (framesRead == -EPIPE)
|
if (framesRead == -EPIPE)
|
||||||
{
|
{
|
||||||
const int rc = snd_pcm_recover(capture_handle, (int)framesRead, 0);
|
const int res = snd_pcm_recover(capture_handle, (int)framesRead, 0);
|
||||||
if (rc < 0)
|
if (res < 0)
|
||||||
WLog_Print(alsa->log, WLOG_WARN, "snd_pcm_recover (%s)", snd_strerror(rc));
|
WLog_Print(alsa->log, WLOG_WARN, "snd_pcm_recover (%s)", snd_strerror(res));
|
||||||
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -202,9 +202,9 @@ static DWORD WINAPI audin_alsa_thread_func(LPVOID arg)
|
|||||||
|
|
||||||
if (capture_handle)
|
if (capture_handle)
|
||||||
{
|
{
|
||||||
const int rc = snd_pcm_close(capture_handle);
|
const int res = snd_pcm_close(capture_handle);
|
||||||
if (rc < 0)
|
if (res < 0)
|
||||||
WLog_Print(alsa->log, WLOG_WARN, "snd_pcm_close (%s)", snd_strerror(rc));
|
WLog_Print(alsa->log, WLOG_WARN, "snd_pcm_close (%s)", snd_strerror(res));
|
||||||
}
|
}
|
||||||
|
|
||||||
out:
|
out:
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <winpr/assert.h>
|
#include <winpr/assert.h>
|
||||||
|
#include <winpr/winpr.h>
|
||||||
|
|
||||||
#include "camera.h"
|
#include "camera.h"
|
||||||
|
|
||||||
@ -160,7 +161,7 @@ static BOOL ecam_encoder_compress_h264(CameraDeviceStream* stream, const BYTE* s
|
|||||||
#if defined(WITH_INPUT_FORMAT_MJPG)
|
#if defined(WITH_INPUT_FORMAT_MJPG)
|
||||||
if (inputFormat == CAM_MEDIA_FORMAT_MJPG)
|
if (inputFormat == CAM_MEDIA_FORMAT_MJPG)
|
||||||
{
|
{
|
||||||
stream->avInputPkt->data = (BYTE*)srcData;
|
stream->avInputPkt->data = WINPR_CAST_CONST_PTR_AWAY(srcData, BYTE*);
|
||||||
stream->avInputPkt->size = srcSize;
|
stream->avInputPkt->size = srcSize;
|
||||||
|
|
||||||
if (avcodec_send_packet(stream->avContext, stream->avInputPkt) < 0)
|
if (avcodec_send_packet(stream->avContext, stream->avInputPkt) < 0)
|
||||||
@ -195,8 +196,8 @@ static BOOL ecam_encoder_compress_h264(CameraDeviceStream* stream, const BYTE* s
|
|||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (av_image_fill_pointers(srcSlice, pixFormat, (int)size.height, (BYTE*)srcData,
|
if (av_image_fill_pointers(srcSlice, pixFormat, (int)size.height,
|
||||||
srcLineSizes) < 0)
|
WINPR_CAST_CONST_PTR_AWAY(srcData, BYTE*), srcLineSizes) < 0)
|
||||||
{
|
{
|
||||||
WLog_ERR(TAG, "av_image_fill_pointers failed");
|
WLog_ERR(TAG, "av_image_fill_pointers failed");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -20,6 +20,9 @@ set (WITH_SANITIZE_ADDRESS ON CACHE BOOL "qa default")
|
|||||||
set (WITH_WINPR_UTILS_IMAGE_JPEG ON CACHE BOOL "qa default")
|
set (WITH_WINPR_UTILS_IMAGE_JPEG ON CACHE BOOL "qa default")
|
||||||
set (WITH_WINPR_UTILS_IMAGE_WEBP ON CACHE BOOL "qa default")
|
set (WITH_WINPR_UTILS_IMAGE_WEBP ON CACHE BOOL "qa default")
|
||||||
set (WITH_WINPR_UTILS_IMAGE_PNG ON CACHE BOOL "qa default")
|
set (WITH_WINPR_UTILS_IMAGE_PNG ON CACHE BOOL "qa default")
|
||||||
|
set (WITH_INTERNAL_RC4 ON CACHE BOOL "qa default")
|
||||||
|
set (WITH_INTERNAL_MD4 ON CACHE BOOL "qa default")
|
||||||
|
set (WITH_INTERNAL_MD5 ON CACHE BOOL "qa default")
|
||||||
set (CHANNEL_RDPECAM ON CACHE BOOL "qa default")
|
set (CHANNEL_RDPECAM ON CACHE BOOL "qa default")
|
||||||
set (CHANNEL_RDPECAM_CLIENT ON CACHE BOOL "qa default")
|
set (CHANNEL_RDPECAM_CLIENT ON CACHE BOOL "qa default")
|
||||||
set (CHANNEL_RDPEAR ON CACHE BOOL "qa default")
|
set (CHANNEL_RDPEAR ON CACHE BOOL "qa default")
|
||||||
|
@ -25,7 +25,6 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
#include <winpr/assert.h>
|
|
||||||
#include <winpr/crt.h>
|
#include <winpr/crt.h>
|
||||||
#include <winpr/path.h>
|
#include <winpr/path.h>
|
||||||
#include <winpr/assert.h>
|
#include <winpr/assert.h>
|
||||||
|
@ -156,7 +156,7 @@ int websocket_write(BIO* bio, const BYTE* buf, int isize, WEBSOCKET_OPCODE opcod
|
|||||||
winpr_RAND(&maskingKey, sizeof(maskingKey));
|
winpr_RAND(&maskingKey, sizeof(maskingKey));
|
||||||
|
|
||||||
payloadSize = isize;
|
payloadSize = isize;
|
||||||
if ((isize < 0) || (isize > UINT32_MAX))
|
if (isize < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (payloadSize < 126)
|
if (payloadSize < 126)
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
#include <winpr/crt.h>
|
#include <winpr/crt.h>
|
||||||
|
#include <winpr/winpr.h>
|
||||||
#include <winpr/string.h>
|
#include <winpr/string.h>
|
||||||
#include <winpr/sspi.h>
|
#include <winpr/sspi.h>
|
||||||
#include <winpr/ssl.h>
|
#include <winpr/ssl.h>
|
||||||
@ -902,7 +903,8 @@ TlsHandshakeResult freerdp_tls_connect_ex(rdpTls* tls, BIO* underlying, const SS
|
|||||||
|
|
||||||
#if !defined(OPENSSL_NO_TLSEXT) && !defined(LIBRESSL_VERSION_NUMBER)
|
#if !defined(OPENSSL_NO_TLSEXT) && !defined(LIBRESSL_VERSION_NUMBER)
|
||||||
const char* str = tls_get_server_name(tls);
|
const char* str = tls_get_server_name(tls);
|
||||||
SSL_set_tlsext_host_name(tls->ssl, WINPR_CAST_CONST_PTR_AWAY(str, void*));
|
void* ptr = WINPR_CAST_CONST_PTR_AWAY(str, void*);
|
||||||
|
SSL_set_tlsext_host_name(tls->ssl, ptr);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return freerdp_tls_handshake(tls);
|
return freerdp_tls_handshake(tls);
|
||||||
|
@ -129,8 +129,8 @@ static const char* general_name_type_label(int general_name_type)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
static char buffer[80];
|
static char buffer[80] = { 0 };
|
||||||
(void)sprintf(buffer, "Unknown general name type (%d)", general_name_type);
|
(void)snprintf(buffer, sizeof(buffer), "Unknown general name type (%d)", general_name_type);
|
||||||
return buffer;
|
return buffer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -62,7 +62,7 @@ static INLINE pstatus_t avx2_image_copy_bgr24_bgrx32(BYTE* WINPR_RESTRICT pDstDa
|
|||||||
const SSIZE_T width = nWidth - rem;
|
const SSIZE_T width = nWidth - rem;
|
||||||
|
|
||||||
const size_t align = nSrcStep % 32;
|
const size_t align = nSrcStep % 32;
|
||||||
const BOOL fast = (align == 0) ? TRUE : (align >= 8 - MIN(8, rem) ? TRUE : FALSE);
|
const BOOL fast = (align == 0) ? TRUE : (align >= 8 - MIN(8, (size_t)rem) ? TRUE : FALSE);
|
||||||
for (SSIZE_T y = 0; y < nHeight; y++)
|
for (SSIZE_T y = 0; y < nHeight; y++)
|
||||||
{
|
{
|
||||||
const BYTE* WINPR_RESTRICT srcLine =
|
const BYTE* WINPR_RESTRICT srcLine =
|
||||||
|
@ -57,7 +57,7 @@ static INLINE pstatus_t sse_image_copy_bgr24_bgrx32(BYTE* WINPR_RESTRICT pDstDat
|
|||||||
const SSIZE_T rem = nWidth % 4;
|
const SSIZE_T rem = nWidth % 4;
|
||||||
|
|
||||||
const size_t align = nSrcStep % 64;
|
const size_t align = nSrcStep % 64;
|
||||||
const BOOL fast = (align == 0) ? TRUE : (align >= 16 - MIN(16, rem) ? TRUE : FALSE);
|
const BOOL fast = (align == 0) ? TRUE : (align >= 16 - MIN(16, (size_t)rem) ? TRUE : FALSE);
|
||||||
const SSIZE_T width = nWidth - rem;
|
const SSIZE_T width = nWidth - rem;
|
||||||
for (SSIZE_T y = 0; y < nHeight; y++)
|
for (SSIZE_T y = 0; y < nHeight; y++)
|
||||||
{
|
{
|
||||||
|
@ -602,8 +602,8 @@ static void* clipboard_synthesize_text_html(wClipboard* clipboard, UINT32 format
|
|||||||
|
|
||||||
const long end = strtol(&endStr[8], NULL, 10);
|
const long end = strtol(&endStr[8], NULL, 10);
|
||||||
|
|
||||||
if (beg < 0 || end < 0 || (beg > SrcSize) || (end > SrcSize) || (beg >= end) ||
|
if (beg < 0 || end < 0 || ((size_t)beg > SrcSize) || ((size_t)end > SrcSize) ||
|
||||||
(errno != 0))
|
(beg >= end) || (errno != 0))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
const size_t DstSize = (size_t)(end - beg);
|
const size_t DstSize = (size_t)(end - beg);
|
||||||
|
@ -3,7 +3,6 @@
|
|||||||
|
|
||||||
#include "hmac_md5.h"
|
#include "hmac_md5.h"
|
||||||
#include "md5.h"
|
#include "md5.h"
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
void hmac_md5_init(WINPR_HMAC_MD5_CTX* ctx, const unsigned char* key, size_t key_len)
|
void hmac_md5_init(WINPR_HMAC_MD5_CTX* ctx, const unsigned char* key, size_t key_len)
|
||||||
{
|
{
|
||||||
|
@ -45,9 +45,18 @@
|
|||||||
* F and G are optimized compared to their RFC 1320 definitions, with the
|
* F and G are optimized compared to their RFC 1320 definitions, with the
|
||||||
* optimization for F borrowed from Colin Plumb's MD5 implementation.
|
* optimization for F borrowed from Colin Plumb's MD5 implementation.
|
||||||
*/
|
*/
|
||||||
#define F(x, y, z) ((z) ^ ((x) & ((y) ^ (z))))
|
static inline winpr_MD4_u32plus F(winpr_MD4_u32plus x, winpr_MD4_u32plus y, winpr_MD4_u32plus z)
|
||||||
#define G(x, y, z) (((x) & ((y) | (z))) | ((y) & (z)))
|
{
|
||||||
#define H(x, y, z) ((x) ^ (y) ^ (z))
|
return ((z) ^ ((x) & ((y) ^ (z))));
|
||||||
|
}
|
||||||
|
static inline winpr_MD4_u32plus G(winpr_MD4_u32plus x, winpr_MD4_u32plus y, winpr_MD4_u32plus z)
|
||||||
|
{
|
||||||
|
return (((x) & ((y) | (z))) | ((y) & (z)));
|
||||||
|
}
|
||||||
|
static inline winpr_MD4_u32plus H(winpr_MD4_u32plus x, winpr_MD4_u32plus y, winpr_MD4_u32plus z)
|
||||||
|
{
|
||||||
|
return ((x) ^ (y) ^ (z));
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The MD4 transformation for all three rounds.
|
* The MD4 transformation for all three rounds.
|
||||||
@ -72,13 +81,14 @@
|
|||||||
* their own translation unit avoids the problem.
|
* their own translation unit avoids the problem.
|
||||||
*/
|
*/
|
||||||
#if defined(__i386__) || defined(__x86_64__) || defined(__vax__)
|
#if defined(__i386__) || defined(__x86_64__) || defined(__vax__)
|
||||||
#define SET(n) (*(const winpr_MD4_u32plus*)&ptr[(n)*4])
|
#define SET(n) (*(const winpr_MD4_u32plus*)&ptr[4ULL * (n)])
|
||||||
#define GET(n) SET(n)
|
#define GET(n) SET(n)
|
||||||
#else
|
#else
|
||||||
#define SET(n) \
|
#define SET(n) \
|
||||||
(ctx->block[(n)] = (winpr_MD4_u32plus)ptr[(n)*4] | ((winpr_MD4_u32plus)ptr[(n)*4 + 1] << 8) | \
|
(ctx->block[(n)] = (winpr_MD4_u32plus)ptr[4ULL * (n)] | \
|
||||||
((winpr_MD4_u32plus)ptr[(n)*4 + 2] << 16) | \
|
((winpr_MD4_u32plus)ptr[4ULL * (n) + 1] << 8) | \
|
||||||
((winpr_MD4_u32plus)ptr[(n)*4 + 3] << 24))
|
((winpr_MD4_u32plus)ptr[4ULL * (n) + 2] << 16) | \
|
||||||
|
((winpr_MD4_u32plus)ptr[4ULL * (n) + 3] << 24))
|
||||||
#define GET(n) (ctx->block[(n)])
|
#define GET(n) (ctx->block[(n)])
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -88,31 +98,22 @@
|
|||||||
*/
|
*/
|
||||||
static const void* body(WINPR_MD4_CTX* ctx, const void* data, unsigned long size)
|
static const void* body(WINPR_MD4_CTX* ctx, const void* data, unsigned long size)
|
||||||
{
|
{
|
||||||
const unsigned char* ptr = NULL;
|
|
||||||
winpr_MD4_u32plus a = 0;
|
|
||||||
winpr_MD4_u32plus b = 0;
|
|
||||||
winpr_MD4_u32plus c = 0;
|
|
||||||
winpr_MD4_u32plus d = 0;
|
|
||||||
winpr_MD4_u32plus saved_a = 0;
|
|
||||||
winpr_MD4_u32plus saved_b = 0;
|
|
||||||
winpr_MD4_u32plus saved_c = 0;
|
|
||||||
winpr_MD4_u32plus saved_d = 0;
|
|
||||||
const winpr_MD4_u32plus ac1 = 0x5a827999;
|
const winpr_MD4_u32plus ac1 = 0x5a827999;
|
||||||
const winpr_MD4_u32plus ac2 = 0x6ed9eba1;
|
const winpr_MD4_u32plus ac2 = 0x6ed9eba1;
|
||||||
|
|
||||||
ptr = (const unsigned char*)data;
|
const unsigned char* ptr = (const unsigned char*)data;
|
||||||
|
|
||||||
a = ctx->a;
|
winpr_MD4_u32plus a = ctx->a;
|
||||||
b = ctx->b;
|
winpr_MD4_u32plus b = ctx->b;
|
||||||
c = ctx->c;
|
winpr_MD4_u32plus c = ctx->c;
|
||||||
d = ctx->d;
|
winpr_MD4_u32plus d = ctx->d;
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
saved_a = a;
|
winpr_MD4_u32plus saved_a = a;
|
||||||
saved_b = b;
|
winpr_MD4_u32plus saved_b = b;
|
||||||
saved_c = c;
|
winpr_MD4_u32plus saved_c = c;
|
||||||
saved_d = d;
|
winpr_MD4_u32plus saved_d = d;
|
||||||
|
|
||||||
/* Round 1 */
|
/* Round 1 */
|
||||||
STEP(F, a, b, c, d, SET(0), 3)
|
STEP(F, a, b, c, d, SET(0), 3)
|
||||||
@ -197,20 +198,16 @@ void winpr_MD4_Init(WINPR_MD4_CTX* ctx)
|
|||||||
|
|
||||||
void winpr_MD4_Update(WINPR_MD4_CTX* ctx, const void* data, unsigned long size)
|
void winpr_MD4_Update(WINPR_MD4_CTX* ctx, const void* data, unsigned long size)
|
||||||
{
|
{
|
||||||
winpr_MD4_u32plus saved_lo = 0;
|
winpr_MD4_u32plus saved_lo = ctx->lo;
|
||||||
unsigned long used = 0;
|
|
||||||
unsigned long available = 0;
|
|
||||||
|
|
||||||
saved_lo = ctx->lo;
|
|
||||||
if ((ctx->lo = (saved_lo + size) & 0x1fffffff) < saved_lo)
|
if ((ctx->lo = (saved_lo + size) & 0x1fffffff) < saved_lo)
|
||||||
ctx->hi++;
|
ctx->hi++;
|
||||||
ctx->hi += size >> 29;
|
ctx->hi += size >> 29;
|
||||||
|
|
||||||
used = saved_lo & 0x3f;
|
unsigned long used = saved_lo & 0x3f;
|
||||||
|
|
||||||
if (used)
|
if (used)
|
||||||
{
|
{
|
||||||
available = 64 - used;
|
unsigned long available = 64 - used;
|
||||||
|
|
||||||
if (size < available)
|
if (size < available)
|
||||||
{
|
{
|
||||||
@ -233,22 +230,21 @@ void winpr_MD4_Update(WINPR_MD4_CTX* ctx, const void* data, unsigned long size)
|
|||||||
memcpy(ctx->buffer, data, size);
|
memcpy(ctx->buffer, data, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define OUT(dst, src) \
|
static inline void OUT(unsigned char* dst, winpr_MD4_u32plus src)
|
||||||
(dst)[0] = (unsigned char)(src); \
|
{
|
||||||
(dst)[1] = (unsigned char)((src) >> 8); \
|
(dst)[0] = (unsigned char)(src);
|
||||||
(dst)[2] = (unsigned char)((src) >> 16); \
|
(dst)[1] = (unsigned char)((src) >> 8);
|
||||||
|
(dst)[2] = (unsigned char)((src) >> 16);
|
||||||
(dst)[3] = (unsigned char)((src) >> 24);
|
(dst)[3] = (unsigned char)((src) >> 24);
|
||||||
|
}
|
||||||
|
|
||||||
void winpr_MD4_Final(unsigned char* result, WINPR_MD4_CTX* ctx)
|
void winpr_MD4_Final(unsigned char* result, WINPR_MD4_CTX* ctx)
|
||||||
{
|
{
|
||||||
unsigned long used = 0;
|
unsigned long used = ctx->lo & 0x3f;
|
||||||
unsigned long available = 0;
|
|
||||||
|
|
||||||
used = ctx->lo & 0x3f;
|
|
||||||
|
|
||||||
ctx->buffer[used++] = 0x80;
|
ctx->buffer[used++] = 0x80;
|
||||||
|
|
||||||
available = 64 - used;
|
unsigned long available = 64 - used;
|
||||||
|
|
||||||
if (available < 8)
|
if (available < 8)
|
||||||
{
|
{
|
||||||
@ -261,15 +257,15 @@ void winpr_MD4_Final(unsigned char* result, WINPR_MD4_CTX* ctx)
|
|||||||
memset(&ctx->buffer[used], 0, available - 8);
|
memset(&ctx->buffer[used], 0, available - 8);
|
||||||
|
|
||||||
ctx->lo <<= 3;
|
ctx->lo <<= 3;
|
||||||
OUT(&ctx->buffer[56], ctx->lo)
|
OUT(&ctx->buffer[56], ctx->lo);
|
||||||
OUT(&ctx->buffer[60], ctx->hi)
|
OUT(&ctx->buffer[60], ctx->hi);
|
||||||
|
|
||||||
body(ctx, ctx->buffer, 64);
|
body(ctx, ctx->buffer, 64);
|
||||||
|
|
||||||
OUT(&result[0], ctx->a)
|
OUT(&result[0], ctx->a);
|
||||||
OUT(&result[4], ctx->b)
|
OUT(&result[4], ctx->b);
|
||||||
OUT(&result[8], ctx->c)
|
OUT(&result[8], ctx->c);
|
||||||
OUT(&result[12], ctx->d)
|
OUT(&result[12], ctx->d);
|
||||||
|
|
||||||
memset(ctx, 0, sizeof(*ctx));
|
memset(ctx, 0, sizeof(*ctx));
|
||||||
}
|
}
|
||||||
|
@ -46,11 +46,26 @@
|
|||||||
* architectures that lack an AND-NOT instruction, just like in Colin Plumb's
|
* architectures that lack an AND-NOT instruction, just like in Colin Plumb's
|
||||||
* implementation.
|
* implementation.
|
||||||
*/
|
*/
|
||||||
#define F(x, y, z) ((z) ^ ((x) & ((y) ^ (z))))
|
static inline winpr_MD5_u32plus F(winpr_MD5_u32plus x, winpr_MD5_u32plus y, winpr_MD5_u32plus z)
|
||||||
#define G(x, y, z) ((y) ^ ((z) & ((x) ^ (y))))
|
{
|
||||||
#define H(x, y, z) (((x) ^ (y)) ^ (z))
|
return ((z) ^ ((x) & ((y) ^ (z))));
|
||||||
#define H2(x, y, z) ((x) ^ ((y) ^ (z)))
|
}
|
||||||
#define I(x, y, z) ((y) ^ ((x) | ~(z)))
|
static inline winpr_MD5_u32plus G(winpr_MD5_u32plus x, winpr_MD5_u32plus y, winpr_MD5_u32plus z)
|
||||||
|
{
|
||||||
|
return ((y) ^ ((z) & ((x) ^ (y))));
|
||||||
|
}
|
||||||
|
static inline winpr_MD5_u32plus H(winpr_MD5_u32plus x, winpr_MD5_u32plus y, winpr_MD5_u32plus z)
|
||||||
|
{
|
||||||
|
return (((x) ^ (y)) ^ (z));
|
||||||
|
}
|
||||||
|
static inline winpr_MD5_u32plus H2(winpr_MD5_u32plus x, winpr_MD5_u32plus y, winpr_MD5_u32plus z)
|
||||||
|
{
|
||||||
|
return ((x) ^ ((y) ^ (z)));
|
||||||
|
}
|
||||||
|
static inline winpr_MD5_u32plus I(winpr_MD5_u32plus x, winpr_MD5_u32plus y, winpr_MD5_u32plus z)
|
||||||
|
{
|
||||||
|
return ((y) ^ ((x) | ~(z)));
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The MD5 transformation for all four rounds.
|
* The MD5 transformation for all four rounds.
|
||||||
@ -76,13 +91,14 @@
|
|||||||
* their own translation unit avoids the problem.
|
* their own translation unit avoids the problem.
|
||||||
*/
|
*/
|
||||||
#if defined(__i386__) || defined(__x86_64__) || defined(__vax__)
|
#if defined(__i386__) || defined(__x86_64__) || defined(__vax__)
|
||||||
#define SET(n) (*(const winpr_MD5_u32plus*)&ptr[(n)*4])
|
#define SET(n) (*(const winpr_MD5_u32plus*)&ptr[4ULL * (n)])
|
||||||
#define GET(n) SET(n)
|
#define GET(n) SET(n)
|
||||||
#else
|
#else
|
||||||
#define SET(n) \
|
#define SET(n) \
|
||||||
(ctx->block[(n)] = (winpr_MD5_u32plus)ptr[(n)*4] | ((winpr_MD5_u32plus)ptr[(n)*4 + 1] << 8) | \
|
(ctx->block[(n)] = (winpr_MD5_u32plus)ptr[4ULL * (n)] | \
|
||||||
((winpr_MD5_u32plus)ptr[(n)*4 + 2] << 16) | \
|
((winpr_MD5_u32plus)ptr[4ULL * (n) + 1] << 8) | \
|
||||||
((winpr_MD5_u32plus)ptr[(n)*4 + 3] << 24))
|
((winpr_MD5_u32plus)ptr[4ULL * (n) + 2] << 16) | \
|
||||||
|
((winpr_MD5_u32plus)ptr[4ULL * (n) + 3] << 24))
|
||||||
#define GET(n) (ctx->block[(n)])
|
#define GET(n) (ctx->block[(n)])
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -92,29 +108,19 @@
|
|||||||
*/
|
*/
|
||||||
static const void* body(WINPR_MD5_CTX* ctx, const void* data, unsigned long size)
|
static const void* body(WINPR_MD5_CTX* ctx, const void* data, unsigned long size)
|
||||||
{
|
{
|
||||||
const unsigned char* ptr = NULL;
|
const unsigned char* ptr = (const unsigned char*)data;
|
||||||
winpr_MD5_u32plus a = 0;
|
|
||||||
winpr_MD5_u32plus b = 0;
|
|
||||||
winpr_MD5_u32plus c = 0;
|
|
||||||
winpr_MD5_u32plus d = 0;
|
|
||||||
winpr_MD5_u32plus saved_a = 0;
|
|
||||||
winpr_MD5_u32plus saved_b = 0;
|
|
||||||
winpr_MD5_u32plus saved_c = 0;
|
|
||||||
winpr_MD5_u32plus saved_d = 0;
|
|
||||||
|
|
||||||
ptr = (const unsigned char*)data;
|
winpr_MD5_u32plus a = ctx->a;
|
||||||
|
winpr_MD5_u32plus b = ctx->b;
|
||||||
a = ctx->a;
|
winpr_MD5_u32plus c = ctx->c;
|
||||||
b = ctx->b;
|
winpr_MD5_u32plus d = ctx->d;
|
||||||
c = ctx->c;
|
|
||||||
d = ctx->d;
|
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
saved_a = a;
|
const winpr_MD5_u32plus saved_a = a;
|
||||||
saved_b = b;
|
const winpr_MD5_u32plus saved_b = b;
|
||||||
saved_c = c;
|
const winpr_MD5_u32plus saved_c = c;
|
||||||
saved_d = d;
|
const winpr_MD5_u32plus saved_d = d;
|
||||||
|
|
||||||
/* Round 1 */
|
/* Round 1 */
|
||||||
STEP(F, a, b, c, d, SET(0), 0xd76aa478, 7)
|
STEP(F, a, b, c, d, SET(0), 0xd76aa478, 7)
|
||||||
@ -217,20 +223,16 @@ void winpr_MD5_Init(WINPR_MD5_CTX* ctx)
|
|||||||
|
|
||||||
void winpr_MD5_Update(WINPR_MD5_CTX* ctx, const void* data, unsigned long size)
|
void winpr_MD5_Update(WINPR_MD5_CTX* ctx, const void* data, unsigned long size)
|
||||||
{
|
{
|
||||||
winpr_MD5_u32plus saved_lo = 0;
|
winpr_MD5_u32plus saved_lo = ctx->lo;
|
||||||
unsigned long used = 0;
|
|
||||||
unsigned long available = 0;
|
|
||||||
|
|
||||||
saved_lo = ctx->lo;
|
|
||||||
if ((ctx->lo = (saved_lo + size) & 0x1fffffff) < saved_lo)
|
if ((ctx->lo = (saved_lo + size) & 0x1fffffff) < saved_lo)
|
||||||
ctx->hi++;
|
ctx->hi++;
|
||||||
ctx->hi += size >> 29;
|
ctx->hi += size >> 29;
|
||||||
|
|
||||||
used = saved_lo & 0x3f;
|
unsigned long used = saved_lo & 0x3f;
|
||||||
|
|
||||||
if (used)
|
if (used)
|
||||||
{
|
{
|
||||||
available = 64 - used;
|
unsigned long available = 64 - used;
|
||||||
|
|
||||||
if (size < available)
|
if (size < available)
|
||||||
{
|
{
|
||||||
@ -253,22 +255,21 @@ void winpr_MD5_Update(WINPR_MD5_CTX* ctx, const void* data, unsigned long size)
|
|||||||
memcpy(ctx->buffer, data, size);
|
memcpy(ctx->buffer, data, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define OUT(dst, src) \
|
static inline void OUT(unsigned char* dst, winpr_MD5_u32plus src)
|
||||||
(dst)[0] = (unsigned char)(src); \
|
{
|
||||||
(dst)[1] = (unsigned char)((src) >> 8); \
|
(dst)[0] = (unsigned char)(src);
|
||||||
(dst)[2] = (unsigned char)((src) >> 16); \
|
(dst)[1] = (unsigned char)((src) >> 8);
|
||||||
|
(dst)[2] = (unsigned char)((src) >> 16);
|
||||||
(dst)[3] = (unsigned char)((src) >> 24);
|
(dst)[3] = (unsigned char)((src) >> 24);
|
||||||
|
}
|
||||||
|
|
||||||
void winpr_MD5_Final(unsigned char* result, WINPR_MD5_CTX* ctx)
|
void winpr_MD5_Final(unsigned char* result, WINPR_MD5_CTX* ctx)
|
||||||
{
|
{
|
||||||
unsigned long used = 0;
|
unsigned long used = ctx->lo & 0x3f;
|
||||||
unsigned long available = 0;
|
|
||||||
|
|
||||||
used = ctx->lo & 0x3f;
|
|
||||||
|
|
||||||
ctx->buffer[used++] = 0x80;
|
ctx->buffer[used++] = 0x80;
|
||||||
|
|
||||||
available = 64 - used;
|
unsigned long available = 64 - used;
|
||||||
|
|
||||||
if (available < 8)
|
if (available < 8)
|
||||||
{
|
{
|
||||||
@ -281,15 +282,15 @@ void winpr_MD5_Final(unsigned char* result, WINPR_MD5_CTX* ctx)
|
|||||||
memset(&ctx->buffer[used], 0, available - 8);
|
memset(&ctx->buffer[used], 0, available - 8);
|
||||||
|
|
||||||
ctx->lo <<= 3;
|
ctx->lo <<= 3;
|
||||||
OUT(&ctx->buffer[56], ctx->lo)
|
OUT(&ctx->buffer[56], ctx->lo);
|
||||||
OUT(&ctx->buffer[60], ctx->hi)
|
OUT(&ctx->buffer[60], ctx->hi);
|
||||||
|
|
||||||
body(ctx, ctx->buffer, 64);
|
body(ctx, ctx->buffer, 64);
|
||||||
|
|
||||||
OUT(&result[0], ctx->a)
|
OUT(&result[0], ctx->a);
|
||||||
OUT(&result[4], ctx->b)
|
OUT(&result[4], ctx->b);
|
||||||
OUT(&result[8], ctx->c)
|
OUT(&result[8], ctx->c);
|
||||||
OUT(&result[12], ctx->d)
|
OUT(&result[12], ctx->d);
|
||||||
|
|
||||||
memset(ctx, 0, sizeof(*ctx));
|
memset(ctx, 0, sizeof(*ctx));
|
||||||
}
|
}
|
||||||
|
@ -693,20 +693,26 @@ static BOOL kerberos_rd_tgt_req_tag2(WinPrAsn1Decoder* dec, char* buf, size_t le
|
|||||||
BOOL first = TRUE;
|
BOOL first = TRUE;
|
||||||
while (WinPrAsn1DecPeekTag(dec, &tag))
|
while (WinPrAsn1DecPeekTag(dec, &tag))
|
||||||
{
|
{
|
||||||
|
BOOL success = FALSE;
|
||||||
char* lstr = NULL;
|
char* lstr = NULL;
|
||||||
if (!WinPrAsn1DecReadGeneralString(dec, &lstr))
|
if (!WinPrAsn1DecReadGeneralString(dec, &lstr))
|
||||||
goto end;
|
goto fail;
|
||||||
|
|
||||||
if (!first)
|
if (!first)
|
||||||
{
|
{
|
||||||
if (!append(buf, len, "/"))
|
if (!append(buf, len, "/"))
|
||||||
goto end;
|
goto fail;
|
||||||
}
|
}
|
||||||
first = FALSE;
|
first = FALSE;
|
||||||
|
|
||||||
if (!append(buf, len, lstr))
|
if (!append(buf, len, lstr))
|
||||||
goto end;
|
goto fail;
|
||||||
|
|
||||||
|
success = TRUE;
|
||||||
|
fail:
|
||||||
free(lstr);
|
free(lstr);
|
||||||
|
if (!success)
|
||||||
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = TRUE;
|
rc = TRUE;
|
||||||
@ -779,7 +785,6 @@ static BOOL kerberos_rd_tgt_req(WinPrAsn1Decoder* dec, char** target)
|
|||||||
rc = FALSE;
|
rc = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
end:
|
|
||||||
if (rc)
|
if (rc)
|
||||||
*target = buf;
|
*target = buf;
|
||||||
else
|
else
|
||||||
|
@ -129,13 +129,10 @@ static HANDLE_OPS ops = { LogonUserIsHandled,
|
|||||||
BOOL LogonUserA(LPCSTR lpszUsername, LPCSTR lpszDomain, LPCSTR lpszPassword, DWORD dwLogonType,
|
BOOL LogonUserA(LPCSTR lpszUsername, LPCSTR lpszDomain, LPCSTR lpszPassword, DWORD dwLogonType,
|
||||||
DWORD dwLogonProvider, PHANDLE phToken)
|
DWORD dwLogonProvider, PHANDLE phToken)
|
||||||
{
|
{
|
||||||
struct passwd* pw = NULL;
|
|
||||||
WINPR_ACCESS_TOKEN* token = NULL;
|
|
||||||
|
|
||||||
if (!lpszUsername)
|
if (!lpszUsername)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
token = (WINPR_ACCESS_TOKEN*)calloc(1, sizeof(WINPR_ACCESS_TOKEN));
|
WINPR_ACCESS_TOKEN* token = (WINPR_ACCESS_TOKEN*)calloc(1, sizeof(WINPR_ACCESS_TOKEN));
|
||||||
|
|
||||||
if (!token)
|
if (!token)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -145,26 +142,29 @@ BOOL LogonUserA(LPCSTR lpszUsername, LPCSTR lpszDomain, LPCSTR lpszPassword, DWO
|
|||||||
token->Username = _strdup(lpszUsername);
|
token->Username = _strdup(lpszUsername);
|
||||||
|
|
||||||
if (!token->Username)
|
if (!token->Username)
|
||||||
{
|
goto fail;
|
||||||
free(token);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (lpszDomain)
|
if (lpszDomain)
|
||||||
{
|
{
|
||||||
token->Domain = _strdup(lpszDomain);
|
token->Domain = _strdup(lpszDomain);
|
||||||
|
|
||||||
if (!token->Domain)
|
if (!token->Domain)
|
||||||
{
|
goto fail;
|
||||||
free(token->Username);
|
|
||||||
free(token);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
pw = getpwnam(lpszUsername);
|
long buflen = sysconf(_SC_GETPW_R_SIZE_MAX);
|
||||||
|
if (buflen == -1)
|
||||||
|
buflen = 8196;
|
||||||
|
|
||||||
if (pw)
|
char* buf = (char*)calloc(buflen + 1, sizeof(char));
|
||||||
|
if (!buf)
|
||||||
|
goto fail;
|
||||||
|
|
||||||
|
struct passwd pwd = { 0 };
|
||||||
|
struct passwd* pw = NULL;
|
||||||
|
const int rc = getpwnam_r(lpszUsername, &pwd, buf, buflen, &pw);
|
||||||
|
free(buf);
|
||||||
|
if ((rc == 0) && pw)
|
||||||
{
|
{
|
||||||
token->UserId = (DWORD)pw->pw_uid;
|
token->UserId = (DWORD)pw->pw_uid;
|
||||||
token->GroupId = (DWORD)pw->pw_gid;
|
token->GroupId = (DWORD)pw->pw_gid;
|
||||||
@ -172,6 +172,12 @@ BOOL LogonUserA(LPCSTR lpszUsername, LPCSTR lpszDomain, LPCSTR lpszPassword, DWO
|
|||||||
|
|
||||||
*((ULONG_PTR*)phToken) = (ULONG_PTR)token;
|
*((ULONG_PTR*)phToken) = (ULONG_PTR)token;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
|
fail:
|
||||||
|
free(token->Username);
|
||||||
|
free(token->Domain);
|
||||||
|
free(token);
|
||||||
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL LogonUserW(LPCWSTR lpszUsername, LPCWSTR lpszDomain, LPCWSTR lpszPassword, DWORD dwLogonType,
|
BOOL LogonUserW(LPCWSTR lpszUsername, LPCWSTR lpszDomain, LPCWSTR lpszPassword, DWORD dwLogonType,
|
||||||
|
@ -576,7 +576,7 @@ static BOOL winpr_StartThread(WINPR_THREAD* thread)
|
|||||||
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);
|
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE);
|
||||||
|
|
||||||
if (thread->dwStackSize > 0)
|
if (thread->dwStackSize > 0)
|
||||||
pthread_attr_setstacksize(&attr, (size_t)thread->dwStackSize);
|
pthread_attr_setstacksize(&attr, thread->dwStackSize);
|
||||||
|
|
||||||
thread->started = TRUE;
|
thread->started = TRUE;
|
||||||
reset_event(thread);
|
reset_event(thread);
|
||||||
|
Loading…
Reference in New Issue
Block a user