1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-15 00:59:59 +00:00
sgminer/doc/KERNEL.md

100 lines
2.4 KiB
Markdown
Raw Normal View History

# Kernels
## Available OpenCL kernels
See directory `kernel`.
2014-01-23 18:25:12 +02:00
## Parameter configuration
### Common
In general, switching kernels requires reconfiguring mining parameters,
such as (but not necessarily limited to) `thread-concurrency`, `intensity`,
`gpu-engine` and `gpu-memclock`.
A description of how to do this is available in `doc/MINING`.
### alexkarnew
2014-01-28 01:00:21 +02:00
Alexey Karimov's optimised kernel, based on `ckolivas`. For Catalyst >=13.4.
2014-01-23 18:25:12 +02:00
Only supports `vectors=1`.
[Announcement](https://litecointalk.org/index.php?topic=4082.0).
### alexkarold
2014-01-28 01:00:21 +02:00
Alexey Karimov's optimised kernel, based on `ckolivas`. For Catalyst <13.4.
2014-01-23 18:25:12 +02:00
Only supports `vectors=1`.
[Announcement](https://litecointalk.org/index.php?topic=4082.0).
### ckolivas
The original Colin Percival `scrypt` kernel, maintained for a long time by
Con Kolivas in `cgminer` and renamed to reflect the fact.
Only supports `vectors=1`.
### psw
Pavel Semjanov optimised kernel, SHA256 speedups.
[Announcement](https://bitcointalk.org/index.php?topic=369858.0).
2014-01-23 18:25:12 +02:00
### zuikkis
Zuikkis' optimised kernel, based on `ckolivas`.
Only supports `vectors=1`, `lookup-gap=2` and `worksize=256`.
[Announcement](https://litecointalk.org/index.php?topic=6058.msg90873#msg90873).
## Submitting new kernels
### Requirements
2014-01-23 18:25:12 +02:00
* OpenCL source code only, licenced under GPLv3 (or later).
* Not hard-coded for a specific GPU model or manufacturer.
2014-02-06 14:54:08 +02:00
* Known limitations and any specific configuration quirks must be
mentioned.
### Procedure
2014-02-06 14:54:08 +02:00
* Copy the kernel you wish to modify, change the file encoding to UTF-8
2014-02-01 16:19:04 +02:00
and commit it without any further modifications.
This way, it is easy to verify that there are no hidden changes. Note in
the commit message which kernel is used as a base.
2014-02-06 14:54:08 +02:00
* Make changes to the kernel. Commit them.
2014-01-23 18:25:12 +02:00
This allows to produce a diff that makes sense.
2014-02-06 14:54:08 +02:00
* Search for `KL_CKOLIVAS and CKOLIVAS_KERNNAME` in the top-level source
directory and make additions to the listed files in order to integrate
the new kernel.
Now it can be selected when starting via the `--kernel` argument or
`kernel` configuration option.
2014-02-06 14:54:08 +02:00
* Recompile and test that the kernel actually works.
2014-02-06 14:54:08 +02:00
* Add yourself to the "kernels" section in `AUTHORS.md`. Keep it short.
2014-02-01 16:19:04 +02:00
2014-02-06 14:54:08 +02:00
* Submit a pull request on GitHub, file it at the issue tracker, or mail
it.
Outline the changes made, known limitations, and tested GPUs. List
2014-01-23 18:25:12 +02:00
your git repository and branch name. The current repository and issue
tracker links should be in `README.md`.