Pages:
Author

Topic: DiabloMiner GPU Miner - page 83. (Read 866572 times)

legendary
Activity: 1162
Merit: 1000
DiabloMiner author
December 21, 2010, 03:40:53 AM
Update: Added dedicated getwork thread, now only gets new work once per 5 seconds instead of 3 times per gpu per 5 seconds.

This should improve performance on miner pools due to remote connection latency, and it should also improve performance on setups that have many miners connecting to a single LAN bitcoind.

Another update: Added -g/--getwork to change the number of seconds between getwork refresh, should help high pool latency issues, default remains 5.

Another another update: the sh scripts now set an environment variable that fixes SDK 2.2 and 2.3 CPU time usage. I still recommend 2.1, but at least it doesn't go apeshit anymore.
newbie
Activity: 24
Merit: 0
December 16, 2010, 12:30:38 PM
True, my bad, a typo.

By the way, clocking core from 700MHz to 850MHz looks stable and you can get quite a bump in performance, 140 mhash/sec right now
legendary
Activity: 1162
Merit: 1000
DiabloMiner author
December 16, 2010, 02:34:07 AM
$ ./DiabloMiner-Linux.sh -u lolzuser -p mehpw -w 64
[12/15/10 6:39:36 PM] Started
[12/15/10 6:39:42 PM] Added Juniper (#1) (9 CU, local work size of 64)
111224 khash/sec


Listed as Juniper, it's a Radeon HD 4750.

Thats a 5750, actually. 5750s do about 116 mhash/sec and are Junipers.
newbie
Activity: 24
Merit: 0
December 15, 2010, 12:44:01 PM
$ ./DiabloMiner-Linux.sh -u lolzuser -p mehpw -w 64
[12/15/10 6:39:36 PM] Started
[12/15/10 6:39:42 PM] Added Juniper (#1) (9 CU, local work size of 64)
111224 khash/sec


Listed as Juniper, it's a Radeon HD 4750.
legendary
Activity: 1162
Merit: 1000
DiabloMiner author
December 15, 2010, 12:02:02 AM
That usually indicates a fault in the OS somewhere. Since no one gives a shit about OpenCL on OSX (not even Apple), I'm not sure what to tell you. Any other OSX users want to chime in?
newbie
Activity: 3
Merit: 0
December 14, 2010, 03:01:18 PM
Hi Diablo, just catching up from IRC on my osx experience.
Code:
511 pyramid:~/Projects/DiabloMiner$ ./DiabloMiner-OSX.sh -u jcw9 -p notarealpasswordfolks -w 64
[12/14/10 2:56:50 PM] Started
[12/14/10 2:56:59 PM] Added ATI Radeon HD 5750 (#1) (10 CU, local work size of 64)
49951 khash/sec

This works great… but it seems to generally freeze the machine after a few minutes. Cursor is mobile and I was able to ssh in last time. The java process was no longer running when I sshed in. I'd like to help figure out ways to improve the stability. Any ideas?
legendary
Activity: 1162
Merit: 1000
DiabloMiner author
December 13, 2010, 12:05:17 PM
H == 0 is checked for every nonce... m0's does H == 0 and G <= target in the kernel for every nonce, and pays a slight speed penalty for it. So, if I check H <= target, I will pay a similar speed penalty.

Well, in fact, there are two different problems:
1. Allow small targets - under 32 bits (H > 0)
2. Perform full checking before send work back to bitcoin to save server resources.

ad 1)
I think it could be easy for every nonce to not compare H == 0, but H <= constant, where constant is pre-counted for every work from bitcoin. It should be easy and safe enough to pick last 32 bits from target and convert to this constant.

ad 2)
Full checking is not performed for every nonce, but only when H <= constant is found. So it does not slow down computing (as it is performed only for hashes which already passed first check), but save resources for server

Quote
Edit: Also, you have to check the full hash on your side anyhow when you submit it to your bitcoind via getwork. It will reject it if its wrong (returns false).

Yes, I'm checking result of bitcoin's getwork() to obtain if block was found. My own checking is against low target to counting worker's shares.


Except you misunderstood what I said about 2. I _already_ fully check the hash, from scratch, using the full 80 bytes of header just to make sure its correct. However, _you must also check this_ as you cannot accept user input as valid. It would take me three seconds to screw over the entire pool once it gets going.

Also, re: 1. See how m0's kernel does it? He has a kernel arg named target, and the kernel does G <= target. This is exactly the same thing as doing H <= target, I would code it exactly this way. GPU hardware can check if something == 0 much faster than <=.

The only reason I would add this code is if, eventually, testnet difficulty dramatically drops again and this would need to be ready before hand.
legendary
Activity: 1386
Merit: 1097
December 13, 2010, 07:03:22 AM
H == 0 is checked for every nonce... m0's does H == 0 and G <= target in the kernel for every nonce, and pays a slight speed penalty for it. So, if I check H <= target, I will pay a similar speed penalty.

Well, in fact, there are two different problems:
1. Allow small targets - under 32 bits (H > 0)
2. Perform full checking before send work back to bitcoin to save server resources.

ad 1)
I think it could be easy for every nonce to not compare H == 0, but H <= constant, where constant is pre-counted for every work from bitcoin. It should be easy and safe enough to pick last 32 bits from target and convert to this constant.

