1
0
mirror of https://github.com/GOSTSec/sgminer synced 2025-01-11 15:27:53 +00:00
Commit Graph

210 Commits

Author SHA1 Message Date
Kano
ec2c0b784f Add API commands: config, switchpool, gpu settings, save 2012-01-22 18:24:55 +11:00
Con Kolivas
e15d57d729 Implement socks4 proxy support. 2012-01-22 09:36:21 +11:00
Con Kolivas
2d5bbc7756 Provide nanosleep() equivalent for windows. 2012-01-22 01:40:29 +11:00
Con Kolivas
1b0b7e4a7c Merge pull request #78 from luke-jr/bugfix_adl
Bugfix: Iterate over devices rather than threads for watchdog (and ADL)
2012-01-20 22:02:07 -08:00
Luke Dashjr
9a0bcc8890 Bugfix: Iterate over devices rather than threads for watchdog (and ADL) 2012-01-20 17:29:52 -05:00
Con Kolivas
5179d22463 Introduce a --net-delay option which guarantees at least 250ms between any networking requests to not overload slow routers. 2012-01-20 15:36:42 +11:00
Con Kolivas
9840c12e74 Generalise locking init code. 2012-01-20 14:47:17 +11:00
Luke Dashjr
3cb7221878 Restore old ugly inconsistent display of ADL information before the standard info 2012-01-19 21:57:08 -05:00
Luke Dashjr
5dfc8b694f BitForce FPGA support
cgminer will scan for and mine BitForce FPGAs on USB ports by providing the
new --scan-serial <device> option, or autodetect them by searching
/dev/serial/by-id for *BitFORCE_SHA256*
2012-01-19 01:24:37 -05:00
Luke Dashjr
b9d197dee8 Refactor the CPU scanhash_* functions to use a common API. Fixes bugs.
- Before, some returned bool, and others returned int (which was then turned
  into a bool with a comparison); now, everything returns a bool
- Before, some set hashes_done to nonce - 1 when a share was found and others
  set it to nonce + 1 or 2. This caused some algorithms to scan/submit shares
  twice with the new cpu_scanhash function. Now, it has all been replaced with
  last_nonce, which is set to the final nonce checked by the scanhash_* func.
- VIA needs the full data, and cannot use midstate. All the others were
  expecting midstate and data+64 for their parameters. Now, we pass midstate
  and the full data pointer, and let the scanhash_* function choose which to
  use.
