Author

Topic: Gateless Gate Sharp 1.3.8: 30Mh/s (Ethash) on RX 480! - page 162. (Read 214458 times)

sr. member
Activity: 728
Merit: 304
Miner Developer
Alright, all the Equihash kernels are working without problems with the new compiler now!
The speed is so-so, but it's a pretty good starting point.
Now I have all the goodies like inline assembly and compiler hints, he he he..
newbie
Activity: 59
Merit: 0
What kind of speeds does GG give for XMR with RX 470/480?

Pretty much the same as Claymore for me, but download it and try it out
sr. member
Activity: 728
Merit: 304
Miner Developer
I am almost done. 11 out of 12 Equihash kernels work flawlessly.
GCN support of LLVM is incredibly buggy, but I can at least fix them now!

Are you seeing any speeds ups from using LLVM vs stock compiler?

Not yet, not yet. I'm still ironing out compatibility issues with the last kernel.
newbie
Activity: 5
Merit: 0
What kind of speeds does GG give for XMR with RX 470/480?
legendary
Activity: 2182
Merit: 1401
I am almost done. 11 out of 12 Equihash kernels work flawlessly.
GCN support of LLVM is incredibly buggy, but I can at least fix them now!

Are you seeing any speeds ups from using LLVM vs stock compiler?
newbie
Activity: 59
Merit: 0
I use gateless for ZEC and Pasc only as there are a ton of eth and XMR miners.
I try gateless for ZEC, work normal, little low hash then Claymore.
But I very wont use gateless for ETH now.

FYI - I had the same problems with ETH. Lots of hardware errors regardless of what clock speed my gpu was at.

I just chalked it up to ETH not being ready for this yet. Both XMR and ZEC work great though
sr. member
Activity: 450
Merit: 255
Yea, from my testing Gateless gets very close to claymore when you compare poolside.
newbie
Activity: 5
Merit: 0
I use gateless for ZEC and Pasc only as there are a ton of eth and XMR miners.
I try gateless for ZEC, work normal, little low hash then Claymore.
But I very wont use gateless for ETH now.
sr. member
Activity: 450
Merit: 255
I use gateless for ZEC and Pasc only as there are a ton of eth and XMR miners.
newbie
Activity: 5
Merit: 0
Nope no ideas then, you don't see alot of rejects  ?
Yes, rejects for ETH I do not have anywhere.
Does anyone use Gatelessgate for mining ETH?
full member
Activity: 224
Merit: 100
CryptoLearner
Nope no ideas then, you don't see alot of rejects  ?
newbie
Activity: 5
Merit: 0
Hello, I try use for mine ETH. Several pool show very low shares and hashrate, but Gateless Gate show normal rates, why? please check it.
For example:
nanopool - 20MH / 8 shares, but miner - 77MH / 40 shares,
https://file-up.net/big_d2d324a7e53bdea28d20170222110801.html
https://file-up.net/big_e4fe952129b7ca04bb20170222110854.html


You need to let it run for a longer time to get a true average number on pools. (6-12h at least)

ok, thank you, I will try..

I waited about 6h, but same result for 2x rx480 8g + 1x rx470 8g:

gatelessgate 0.1.3-pre1 - Started: [2017-02-22 04:20:59] - [0 days 05:56:53]
--------------------------------------------------------------------------------
(5s):81.03M (avg):77.58Mh/s | A:371000000000  R:0  HW:145  WU:18.912/m
ST: 2  SS: 0  NB: 1510  LW: 39099  GF: 1  RF: 0
Connected to eth-eu1.nanopool.org (stratum) diff 5G as user 0x5...
Block: 3fe832b0...  Diff:0  Started: [10:17:33]  Best share: 791G
--------------------------------------------------------------------------------
[P]ool management [G]PU management Settings [D]isplay options [Q]uit
GPU 0:                | 26.93M/27.02Mh/s | R:  0.0% HW:44 WU:6.465/m xI:4620
GPU 1:                | 23.39M/23.38Mh/s | R:  0.0% HW:47 WU:5.815/m xI:4620
GPU 2:                | 27.23M/27.19Mh/s | R:  0.0% HW:54 WU:6.633/m xI:4620


but info from pool:

Current Calculated Hashrate
17.0 Mh/s
Average Hashrate
for last 6 hours
16.5 Mh/s
Last Reported Hashrate
0.0 Mh/s

    Shares
Date   Amount
Current hour   3
Feb 22nd 09:59:59 (12 minutes ago)   12
Feb 22nd 08:59:59 (an hour ago)   10
Feb 22nd 07:59:59 (2 hours ago)   15
Feb 22nd 06:59:59 (3 hours ago)   10
Feb 22nd 05:59:59 (4 hours ago)   12
Feb 22nd 04:59:59 (5 hours ago)   8

and from another pool too.
Have any idea?
newbie
Activity: 5
Merit: 0
Hello, I try use for mine ETH. Several pool show very low shares and hashrate, but Gateless Gate show normal rates, why? please check it.
For example:
nanopool - 20MH / 8 shares, but miner - 77MH / 40 shares,
https://file-up.net/big_d2d324a7e53bdea28d20170222110801.html
https://file-up.net/big_e4fe952129b7ca04bb20170222110854.html


You need to let it run for a longer time to get a true average number on pools. (6-12h at least)

