Merge pull request #5230 from akallabeth/sign_compare_fixes
Sign compare fixes
This commit is contained in:
commit
3169b77d70
@ -1786,7 +1786,7 @@ BOOL gcc_read_client_monitor_data(wStream* s, rdpMcs* mcs, UINT16 blockLength)
|
||||
|
||||
void gcc_write_client_monitor_data(wStream* s, rdpMcs* mcs)
|
||||
{
|
||||
int i;
|
||||
UINT32 i;
|
||||
UINT16 length;
|
||||
UINT32 left, top, right, bottom, flags;
|
||||
INT32 baseX = 0, baseY = 0;
|
||||
|
@ -643,8 +643,8 @@ typedef struct _wEventType wEventType;
|
||||
WINPR_API BYTE* BipBuffer_ReadTryReserve(wBipBuffer* bb, size_t size, size_t* reserved);
|
||||
WINPR_API void BipBuffer_ReadCommit(wBipBuffer* bb, size_t size);
|
||||
|
||||
WINPR_API int BipBuffer_Read(wBipBuffer* bb, BYTE* data, size_t size);
|
||||
WINPR_API int BipBuffer_Write(wBipBuffer* bb, BYTE* data, size_t size);
|
||||
WINPR_API SSIZE_T BipBuffer_Read(wBipBuffer* bb, BYTE* data, size_t size);
|
||||
WINPR_API SSIZE_T BipBuffer_Write(wBipBuffer* bb, const BYTE* data, size_t size);
|
||||
|
||||
WINPR_API wBipBuffer* BipBuffer_New(size_t size);
|
||||
WINPR_API void BipBuffer_Free(wBipBuffer* bb);
|
||||
|
@ -517,6 +517,17 @@ typedef const BYTE* LPCBYTE;
|
||||
#endif /* _MSC_VER */
|
||||
#endif /* WINPR_HAVE_INTTYPES_H not defined*/
|
||||
|
||||
#ifndef SSIZE_MAX
|
||||
#if defined(_POSIX_SSIZE_MAX)
|
||||
#define SSIZE_MAX _POSIX_SSIZE_MAX
|
||||
#elif defined(_WIN64)
|
||||
#define SSIZE_MAX _I64_MAX
|
||||
#elif defined(_WIN32)
|
||||
#define SSIZE_MAX LONG_MAX
|
||||
#else
|
||||
#define SSIZE_MAX LONG_MAX
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#if defined(_MSC_VER) && _MSC_VER < 1900
|
||||
/* %z not supported before MSVC 2015 */
|
||||
|
@ -51,7 +51,7 @@
|
||||
DWORD GetCurrentDirectoryA(DWORD nBufferLength, LPSTR lpBuffer)
|
||||
{
|
||||
char* cwd;
|
||||
int length;
|
||||
size_t length;
|
||||
|
||||
cwd = getcwd(NULL, 0);
|
||||
|
||||
@ -139,7 +139,7 @@ BOOL NeedCurrentDirectoryForExePathW(LPCWSTR ExeName)
|
||||
DWORD GetEnvironmentVariableA(LPCSTR lpName, LPSTR lpBuffer, DWORD nSize)
|
||||
{
|
||||
#if !defined(_UWP)
|
||||
int length;
|
||||
size_t length;
|
||||
char* env = NULL;
|
||||
|
||||
env = getenv(lpName);
|
||||
|
@ -726,7 +726,7 @@ HRESULT PathCchStripPrefixW(PWSTR pszPath, size_t cchPath)
|
||||
if (cchPath < (lstrlenW(&pszPath[4]) + 1))
|
||||
return HRESULT_FROM_WIN32(ERROR_INSUFFICIENT_BUFFER);
|
||||
|
||||
if (IsCharAlpha(pszPath[4]) && (pszPath[5] == ':')) /* like C: */
|
||||
if (IsCharAlphaW(pszPath[4]) && (pszPath[5] == L':')) /* like C: */
|
||||
{
|
||||
wmemmove_s(pszPath, cchPath, &pszPath[4], cchPath - 4);
|
||||
/* since the passed pszPath must not necessarily be null terminated
|
||||
|
@ -189,7 +189,7 @@ BOOL WINAPI winpr_EnterSynchronizationBarrier(LPSYNCHRONIZATION_BARRIER lpBarrie
|
||||
* of processors.
|
||||
*/
|
||||
|
||||
if (spinOnly || (remainingThreads < dwProcessors && !blockOnly))
|
||||
if (spinOnly || (((ULONG)remainingThreads < dwProcessors) && !blockOnly))
|
||||
{
|
||||
DWORD dwSpinCount = lpBarrier->Reserved5;
|
||||
DWORD sp = 0;
|
||||
|
@ -67,7 +67,7 @@ int CommandLineParseArgumentsA(int argc, LPSTR* argv, COMMAND_LINE_ARGUMENT_A* o
|
||||
const char* sigil;
|
||||
size_t sigil_length;
|
||||
char* keyword;
|
||||
SSIZE_T keyword_length;
|
||||
size_t keyword_length;
|
||||
SSIZE_T keyword_index;
|
||||
char* separator;
|
||||
char* value;
|
||||
|
@ -21,6 +21,7 @@
|
||||
#include "config.h"
|
||||
#endif
|
||||
|
||||
#include <limits.h>
|
||||
#include <winpr/crt.h>
|
||||
#include <winpr/sysinfo.h>
|
||||
|
||||
@ -52,14 +53,12 @@ BOOL BipBuffer_AllocBuffer(wBipBuffer* bb, size_t size)
|
||||
return FALSE;
|
||||
|
||||
size += size % bb->pageSize;
|
||||
|
||||
bb->buffer = (BYTE*) malloc(size);
|
||||
|
||||
if (!bb->buffer)
|
||||
return FALSE;
|
||||
|
||||
bb->size = size;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
@ -69,7 +68,6 @@ BOOL BipBuffer_Grow(wBipBuffer* bb, size_t size)
|
||||
BYTE* buffer;
|
||||
size_t blockSize = 0;
|
||||
size_t commitSize = 0;
|
||||
|
||||
size += size % bb->pageSize;
|
||||
|
||||
if (size <= bb->size)
|
||||
@ -99,14 +97,11 @@ BOOL BipBuffer_Grow(wBipBuffer* bb, size_t size)
|
||||
}
|
||||
|
||||
BipBuffer_Clear(bb);
|
||||
|
||||
free(bb->buffer);
|
||||
bb->buffer = buffer;
|
||||
bb->size = size;
|
||||
|
||||
bb->blockA.index = 0;
|
||||
bb->blockA.size = commitSize;
|
||||
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
@ -141,7 +136,6 @@ BYTE* BipBuffer_WriteTryReserve(wBipBuffer* bb, size_t size, size_t* reserved)
|
||||
if (!bb->blockB.size)
|
||||
{
|
||||
/* block B does not exist */
|
||||
|
||||
reservable = bb->size - bb->blockA.index - bb->blockA.size; /* space after block A */
|
||||
|
||||
if (reservable >= bb->blockA.index)
|
||||
@ -154,7 +148,6 @@ BYTE* BipBuffer_WriteTryReserve(wBipBuffer* bb, size_t size, size_t* reserved)
|
||||
|
||||
bb->writeR.size = reservable;
|
||||
*reserved = reservable;
|
||||
|
||||
bb->writeR.index = bb->blockA.index + bb->blockA.size;
|
||||
return &bb->buffer[bb->writeR.index];
|
||||
}
|
||||
@ -167,13 +160,11 @@ BYTE* BipBuffer_WriteTryReserve(wBipBuffer* bb, size_t size, size_t* reserved)
|
||||
|
||||
bb->writeR.size = size;
|
||||
*reserved = size;
|
||||
|
||||
bb->writeR.index = 0;
|
||||
return bb->buffer;
|
||||
}
|
||||
|
||||
/* block B exists */
|
||||
|
||||
reservable = bb->blockA.index - bb->blockB.index - bb->blockB.size; /* space after block B */
|
||||
|
||||
if (size < reservable)
|
||||
@ -184,7 +175,6 @@ BYTE* BipBuffer_WriteTryReserve(wBipBuffer* bb, size_t size, size_t* reserved)
|
||||
|
||||
bb->writeR.size = reservable;
|
||||
*reserved = reservable;
|
||||
|
||||
bb->writeR.index = bb->blockB.index + bb->blockB.size;
|
||||
return &bb->buffer[bb->writeR.index];
|
||||
}
|
||||
@ -193,7 +183,6 @@ BYTE* BipBuffer_WriteReserve(wBipBuffer* bb, size_t size)
|
||||
{
|
||||
BYTE* block = NULL;
|
||||
size_t reserved = 0;
|
||||
|
||||
block = BipBuffer_WriteTryReserve(bb, size, &reserved);
|
||||
|
||||
if (reserved == size)
|
||||
@ -203,7 +192,6 @@ BYTE* BipBuffer_WriteReserve(wBipBuffer* bb, size_t size)
|
||||
return NULL;
|
||||
|
||||
block = BipBuffer_WriteTryReserve(bb, size, &reserved);
|
||||
|
||||
return block;
|
||||
}
|
||||
|
||||
@ -234,16 +222,22 @@ void BipBuffer_WriteCommit(wBipBuffer* bb, size_t size)
|
||||
BipBlock_Clear(bb->writeR);
|
||||
}
|
||||
|
||||
int BipBuffer_Write(wBipBuffer* bb, BYTE* data, size_t size)
|
||||
SSIZE_T BipBuffer_Write(wBipBuffer* bb, const BYTE* data, size_t size)
|
||||
{
|
||||
int status = 0;
|
||||
size_t status = 0;
|
||||
BYTE* block = NULL;
|
||||
size_t writeSize = 0;
|
||||
size_t blockSize = 0;
|
||||
|
||||
if (!bb)
|
||||
if (size == 0)
|
||||
return 0;
|
||||
|
||||
if (!bb || !data)
|
||||
return -1;
|
||||
|
||||
if (size > SSIZE_MAX)
|
||||
size = SSIZE_MAX;
|
||||
|
||||
block = BipBuffer_WriteReserve(bb, size);
|
||||
|
||||
if (!block)
|
||||
@ -260,10 +254,10 @@ int BipBuffer_Write(wBipBuffer* bb, BYTE* data, size_t size)
|
||||
|
||||
CopyMemory(block, &data[status], writeSize);
|
||||
BipBuffer_WriteCommit(bb, writeSize);
|
||||
status += (int) writeSize;
|
||||
status += writeSize;
|
||||
|
||||
if ((status == size) || (writeSize < blockSize))
|
||||
return status;
|
||||
return (SSIZE_T)status;
|
||||
}
|
||||
|
||||
block = BipBuffer_WriteTryReserve(bb, size - status, &blockSize);
|
||||
@ -277,13 +271,13 @@ int BipBuffer_Write(wBipBuffer* bb, BYTE* data, size_t size)
|
||||
|
||||
CopyMemory(block, &data[status], writeSize);
|
||||
BipBuffer_WriteCommit(bb, writeSize);
|
||||
status += (int) writeSize;
|
||||
status += writeSize;
|
||||
|
||||
if ((status == size) || (writeSize < blockSize))
|
||||
return status;
|
||||
return (SSIZE_T)status;
|
||||
}
|
||||
|
||||
return status;
|
||||
return (SSIZE_T)status;
|
||||
}
|
||||
|
||||
BYTE* BipBuffer_ReadTryReserve(wBipBuffer* bb, size_t size, size_t* reserved)
|
||||
@ -349,16 +343,22 @@ void BipBuffer_ReadCommit(wBipBuffer* bb, size_t size)
|
||||
}
|
||||
}
|
||||
|
||||
int BipBuffer_Read(wBipBuffer* bb, BYTE* data, size_t size)
|
||||
SSIZE_T BipBuffer_Read(wBipBuffer* bb, BYTE* data, size_t size)
|
||||
{
|
||||
int status = 0;
|
||||
size_t status = 0;
|
||||
BYTE* block = NULL;
|
||||
size_t readSize = 0;
|
||||
size_t blockSize = 0;
|
||||
|
||||
if (!bb)
|
||||
if (size == 0)
|
||||
return 0;
|
||||
|
||||
if (!bb || !data)
|
||||
return -1;
|
||||
|
||||
if (size > SSIZE_MAX)
|
||||
size = SSIZE_MAX;
|
||||
|
||||
block = BipBuffer_ReadTryReserve(bb, 0, &blockSize);
|
||||
|
||||
if (block)
|
||||
@ -370,10 +370,10 @@ int BipBuffer_Read(wBipBuffer* bb, BYTE* data, size_t size)
|
||||
|
||||
CopyMemory(&data[status], block, readSize);
|
||||
BipBuffer_ReadCommit(bb, readSize);
|
||||
status += (int) readSize;
|
||||
status += readSize;
|
||||
|
||||
if ((status == size) || (readSize < blockSize))
|
||||
return status;
|
||||
return (SSIZE_T)status;
|
||||
}
|
||||
|
||||
block = BipBuffer_ReadTryReserve(bb, 0, &blockSize);
|
||||
@ -387,13 +387,13 @@ int BipBuffer_Read(wBipBuffer* bb, BYTE* data, size_t size)
|
||||
|
||||
CopyMemory(&data[status], block, readSize);
|
||||
BipBuffer_ReadCommit(bb, readSize);
|
||||
status += (int) readSize;
|
||||
status += readSize;
|
||||
|
||||
if ((status == size) || (readSize < blockSize))
|
||||
return status;
|
||||
return (SSIZE_T)status;
|
||||
}
|
||||
|
||||
return status;
|
||||
return (SSIZE_T)status;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -403,15 +403,12 @@ int BipBuffer_Read(wBipBuffer* bb, BYTE* data, size_t size)
|
||||
wBipBuffer* BipBuffer_New(size_t size)
|
||||
{
|
||||
wBipBuffer* bb;
|
||||
|
||||
bb = (wBipBuffer*) calloc(1, sizeof(wBipBuffer));
|
||||
|
||||
if (bb)
|
||||
{
|
||||
SYSTEM_INFO si;
|
||||
|
||||
GetSystemInfo(&si);
|
||||
|
||||
bb->pageSize = (size_t) si.dwPageSize;
|
||||
|
||||
if (bb->pageSize < 4096)
|
||||
@ -433,6 +430,5 @@ void BipBuffer_Free(wBipBuffer* bb)
|
||||
return;
|
||||
|
||||
BipBuffer_FreeBuffer(bb);
|
||||
|
||||
free(bb);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user