2012-01-17 17:32:07 -05:00
Luke Dashjr
a4d1fe1e5d Refactor miner_thread to be common code for any kind of device
This expands on the device API, by taking the actual main thread out of the
device's code, and calling the API only for specific tasks. This brings
various changes that were made to the GPU thread code into the CPU miner.
It also fixes a bug where shares found on old GPU work were discarded when
it switched to a new work.
2012-01-16 23:59:13 -05:00
Luke Dashjr
845961af66 Refactor to abstract device-specific code 2012-01-08 20:01:35 -05:00
Kano
5033dcd355 fix test/set of thr->pth to also work in windows 2011-12-27 18:33:49 +11:00
Con Kolivas
2257b5023a Simplify longpoll changeover to just check which pool it should grab its next longpoll from. This should prevent locking hangs and thread cancellation
crashes.
2011-12-27 11:40:53 +11:00
Con Kolivas
b69aa23470 Use control_lock to protect thr->pth for thread creation/destruction. 2011-12-26 10:50:00 +11:00
Kano
50a0892254 2.0.8x Full GPU stats, descriptive field names and --api-description 2011-12-04 00:24:26 +11:00
Kano
45068ced82 Version 2.0.8w (windows changes) 2011-11-29 11:07:27 +11:00
Kano
45ebf2c5b4 Fix threading issues and bugs 2011-11-24 20:41:31 +11:00
Kano
d234b857ff API v0.2 Added GPU commands and improved messages 2011-11-24 12:59:30 +11:00
Kano
df3fad3dbc Add API options for port and listen mode 2011-11-23 22:22:10 +11:00
Kano
49532277df Add summary command 2011-11-23 17:01:45 +11:00
Kano
bbe1702d66 Add quit command 2011-11-23 16:25:13 +11:00
Kano
2358056606 API v0.1 2011-11-23 14:35:49 +11:00
Con Kolivas
b0bfd816d6 Don't build VIA on apple since -a auto bombs instead of gracefully ignoring VIA failing. 2011-11-11 19:35:41 +11:00
Con Kolivas
a70629a701 Make longpoll do a mandatory flushing of all work even if the block hasn't changed, thus supporting longpoll initiated work change of any sort and
merged mining.
2011-11-01 15:19:26 +11:00
Con Kolivas
8c63061eaa Allow a fixed speed difference between memory and GPU clock speed that will change memory speed when GPU speed is changed in autotune mode. 2011-10-23 20:52:16 +11:00
Con Kolivas
5133cf5b06 Add altivec 4 way support courtesy of Gilles Risch. 2011-10-09 12:22:00 +11:00
Con Kolivas
28796de72e Merge https://github.com/geekmug/cgminer into gitmug 2011-09-27 11:14:43 +10:00
Con Kolivas
4128b954a6 Add a --donation feature which reads a url/userpass from the author's site and contributes a percentage of getworks to the author, but default to off. 2011-09-27 11:02:45 +10:00
Scott Dial
c54b0870a8 Assiging the bswap_{16,32,64} macros to __builtin_bswap{16,32,64}. 2011-09-26 19:35:30 -04:00
Con Kolivas
21c2bc469f Make it possible to set the intensity on a per-card basis, dynamic or static values. 2011-09-26 15:24:20 +10:00
Con Kolivas
0ae3f71824 Check last temperature we reached and don't change fan speed if it's already correcting. 2011-09-23 10:46:34 +10:00
Kano
ba14a6705e Remove EOL spaces from stderr and curses 2011-09-21 21:45:24 +10:00
Con Kolivas
b8ea0dd194 Update curses logging to allow LOG_WARNING and LOG_ERR messages to still go through while within the menu, and drop share message to LOG_NOTICE. 2011-09-17 13:25:04 +10:00
Con Kolivas
67fe6ab726 Don't both with adapter speed set as it has no effect on mining speed. 2011-09-16 10:26:25 +10:00
Con Kolivas
8e2becc12d Change pth from being a pointer as we can dereference if we're unlucky on stopping longpoll. 2011-09-15 11:46:17 +10:00
Con Kolivas
833e020dfd Standardise the way all non-mining threads are destroyed to make sure we can safely cancel them, freeing ram and NULLifying pointers. 2011-09-15 10:34:59 +10:00
Con Kolivas
dff1a81da7 Use a re-entrant value to store what fanspeed we're trying to set in case the card doesn't support small changes.
Force it to a multiple of 10% if it fails on trying to speed up the fan.
2011-09-11 11:25:28 +10:00
Con Kolivas
d5fe2cfd7a Flag devices that have never started and don't allow enabling of devices without restarting them. 2011-09-11 10:48:39 +10:00
Con Kolivas
1917643dd0 Do away with the increasingly confusing and irrelevant total queued and efficiency measures per device. 2011-09-09 10:19:01 +10:00
Con Kolivas
6c8341f133 Define max gpudevices in one macro. 2011-09-08 14:44:14 +10:00
Con Kolivas
9b5cd61886 Implement accepting a range of engine speeds as well to allow a lower limit to be specified on the command line. 2011-09-08 13:04:39 +10:00
Con Kolivas
3997f308a0 Add a thermal cutoff option as well and set it to 95 degrees by default. 2011-09-07 10:43:26 +10:00
Con Kolivas
058303bcf3 Only reset values on exiting if we've ever modified them. 2011-09-07 10:00:10 +10:00
Con Kolivas
b8be1e6c15 Ignore whether the display is active or not since only display enabled devices work this way, and we skip over repeat entries anwyay. 2011-09-07 09:17:51 +10:00
Con Kolivas
2053de6d59 Add the directory name from the arguments cgminer was called from as well to allow it running from a relative pathname. 2011-09-06 10:11:34 +10:00
Con Kolivas
5fc56a45ee Force the speed to high on startup and restore it to whatever the setting was on exit. 2011-09-05 19:30:03 +10:00
Con Kolivas
47f1a75924 Implement setting the GPU powertune value of all devices or each device as a comma separated value. 2011-09-05 19:30:03 +10:00
Con Kolivas
bd292258d3 Add support for monitoring powertune setting. 2011-09-04 22:56:19 +10:00
Con Kolivas
3a5663cac1 Implement setting the GPU fan speed of all devices or each device as a comma separated value. 2011-09-04 22:25:31 +10:00
Con Kolivas
8ae273c56c Implement setting the GPU voltage of all devices or each device as a comma separated value. 2011-09-04 22:08:42 +10:00
Con Kolivas
54bc30ceec Implement setting the GPU memory clock speed of all devices or each device as a comma separated value. 2011-09-04 22:01:58 +10:00
Con Kolivas
ec8808d004 Implement setting the GPU engine clock speed of all devices or each device as a comma separated value. 2011-09-04 21:55:06 +10:00
Con Kolivas
e9b5885ebe Add a gpu autotune option which adjusts GPU speed to maintain a target temperature within the bounds of the default GPU speed and any overclocking set. 2011-09-03 22:30:11 +10:00
Con Kolivas
dcc97e45db Add an --auto-fan command line option to allow all GPUs to have autofan enabled from startup. 2011-09-03 15:46:57 +10:00
Con Kolivas
495adcbf5f Implement auto fanspeed adjustment to maintain a target temperature and fanspeed below 85%, with an overheat check that will speed the fan up to 100%. 2011-09-03 15:33:53 +10:00
Con Kolivas
35ace46325 Enable changing of engine clock setting on the fly. 2011-09-03 13:02:21 +10:00
Con Kolivas
d57cd91955 Implement ATI ADL support for GPU parameter monitoring now and setting later (temp, fan, clocks etc.).
Check for the presence of the ADL header files in ADL_SDK.
Import adl_functions.h from amd overdrive ctrl.
Implement a setup function that tries to detect GPUs that support the ADL and link in the parameters into the gpus struct.
Put a summary of monitoring information from the GPU menu.
2011-09-03 10:53:35 +10:00
Con Kolivas
063efb1996 Rename localgen occasions to getwork fail occasions since localgen is unrelated now. 2011-09-02 10:37:00 +10:00
Con Kolivas
8496534168 Add start and stop time scheduling for regular time of day running or once off start/stop options. 2011-09-01 13:19:51 +10:00
Con Kolivas
a593afdbeb Use the curses_lock to protect the curses_active variable and test it under lock. 2011-08-31 13:23:36 +10:00
Con Kolivas
4969162c03 Check for SSE2 before trying to build 32 bit SSE2 assembly version. Prevents build failure when yasm is installed but -msse2 is not specified. 2011-08-29 10:12:34 +10:00
Con Kolivas
3d5f555407 Allow a custom kernel path to be entered on the command line. 2011-08-25 14:42:03 +10:00
Con Kolivas
7dc3db2340 Implement SSE2 32 bit assembly algorithm as well. 2011-08-25 13:04:15 +10:00
Con Kolivas
dbf0a1366d Use the new hashes directly for counts instead of the fragile counters currently in use. 2011-08-24 21:50:04 +10:00
Con Kolivas
666fcc3f55 Move staged threads to hashes so we can sort them by time. 2011-08-24 12:51:38 +10:00
Con Kolivas
ced4a9ac92 Clean up the pool switching to not be dependent on whether the work can roll or not by setting a lagging flag and then the idle flag. 2011-08-23 11:40:48 +10:00
Con Kolivas
324d849bf2 Attempt to restart a GPU once every minute while it's sick.
Don't kill off the reinit thread if it fails to init a GPU but returns safely.
Only declare a GPU dead if there's been no sign of activity from the reinit thread for 10 mins.
2011-08-20 23:03:49 +10:00
Znort 987
e49bfbf2ec Add per-device statics log output 2011-08-18 12:17:10 +02:00
Phateus
d15d225a4c Changed phatk version to 2.2 2011-08-17 14:53:17 +10:00
Con Kolivas
1e77f04481 Clean up the longpoll management to ensure the right paths go to the right pool and display whether we're connected to LP or not in the status line. 2011-08-17 12:43:39 +10:00
Con Kolivas
4e48561a13 Rework the last-initialised time displayed. 2011-08-15 23:23:53 +10:00
Con Kolivas
b1289a0159 Revert "Move the non cl_ variables into the cgpu info struct to allow creating a new cl state on reinit, preserving known GPU variables."
This reverts commit 28880d0dc7.
2011-08-15 23:23:29 +10:00
Con Kolivas
7c50bb02ab Revert "Display last initialised time in gpu management info."
This reverts commit 177e07aed3.
2011-08-15 23:23:20 +10:00
Con Kolivas
50504ef9e0 If a work item has had any mining done on it, don't consider it discarded work. 2011-08-14 13:57:58 +10:00
Con Kolivas
639d38fbd4 Revert "Make sure to give work items a starting time only once when they're staged."
This reverts commit 626ae10d7c.