ad 2)
Full checking is not performed for every nonce, but only when H <= constant is found. So it does not slow down computing (as it is performed only for hashes which already passed first check), but save resources for server

Quote
Edit: Also, you have to check the full hash on your side anyhow when you submit it to your bitcoind via getwork. It will reject it if its wrong (returns false).

Yes, I'm checking result of bitcoin's getwork() to obtain if block was found. My own checking is against low target to counting worker's shares.
legendary
Activity: 1162
Merit: 1000
DiabloMiner author
December 13, 2010, 02:23:32 AM
[13.12.10 07:10:53] Started
[13.12.10 07:10:53] ERROR: No OpenCL platforms found.

Some more bruteforcing and I seem to be a little closer. Trying on Win7 x64, with ATI 5870. I just installed the ATI stream SDK v2.2 and I see to be one step closer now. Any idea why it fails to identify the OpenCL drivers?

Try installing the version of Catalyst that includes the the stream runtime already (downloading offers two choices, 10.12 is supposed to eliminate this and always include the runtime).
newbie
Activity: 2
Merit: 0
December 13, 2010, 01:05:17 AM
[13.12.10 07:10:53] Started
[13.12.10 07:10:53] ERROR: No OpenCL platforms found.

Some more bruteforcing and I seem to be a little closer. Trying on Win7 x64, with ATI 5870. I just installed the ATI stream SDK v2.2 and I see to be one step closer now. Any idea why it fails to identify the OpenCL drivers?
legendary
Activity: 1162
Merit: 1000
DiabloMiner author
December 13, 2010, 12:39:23 AM
H == 0 is checked for every nonce... m0's does H == 0 and G <= target in the kernel for every nonce, and pays a slight speed penalty for it. So, if I check H <= target, I will pay a similar speed penalty.

Edit: Also, you have to check the full hash on your side anyhow when you submit it to your bitcoind via getwork. It will reject it if its wrong (returns false).
legendary
Activity: 1386
Merit: 1097
December 12, 2010, 11:15:15 PM
testnet, for the time being, has been > 32 bits. Checking if H <= target (instead of H == 0 and then G <= in the host code) would slow it down.  I could add it, but it'd cause complexity that might slow it down for normal users if I do it wrong.

Well, but this check is performed only when possible valid block is found, right? So we are talking about 'slowing down' once per tens of seconds or even minutes for every worker (depends on target and machine speed).

I'm asking that because strict checking on workers are much 'cheaper' than lazy checking on workers and full check on central server. For saving server resources we need to distribute full target checking as much as possible...
newbie
Activity: 2
Merit: 0
December 12, 2010, 10:01:46 PM
Could someone please take the time to write down the steps needed to get this to run on Win7 x64?
legendary
Activity: 1162
Merit: 1000
DiabloMiner author
December 12, 2010, 09:33:42 PM
Feature request: Please support targets with less than 32bits of zeros
Reason: Miner is not properly working on testnet, where target can be under that. I'm also working on cooperative mining server and would like to introduce small targets for counting shares of every worker. DiabloMiner with correct target handling will be compatible with this mining server...

Thanks!

testnet, for the time being, has been > 32 bits. Checking if H <= target (instead of H == 0 and then G <= in the host code) would slow it down.  I could add it, but it'd cause complexity that might slow it down for normal users if I do it wrong.

How's this vs. all the other mining tools?

Its faster than m0's, which is your only other option.
newbie
Activity: 37
Merit: 0
December 12, 2010, 05:35:54 PM
How's this vs. all the other mining tools?
legendary
Activity: 1386
Merit: 1097
December 12, 2010, 01:42:32 PM
Feature request: Please support targets with less than 32bits of zeros
Reason: Miner is not properly working on testnet, where target can be under that. I'm also working on cooperative mining server and would like to introduce small targets for counting shares of every worker. DiabloMiner with correct target handling will be compatible with this mining server...

Thanks!
legendary
Activity: 1162
Merit: 1000
DiabloMiner author
December 12, 2010, 09:00:56 AM
Update: Made logging output more consistent
legendary
Activity: 1162
Merit: 1000
DiabloMiner author
December 11, 2010, 08:39:46 PM
Update: Removed -a, it autodetects it now
legendary
Activity: 1078
Merit: 1005
December 11, 2010, 02:15:52 AM
Hello.  I looked through this thread and can't find the download link for this client.

Repost please? Smiley

Thank you.

It's in the very first post of the thread, at the top, where it says "Newest binary".
sr. member
Activity: 1344
Merit: 264
bit.ly/3QXp3oh | Ultimate Launchpad on TON
December 11, 2010, 01:54:23 AM
Hello.  I looked through this thread and can't find the download link for this client.

Repost please? Smiley

Thank you.
Pages:
Jump to: