1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-22 20:44:19 +00:00

Adjust opencl intensity when adjusting thread count to prevent it getting pegged at a value below the minimum threads possible.

This commit is contained in:
Con Kolivas 2012-08-31 09:13:19 +10:00
parent f97bf2e2ac
commit f1c6ae22f7

View File

@ -1106,20 +1106,23 @@ static cl_int queue_scrypt_kernel(_clState *clState, dev_blk_ctx *blk, __maybe_u
} }
#endif #endif
static void set_threads_hashes(unsigned int vectors, unsigned int *threads, static void set_threads_hashes(unsigned int vectors,int64_t *hashes, size_t *globalThreads,
int64_t *hashes, size_t *globalThreads, unsigned int minthreads, __maybe_unused int *intensity)
unsigned int minthreads, int intensity)
{ {
if (opt_scrypt) { unsigned int threads = 0;
if (intensity < 0)
intensity = 0; while (threads < minthreads) {
*threads = 1 << intensity; threads = 1 << ((opt_scrypt ? 0 : 15) + *intensity);
} else if (threads < minthreads) {
*threads = 1 << (15 + intensity); if (likely(*intensity < MAX_INTENSITY))
if (*threads < minthreads) (*intensity)++;
*threads = minthreads; else
*globalThreads = *threads; threads = minthreads;
*hashes = *threads * vectors; }
}
*globalThreads = threads;
*hashes = threads * vectors;
} }
#endif /* HAVE_OPENCL */ #endif /* HAVE_OPENCL */
@ -1499,15 +1502,13 @@ static int64_t opencl_scanhash(struct thr_info *thr, struct work *work,
cl_int status; cl_int status;
size_t globalThreads[1]; size_t globalThreads[1];
size_t localThreads[1] = { clState->wsize }; size_t localThreads[1] = { clState->wsize };
unsigned int threads;
int64_t hashes; int64_t hashes;
/* This finish flushes the readbuffer set with CL_FALSE later */ /* This finish flushes the readbuffer set with CL_FALSE later */
if (!gpu->dynamic) if (!gpu->dynamic)
clFinish(clState->commandQueue); clFinish(clState->commandQueue);
set_threads_hashes(clState->vwidth, &threads, &hashes, globalThreads, set_threads_hashes(clState->vwidth, &hashes, globalThreads, localThreads[0], &gpu->intensity);
localThreads[0], gpu->intensity);
if (hashes > gpu->max_hashes) if (hashes > gpu->max_hashes)
gpu->max_hashes = hashes; gpu->max_hashes = hashes;