Failed to address all work items.
2011-08-14 07:54:45 +10:00
Con Kolivas
626ae10d7c Make sure to give work items a starting time only once when they're staged. 2011-08-14 02:33:55 +10:00
Con Kolivas
d6dd5d700b Test each work item to see if it can be rolled instead of per-pool and roll whenever possible, adhering to the 60 second timeout. 2011-08-14 01:54:47 +10:00
Con Kolivas
177e07aed3 Display last initialised time in gpu management info. 2011-08-13 20:55:30 +10:00
Con Kolivas
28880d0dc7 Move the non cl_ variables into the cgpu info struct to allow creating a new cl state on reinit, preserving known GPU variables.
Create a new context from scratch in initCQ in case something was corrupted to maximise our chance of succesfully creating a new worker thread.
2011-08-13 20:54:20 +10:00
Con Kolivas
947a74bfa3 Differentiate thread failure from GPU failure by declaring a GPU sick first and trying to restart the thread without re-initialising the card.
If that fails, then try once more at ten minutes and declare it dead.
This should prevent an attempted re-initialising of the GPU from taking out other GPUs.
2011-07-30 01:23:17 +10:00
Con Kolivas
3803760689 Reimplement the per-thread getwork count with proper accounting at get_work(). 2011-07-29 11:11:42 +10:00
Con Kolivas
0fe22d8d94 Revert "Only update the thread getwork queue count if it actually results in a getwork request from the server."
This reverts commit 2e607d44f2.

