if (pthread_mutex_unlock(&ctx->queueMutex)) { return NULL; }
return opaque;
}
- {
- /* Pop a job off the queue */
- POOL_job job = ctx->queue[ctx->queueHead];
+ /* Pop a job off the queue */
+ { POOL_job job = ctx->queue[ctx->queueHead];
ctx->queueHead = (ctx->queueHead + 1) % ctx->queueSize;
/* Unlock the mutex, signal a pusher, and run the job */
if (pthread_mutex_unlock(&ctx->queueMutex)) { return NULL; }
ctx->numThreads = i;
POOL_free(ctx);
return NULL;
- }
- }
+ } }
ctx->numThreads = numThreads;
}
return ctx;
{ size_t i;
for (i = 0; i < ctx->numThreads; ++i) {
pthread_join(ctx->threads[i], NULL);
- }
- }
+ } }
}
void POOL_free(POOL_ctx *ctx) {
if (!ctx) { return; }
pthread_mutex_lock(&ctx->queueMutex);
- {
- POOL_job job = {function, opaque};
+ { POOL_job const job = {function, opaque};
/* Wait until there is space in the queue for the new job */
size_t newTail = (ctx->queueTail + 1) % ctx->queueSize;
while (ctx->queueHead == newTail && !ctx->shutdown) {
return 0;
}
-size_t ZSTDMT_compressCCtx(ZSTDMT_CCtx* cctx,
+size_t ZSTDMT_compressCCtx(ZSTDMT_CCtx* mtctx,
void* dst, size_t dstCapacity,
const void* src, size_t srcSize,
int compressionLevel)
{
- ZSTDMT_jobAgency* jobAgency = &cctx->jobAgency;
+ ZSTDMT_jobAgency* jobAgency = &mtctx->jobAgency;
ZSTD_parameters const params = ZSTD_getParams(compressionLevel, srcSize, 0);
size_t const frameSizeTarget = (size_t)1 << (params.cParams.windowLog + 2);
unsigned const nbFramesMax = (unsigned)(srcSize / frameSizeTarget) + (srcSize < frameSizeTarget) /* min 1 */;
- unsigned const nbFrames = MIN(nbFramesMax, cctx->nbThreads);
+ unsigned const nbFrames = MIN(nbFramesMax, mtctx->nbThreads);
size_t const avgFrameSize = (srcSize + (nbFrames-1)) / nbFrames;
size_t remainingSrcSize = srcSize;
const char* const srcStart = (const char*)src;
#include "util.h" /* UTIL_getFileSize, UTIL_sleep */
#include <stdlib.h> /* malloc, free */
#include <string.h> /* memset */
-#include <stdio.h> /* fprintf, fopen, ftello64 */
+#include <stdio.h> /* fprintf, fopen */
#include <time.h> /* clock_t, clock, CLOCKS_PER_SEC */
#include "mem.h"
exit(error); \
}
+/* *************************************
+* Time
+***************************************/
+/* for posix only - proper detection macros to setup */
+#include <unistd.h>
+#include <sys/times.h>
+
+typedef unsigned long long clock_us_t;
+static clock_us_t BMK_clockMicroSec()
+{
+ static clock_t _ticksPerSecond = 0;
+ if (_ticksPerSecond <= 0) _ticksPerSecond = sysconf(_SC_CLK_TCK);
+
+ struct tms junk; clock_t newTicks = (clock_t) times(&junk); (void)junk;
+ return ((((clock_us_t)newTicks)*(1000000))/_ticksPerSecond);
+}
+
/* *************************************
* Benchmark Parameters
UTIL_getTime(&coolTime);
DISPLAYLEVEL(2, "\r%79s\r", "");
while (!cCompleted || !dCompleted) {
- UTIL_time_t clockStart;
/* overheat protection */
if (UTIL_clockSpanMicro(coolTime, ticksPerSecond) > ACTIVEPERIOD_MICROSEC) {
}
if (!g_decodeOnly) {
+ clock_us_t clockStart;
/* Compression */
DISPLAYLEVEL(2, "%2s-%-17.17s :%10u ->\r", marks[markNb], displayName, (U32)srcSize);
if (!cCompleted) memset(compressedBuffer, 0xE5, maxCompressedSize); /* warm up and erase result buffer */
UTIL_sleepMilli(1); /* give processor time to other processes */
UTIL_waitForNextTick(ticksPerSecond);
- UTIL_getTime(&clockStart);
+ clockStart = BMK_clockMicroSec();
if (!cCompleted) { /* still some time to do compression tests */
ZSTD_parameters zparams = ZSTD_getParams(cLevel, avgSize, dictBufferSize);
blockTable[blockNb].cSize = rSize;
}
nbLoops++;
- } while (UTIL_clockSpanMicro(clockStart, ticksPerSecond) < clockLoop);
+ } while (BMK_clockMicroSec() - clockStart < clockLoop);
ZSTD_freeCDict(cdict);
- { U64 const clockSpan = UTIL_clockSpanMicro(clockStart, ticksPerSecond);
- if (clockSpan < fastestC*nbLoops) fastestC = clockSpan / nbLoops;
- totalCTime += clockSpan;
+ { clock_us_t const clockSpanMicro = BMK_clockMicroSec() - clockStart;
+ if (clockSpanMicro < fastestC*nbLoops) fastestC = clockSpanMicro / nbLoops;
+ totalCTime += clockSpanMicro;
cCompleted = (totalCTime >= maxTime);
} }