No Description

Con Kolivas ad53696f3f The longpoll blanking of the current_block data may not be happening before the work is converted and appears to be a detected block change. 14 years ago
ccan f20e25e0c0 Moved pthread mutex inits up, due to applog using a mutex causing a crash. 14 years ago
compat 4de3f32a22 Move to newer jansson library. 14 years ago
lib 8ec2dcc9b9 Mingw suseconds_t and sigaction fixes. 14 years ago
m4 8ec2dcc9b9 Mingw suseconds_t and sigaction fixes. 14 years ago
x86_64 0aa9887300 Add an sse4 algorithm to CPU mining. 14 years ago
.gitignore 91f9c527ba Rename code and application binary to cgminer version 1.0.9 preempting version 1.1.0, moving main code to main.c. 14 years ago
AUTHORS 91f9c527ba Rename code and application binary to cgminer version 1.0.9 preempting version 1.1.0, moving main code to main.c. 14 years ago
COPYING 702e2ac811 Convert over to autotools. Release version 0.1. 15 years ago
ChangeLog 702e2ac811 Convert over to autotools. Release version 0.1. 15 years ago
LICENSE 702e2ac811 Convert over to autotools. Release version 0.1. 15 years ago
Makefile.am 0aa9887300 Add an sse4 algorithm to CPU mining. 14 years ago
NEWS b4430f1247 Document changes. 14 years ago
README b4430f1247 Document changes. 14 years ago
arg-nonnull.h 3320c627f0 Added previously missing gnulib files. 14 years ago
autogen.sh 513b445d6a autogen.sh fix 14 years ago
c++defs.h 3320c627f0 Added previously missing gnulib files. 14 years ago
compat.h 31d98cf167 Fix suseconds_t for OSX. 14 years ago
configure.ac 3f202fe8cc Bump version number. 14 years ago
elist.h 4f7a51e9ed Move all RPC I/O to separate thread. 15 years ago
example-cfg.json 594fe678fb example-cfg.json: remove extraneous commas, which broke JSON decode 15 years ago
findnonce.c 1c070475c3 Cycling over 1026 nonces is a remnant of old code not relevant now and can just lead to repeat submission of the same block increasing rejects. 14 years ago
findnonce.h eea05c05b8 Update kernel with a shorter output path, and use 4k output buffer to match OS page sizes. 14 years ago
main.c ad53696f3f The longpoll blanking of the current_block data may not be happening before the work is converted and appears to be a detected block change. 14 years ago
miner.h b0a8f279f7 Implement the ability to live add, enable, disable, and switch to pools. 14 years ago
mkinstalldirs ec8319176e Build on windows using mingw32. 14 years ago
mknsis.sh a7518360ad Windows build tweaks. 15 years ago
ocl.c 1c67f6068c Sometimes the cl compiler generates zero sized binaries and only a reboot seems to fix it. 14 years ago
ocl.h a93b22c630 Make it possible to build without GPU mining by picking up HAVE_OPENCL from config.h. 14 years ago
phatk110714.cl 009e8f31c5 Shorten the code path in the kernel even more. 14 years ago
poclbm110717.cl a7707a26cb Rename the poclbm file to ensure a new binary is built since. 14 years ago
sha256_4way.c 5007805d1f Update CPU reentrant scan code to work properly for extended periods up to scantime and adjust rate properly. 14 years ago
sha256_cryptopp.c 0c49935250 Fix CPU mining with other algorithms not working. 14 years ago
sha256_generic.c 0c49935250 Fix CPU mining with other algorithms not working. 14 years ago
sha256_sse2_amd64.c 0aa9887300 Add an sse4 algorithm to CPU mining. 14 years ago
sha256_sse4_amd64.c 0aa9887300 Add an sse4 algorithm to CPU mining. 14 years ago
sha256_via.c 0c49935250 Fix CPU mining with other algorithms not working. 14 years ago
util.c b0a8f279f7 Implement the ability to live add, enable, disable, and switch to pools. 14 years ago
warn-on-use.h 3320c627f0 Added previously missing gnulib files. 14 years ago

README


This is a multi-threaded multi-pool CPU and GPU miner for bitcoin.

License: GPLv2. See COPYING for details.

Dependencies:
libcurl http://curl.haxx.se/libcurl/
jansson http://www.digip.org/jansson/
(jansson is included in-tree and not necessary)
libncurses5-dev (or libpdcurses on WIN32)

Basic *nix build instructions:
To build with GPU mining support:
Install AMD APP sdk, latest version - there is no official place to
install it so just keep track of where it is if you're not installing
the include files and library files into the system directory.
(Do NOT install the ati amd sdk if you are on nvidia)