The count looks far too difficult to add up with this change since many are queued generically.
2011-07-29 11:02:47 +10:00
Con Kolivas
2e607d44f2 Only update the thread getwork queue count if it actually results in a getwork request from the server. 2011-07-29 10:39:58 +10:00
Con Kolivas
0006eb2da4 Make the "quiet" mode still update the status and display errors, and add a new --real-quiet option which disables all output and can be set once while running. 2011-07-28 10:36:48 +10:00
Con Kolivas
e82e390295 If work has been cloned it is already at the head of the list and when being reinserted into the queue it should be placed back at the head of the list. 2011-07-27 16:40:52 +10:00
Con Kolivas
98f609b5be Sanity check to prove locking. 2011-07-27 10:31:44 +10:00
Con Kolivas
1536e085da Increase efficiency of slow mining threads such as CPU miners dramatically.
Do this by detecting which threads cannot complete searching a work item within the scantime and then divide up a work item into multiple smaller work items.
Detect the age of the work items and if they've been cloned before to prevent doing the same work over.
If the work is too old to be divided, then see if it can be time rolled and do that to generate work.
This dramatically decreases the number of queued work items from a pool leading to higher overall efficiency (but the same hashrate and share submission rate).
2011-07-26 20:48:05 +10:00
Con Kolivas
fa17f03432 Implement much more accurate rolling statistics per thread and per gpu and improve accuracy of rolling displayed values. 2011-07-26 11:58:45 +10:00
Con Kolivas
7707ed4db1 Add a menu to manage GPUs on the fly allowing you to enable/disable GPUs or try restarting them.
Keep track of which GPUs are alive versus enabled.
Start threads for devices that are even disabled, but don't allow them to start working.
2011-07-26 10:26:03 +10:00
Con Kolivas
020cf7d63f Build support in for all SSE if possible and only set the default according to machine capabilities. 2011-07-23 16:19:51 +10:00
Ycros
a150140eb7 Merge branch 'cgminer' of git://github.com/ckolivas/cgminer into cgminer 2011-07-23 16:00:49 +10:00
Con Kolivas
a9e1a25518 Make it possible to select the choice of kernel on the command line. 2011-07-23 15:15:46 +10:00
Con Kolivas
116a9dc025 Update phatk kernel to one with new parameters for slightly less overhead again.
Make the queue kernel parameters call a function pointer to select phatk or poclbm.
2011-07-23 14:17:25 +10:00
Ycros
d37c3fe56b Win32 threading and longpoll keepalive fixes. 2011-07-22 23:43:26 +10:00
Con Kolivas
ec86da70e1 Limit rolltime work generation to 10 iterations only. 2011-07-22 20:06:06 +10:00
Con Kolivas
b0a8f279f7 Implement the ability to live add, enable, disable, and switch to pools. 2011-07-22 11:46:26 +10:00
Con Kolivas
7841486f83 Add a bool for explicit enabling/disabling of pools. 2011-07-21 14:41:12 +10:00
Con Kolivas
6305146bea Implement proper flagging of idle pools, test them with the watchdog thread, and failover correctly. 2011-07-20 13:07:41 +10:00
Con Kolivas
d518f7cbfd Track pool number. 2011-07-20 11:27:21 +10:00