2014-04-03 19:12:35 +03:00
|
|
|
#ifndef OCL_H
|
|
|
|
#define OCL_H
|
2012-01-24 20:23:44 +11:00
|
|
|
|
2011-07-05 17:34:54 +10:00
|
|
|
#include "config.h"
|
2012-01-24 20:23:44 +11:00
|
|
|
|
|
|
|
#include <stdbool.h>
|
2011-06-14 10:32:54 +10:00
|
|
|
#ifdef __APPLE_CC__
|
|
|
|
#include <OpenCL/opencl.h>
|
|
|
|
#else
|
|
|
|
#include <CL/cl.h>
|
|
|
|
#endif
|
|
|
|
|
2012-02-10 13:18:16 +11:00
|
|
|
#include "miner.h"
|
|
|
|
|
2014-05-25 00:27:42 +02:00
|
|
|
typedef struct __clState {
|
2011-06-14 10:32:54 +10:00
|
|
|
cl_context context;
|
|
|
|
cl_kernel kernel;
|
2014-05-27 03:13:30 +02:00
|
|
|
cl_kernel *extra_kernels;
|
|
|
|
size_t n_extra_kernels;
|
2011-06-14 10:32:54 +10:00
|
|
|
cl_command_queue commandQueue;
|
|
|
|
cl_program program;
|
|
|
|
cl_mem outputBuffer;
|
2012-07-13 20:28:36 +10:00
|
|
|
cl_mem CLbuffer0;
|
|
|
|
cl_mem padbuffer8;
|
2014-02-19 23:06:29 +01:00
|
|
|
unsigned char cldata[80];
|
2012-01-24 20:23:44 +11:00
|
|
|
bool hasBitAlign;
|
2012-02-09 15:15:03 +01:00
|
|
|
bool hasOpenCL11plus;
|
2013-10-12 16:54:39 +11:00
|
|
|
bool hasOpenCL12plus;
|
2012-03-27 22:10:17 +11:00
|
|
|
bool goffset;
|
2012-02-22 16:54:06 +11:00
|
|
|
cl_uint vwidth;
|
2011-08-15 20:26:46 +10:00
|
|
|
size_t max_work_size;
|
2012-02-22 16:54:06 +11:00
|
|
|
size_t wsize;
|
EXPERIMENTAL: A new way of setting intensity; introducing xintensity!
All of this is credited to ArGee of RGMiner, he did the initial ground work for this setting.
This new setting allows for a much finer grained intensity setting and also opens up for dual gpu threads on devices not previously able to. Note: make sure to use lower thread-concurrency values when you increase cpu threads.
Intensity is currently used to spawn GPU threads as a simple 2^value setting.
I:13 = 8192 threads
I:15 = 32768 threads
I:17 = 131072 threads
I:18 = 262144 threads
I:19 = 524288 threads
I:20 = 1048576 threads
Notice how the higher settings increase thread count tremendously.
Now enter the xintensity setting (Yes, I am a genius with my naming convention!).
It is simply a shader multiplier, obviously based on the amount of shaders you got on a card, this should allow the same value to scale with different card models.
6970 with 1536 shaders: xI:64 = 98304 threads
R9 280X with 2048 shaders: xI:64 = 131072 threads
R9 290 with 2560 shaders: xI:64 = 180224 threads
R9 290X with 2816 shaders: xI:64 = 163840 threads
6970 with 1536 shaders: xI:300 = 460800 threads
R9 280X with 2048 shaders: xI:300 = 614400 threads
R9 290 with 2560 shaders: xI:300 = 768000 threads
R9 290X with 2816 shaders: xI:300 = 844800 threads
It's now much easier to control thread intensity and it potentially allows for a uniform way of setting the intensity on your system. I'm very interested in constructive feedback, as I do not have access to a lot of different card models.
This change has been tested on 6970, R9 290, R9 290X - all with equal or a little better speeds than regular intensity setting after a little tuning, but your mileage may vary. Don't fret it, if this doesn't work for you, the regular intensity setting is still available.
Conflicts:
driver-opencl.c
sgminer.c
2014-01-18 16:49:15 +01:00
|
|
|
size_t compute_shaders;
|
2011-06-14 10:32:54 +10:00
|
|
|
} _clState;
|
|
|
|
|
|
|
|
extern char *file_contents(const char *filename, int *length);
|
2012-02-04 14:47:23 +11:00
|
|
|
extern int clDevicesNum(void);
|
2014-03-23 07:25:55 +01:00
|
|
|
extern _clState *initCl(unsigned int gpu, char *name, size_t nameSize, algorithm_t *algorithm);
|
2014-04-03 19:12:35 +03:00
|
|
|
|
|
|
|
#endif /* OCL_H */
|