ok, thank you, I will try..
full member
Activity: 224
Merit: 100
CryptoLearner
Hello, I try use for mine ETH. Several pool show very low shares and hashrate, but Gateless Gate show normal rates, why? please check it.
For example:
nanopool - 20MH / 8 shares, but miner - 77MH / 40 shares,




You need to let it run for a longer time to get a true average number on pools. (6-12h at least)
newbie
Activity: 5
Merit: 0
Hello, I try use for mine ETH. Several pool show very low shares and hashrate, but Gateless Gate show normal rates, why? please check it.
For example:
nanopool - 20MH / 8 shares, but miner - 77MH / 40 shares,
https://file-up.net/big_d2d324a7e53bdea28d20170222110801.html
https://file-up.net/big_e4fe952129b7ca04bb20170222110854.html
sr. member
Activity: 728
Merit: 304
Miner Developer
I am almost done. 11 out of 12 Equihash kernels work flawlessly.
GCN support of LLVM is incredibly buggy, but I can at least fix them now!
sr. member
Activity: 728
Merit: 304
Miner Developer
The second to last Equihash kernel is almost working with occasional invalid solutions. Pretty close!
sr. member
Activity: 728
Merit: 304
Miner Developer
There seems to be a problem with LLVM's loop optimizations, so I am disabling them in PassBuilder.cpp.
LLVM may be buggy, but it is fun to play with!
sr. member
Activity: 588
Merit: 251
God grief, they are not checking GCN address spaces at all!
This is unreal...

Code:
bool llvm::isAllocaPromotable(const AllocaInst *AI) {
  // FIXME: If the memory unit is of pointer or integer type, we can permit
  // assignments to subsections of the memory unit.
  unsigned AS = AI->getType()->getAddressSpace();

  // Only allow direct and non-volatile loads and stores...
  for (const User *U : AI->users()) {
    if (const LoadInst *LI = dyn_cast(U)) {
      // Note that atomic loads can be transformed; atomic semantics do
      // not have any meaning for a local alloca.
      if (LI->isVolatile())
        return false;
    } else if (const StoreInst *SI = dyn_cast(U)) {
      if (SI->getOperand(0) == AI)
        return false; // Don't allow a store OF the AI, only INTO the AI.
      // Note that atomic stores can be transformed; atomic semantics do
      // not have any meaning for a local alloca.
      if (SI->isVolatile())
        return false;
    } else if (const IntrinsicInst *II = dyn_cast(U)) {
      if (II->getIntrinsicID() != Intrinsic::lifetime_start &&
          II->getIntrinsicID() != Intrinsic::lifetime_end)
        return false;
    } else if (const BitCastInst *BCI = dyn_cast(U)) {
      if (BCI->getType() != Type::getInt8PtrTy(U->getContext(), AS))
        return false;
      if (!onlyUsedByLifetimeMarkers(BCI))
        return false;
    } else if (const GetElementPtrInst *GEPI = dyn_cast(U)) {
      if (GEPI->getType() != Type::getInt8PtrTy(U->getContext(), AS))
        return false;
      if (!GEPI->hasAllZeroIndices())
        return false;
      if (!onlyUsedByLifetimeMarkers(GEPI))
        return false;
    } else {
      return false;
    }
  }

  return true;
}

Well, the memory addressing is strange, at least for someone used to C/C++ and assembler.  I wish all GCN devices supported flat addressing, but alas we still have to deal with the memory buffer structures.
legendary
Activity: 2940
Merit: 1091
--- ChainWorks Industries ---
God grief, they are not checking GCN address spaces at all!
This is unreal...

Code:
bool llvm::isAllocaPromotable(const AllocaInst *AI) {
  // FIXME: If the memory unit is of pointer or integer type, we can permit
  // assignments to subsections of the memory unit.
  unsigned AS = AI->getType()->getAddressSpace();

  // Only allow direct and non-volatile loads and stores...
  for (const User *U : AI->users()) {
    if (const LoadInst *LI = dyn_cast(U)) {
      // Note that atomic loads can be transformed; atomic semantics do
      // not have any meaning for a local alloca.
      if (LI->isVolatile())
        return false;
    } else if (const StoreInst *SI = dyn_cast(U)) {
      if (SI->getOperand(0) == AI)
        return false; // Don't allow a store OF the AI, only INTO the AI.
      // Note that atomic stores can be transformed; atomic semantics do
      // not have any meaning for a local alloca.
      if (SI->isVolatile())
        return false;
    } else if (const IntrinsicInst *II = dyn_cast(U)) {
      if (II->getIntrinsicID() != Intrinsic::lifetime_start &&
          II->getIntrinsicID() != Intrinsic::lifetime_end)
        return false;
    } else if (const BitCastInst *BCI = dyn_cast(U)) {
      if (BCI->getType() != Type::getInt8PtrTy(U->getContext(), AS))
        return false;
      if (!onlyUsedByLifetimeMarkers(BCI))
        return false;
    } else if (const GetElementPtrInst *GEPI = dyn_cast(U)) {
      if (GEPI->getType() != Type::getInt8PtrTy(U->getContext(), AS))
        return false;
      if (!GEPI->hasAllZeroIndices())
        return false;
      if (!onlyUsedByLifetimeMarkers(GEPI))
        return false;
    } else {
      return false;
    }
  }

  return true;
}

hehehe ...

now this is the sign of a good coder ...

Wink ...

#crysx
Jump to: