1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-08 22:08:02 +00:00
sgminer/doc/KERNEL.md
2014-02-06 14:54:08 +02:00

2.4 KiB

Kernels

Available OpenCL kernels

See directory kernel.

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

Alexey Karimov's optimised kernel, based on ckolivas. For Catalyst >=13.4.

Only supports vectors=1.

Announcement.

alexkarold

Alexey Karimov's optimised kernel, based on ckolivas. For Catalyst <13.4.

Only supports vectors=1.

Announcement.

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.

zuikkis

Zuikkis' optimised kernel, based on ckolivas.

Only supports vectors=1, lookup-gap=2 and worksize=256.

Announcement.

Submitting new kernels

Requirements

  • OpenCL source code only, licenced under GPLv3 (or later).
  • Not hard-coded for a specific GPU model or manufacturer.
  • Known limitations and any specific configuration quirks must be mentioned.

Procedure

  • Copy the kernel you wish to modify, change the file encoding to UTF-8 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.

  • Make changes to the kernel. Commit them.

This allows to produce a diff that makes sense.

  • 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.

  • Recompile and test that the kernel actually works.

  • Add yourself to the "kernels" section in AUTHORS.md. Keep it short.

  • 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 your git repository and branch name. The current repository and issue tracker links should be in README.md.