The easiest way to install the ATI AMD SPP sdk on linux is to actually put it
into a system location. Then building will be simpler. Download the correct
version for either 32 bit or 64 bit from here:
http://developer.amd.com/sdks/AMDAPPSDK/downloads/Pages/default.aspx

This will give you a file with a name like AMD-APP-SDK-v2.4-lnx64.tgz

Then:

sudo su
cd /opt
tar xf /path/to/AMD-APP-SDK-v2.4-lnx64.tgz
cd /
tar xf /opt/AMD-APP-SDK-v2.4-lnx64/icd-registration.tgz
ln -s /opt/AMD-APP-SDK-v2.4-lnx64/include/CL /usr/include
ln -s /opt/AMD-APP-SDK-v2.4-lnx64/lib/x86_64/* /usr/lib/
ldconfig

If you are on 32 bit, x86_64 in the 2nd last line should be x86

To actually build:

./autogen.sh # only needed if building from git repo
CFLAGS="-O3 -Wall -march=native" ./configure
or if you haven't installed the ati files in system locations:
CFLAGS="-O3 -Wall -march=native -I" LDFLAGS="-L ./configure
make

If it finds the opencl files it will inform you with
"OpenCL: FOUND. GPU mining support enabled."

Basic WIN32 build instructions (on Fedora 13; requires mingw32):
./autogen.sh # only needed if building from git repo
rm -f mingw32-config.cache
MINGW32_CFLAGS="-O3 -Wall -msse2" mingw32-configure
make
./mknsis.sh

Native WIN32 build instructions (on mingw32, on windows):
Install AMD APP sdk, latest version
(Do NOT install the ati amd sdk if you are on nvidia)
Install mingw32
Install libcurl, copy libcurl.m4 into /mingw/share/aclocal
Run:
autoreconf -fvi
CFLAGS="-O3 -Wall -msse2 -I" LDFLAGS="-L" ./configure
make

Usage instructions: Run "cgminer --help" to see options.


EXECUTIVE SUMMARY ON USAGE:

Single pool, regular desktop:

cgminer -o http://pool:port -u username -p password

Single pool, dedicated miner:

cgminer -o http://pool:port -u username -p password -I 8

Multiple pool, dedicated miner:

cgminer -o http://pool1:port -u pool1username -p pool1password -o http://pool2:port -u pool2usernmae -p pool2password -I 8


Also many issues and FAQs are covered in the forum thread
dedicated to this program,
http://forum.bitcoin.org/index.php?topic=28402.0

The output line shows the following:
[(5s):204.4 (avg):203.1 Mh/s] [Q:56 A:51 R:4 HW:0 E:91% U:2.47/m]

Each column is as follows:
A 5 second exponentially decaying average hash rate
An all time average hash rate
The number of requested work items
The number of accepted shares
The number of rejected shares
The number of hardware erorrs
The efficiency defined as the accepted shares / requested work
The utility defines as the number of shares / minute

The cgminer status line shows:
TQ: 1 ST: 1 LS: 0 SS: 0 DW: 0 NB: 1 LW: 8 LO: 1 RF: 1 I: 2

TQ is Total Queued work items.
ST is STaged work items (ready to use).
LS is Longpoll Staged work items (mandatory new work)
SS is Stale Shares discarded (detected and not submitted so don't count as rejects)
DW is Discarded Work items (work from block no longer valid to work on)
NB is New Blocks detected on the network
LW is Locally generated Work items (during slow server providing work)
LO is Local generation Occasions (server slow to provide work)
RF is Remote Fail occasions (server slow to accept work)
I is current Intensity (changes in dynamic mode).

NOTE: Running intensities above 9 with current hardware is likely to only
diminish return performance even if the hash rate might appear better. A good
starting baseline intensity to try on dedicated miners is 8. Higher values are
there to cope with future improvements in hardware.


FAILOVER STRATEGIES WITH MULTIPOOL:
A number of different strategies for dealing with multipool setups are
available. Each has their advantages and disadvantages so multiple strategies
are available by user choice, as per the following list:

FAILOVER:
The default strategy is failover. This means that if you input a number of
pools, it will try to use them as a priority list, moving away from the 1st
to the 2nd, 2nd to 3rd and so on. If any of the earlier pools recover, it will
move back to the higher priority ones.

ROUND ROBIN:
This strategy only moves from one pool to the next when the current one falls
idle and makes no attempt to move otherwise.

ROTATE:
This strategy moves at user-defined intervals from one active pool to the next,
skipping pools that are idle.

LOAD BALANCE:
This strategy sends work in equal amounts to all the pools specified. If any
pool falls idle, the rest will take up the slack keeping the miner busy.