forked from cbuchner1/ccminer
-
Notifications
You must be signed in to change notification settings - Fork 741
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
x16: optimised echo512-64 kernel for maxwell+
which keep the SM 3.0 compat with x11 kernel
- Loading branch information
Showing
7 changed files
with
279 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,248 @@ | ||
/** | ||
* Echo512-64 kernel for maxwell, based on alexis work | ||
*/ | ||
|
||
#include <cuda_helper.h> | ||
#include <cuda_vector_uint2x4.h> | ||
#include <cuda_vectors.h> | ||
|
||
#define INTENSIVE_GMF | ||
#include "tribus/cuda_echo512_aes.cuh" | ||
|
||
#ifdef __INTELLISENSE__ | ||
#define __byte_perm(x, y, b) x | ||
#define atomicExch(p,y) (*p) = y | ||
#endif | ||
|
||
__device__ | ||
static void echo_round_alexis(const uint32_t sharedMemory[4][256], uint32_t *W, uint32_t &k0) | ||
{ | ||
// Big Sub Words | ||
#pragma unroll 16 | ||
for (int idx = 0; idx < 16; idx++) | ||
AES_2ROUND(sharedMemory,W[(idx<<2) + 0], W[(idx<<2) + 1], W[(idx<<2) + 2], W[(idx<<2) + 3], k0); | ||
|
||
// Shift Rows | ||
#pragma unroll 4 | ||
for (int i = 0; i < 4; i++){ | ||
uint32_t t[4]; | ||
/// 1, 5, 9, 13 | ||
t[0] = W[i+ 4]; | ||
t[1] = W[i+ 8]; | ||
t[2] = W[i+24]; | ||
t[3] = W[i+60]; | ||
W[i + 4] = W[i + 20]; | ||
W[i + 8] = W[i + 40]; | ||
W[i +24] = W[i + 56]; | ||
W[i +60] = W[i + 44]; | ||
|
||
W[i +20] = W[i +36]; | ||
W[i +40] = t[1]; | ||
W[i +56] = t[2]; | ||
W[i +44] = W[i +28]; | ||
|
||
W[i +28] = W[i +12]; | ||
W[i +12] = t[3]; | ||
W[i +36] = W[i +52]; | ||
W[i +52] = t[0]; | ||
} | ||
// Mix Columns | ||
#pragma unroll 4 | ||
for (int i = 0; i < 4; i++){ // Schleife über je 2*uint32_t | ||
#pragma unroll 4 | ||
for (int idx = 0; idx < 64; idx += 16){ // Schleife über die elemnte | ||
uint32_t a[4]; | ||
a[0] = W[idx + i]; | ||
a[1] = W[idx + i + 4]; | ||
a[2] = W[idx + i + 8]; | ||
a[3] = W[idx + i +12]; | ||
|
||
uint32_t ab = a[0] ^ a[1]; | ||
uint32_t bc = a[1] ^ a[2]; | ||
uint32_t cd = a[2] ^ a[3]; | ||
|
||
uint32_t t, t2, t3; | ||
t = (ab & 0x80808080); | ||
t2 = (bc & 0x80808080); | ||
t3 = (cd & 0x80808080); | ||
|
||
uint32_t abx = (t >> 7) * 27U ^ ((ab^t) << 1); | ||
uint32_t bcx = (t2 >> 7) * 27U ^ ((bc^t2) << 1); | ||
uint32_t cdx = (t3 >> 7) * 27U ^ ((cd^t3) << 1); | ||
|
||
W[idx + i] = bc ^ a[3] ^ abx; | ||
W[idx + i + 4] = a[0] ^ cd ^ bcx; | ||
W[idx + i + 8] = ab ^ a[3] ^ cdx; | ||
W[idx + i +12] = ab ^ a[2] ^ (abx ^ bcx ^ cdx); | ||
} | ||
} | ||
} | ||
|
||
__global__ __launch_bounds__(128, 5) /* will force 80 registers */ | ||
static void x16_echo512_gpu_hash_64(uint32_t threads, uint32_t *g_hash) | ||
{ | ||
__shared__ uint32_t sharedMemory[4][256]; | ||
|
||
aes_gpu_init128(sharedMemory); | ||
|
||
const uint32_t thread = (blockDim.x * blockIdx.x + threadIdx.x); | ||
uint32_t k0; | ||
uint32_t h[16]; | ||
uint32_t hash[16]; | ||
if (thread < threads) | ||
{ | ||
uint32_t *Hash = &g_hash[thread<<4]; | ||
|
||
*(uint2x4*)&h[ 0] = __ldg4((uint2x4*)&Hash[ 0]); | ||
*(uint2x4*)&h[ 8] = __ldg4((uint2x4*)&Hash[ 8]); | ||
|
||
*(uint2x4*)&hash[ 0] = *(uint2x4*)&h[ 0]; | ||
*(uint2x4*)&hash[ 8] = *(uint2x4*)&h[ 8]; | ||
|
||
__syncthreads(); | ||
|
||
const uint32_t P[48] = { | ||
0xe7e9f5f5, 0xf5e7e9f5, 0xb3b36b23, 0xb3dbe7af, 0xa4213d7e, 0xf5e7e9f5, 0xb3b36b23, 0xb3dbe7af, | ||
//8-12 | ||
0x01425eb8, 0xf5e7e9f5, 0xb3b36b23, 0xb3dbe7af, 0x65978b09, 0xf5e7e9f5, 0xb3b36b23, 0xb3dbe7af, | ||
//21-25 | ||
0x2cb6b661, 0x6b23b3b3, 0xcf93a7cf, 0x9d9d3751, 0x9ac2dea3, 0xf5e7e9f5, 0xb3b36b23, 0xb3dbe7af, | ||
//34-38 | ||
0x579f9f33, 0xfbfbfbfb, 0xfbfbfbfb, 0xefefd3c7, 0xdbfde1dd, 0xf5e7e9f5, 0xb3b36b23, 0xb3dbe7af, | ||
0x34514d9e, 0xf5e7e9f5, 0xb3b36b23, 0xb3dbe7af, 0xb134347e, 0xea6f7e7e, 0xbd7731bd, 0x8a8a1968, | ||
0x14b8a457, 0xf5e7e9f5, 0xb3b36b23, 0xb3dbe7af, 0x265f4382, 0xf5e7e9f5, 0xb3b36b23, 0xb3dbe7af | ||
//58-61 | ||
}; | ||
|
||
k0 = 520; | ||
|
||
#pragma unroll 4 | ||
for (uint32_t idx = 0; idx < 16; idx += 4) { | ||
AES_2ROUND(sharedMemory, h[idx + 0], h[idx + 1], h[idx + 2], h[idx + 3], k0); | ||
} | ||
k0 += 4; | ||
|
||
uint32_t W[64]; | ||
|
||
#pragma unroll 4 | ||
for (uint32_t i = 0; i < 4; i++) | ||
{ | ||
uint32_t a = P[i]; | ||
uint32_t b = P[i + 4]; | ||
uint32_t c = h[i + 8]; | ||
uint32_t d = P[i + 8]; | ||
|
||
uint32_t ab = a ^ b; | ||
uint32_t bc = b ^ c; | ||
uint32_t cd = c ^ d; | ||
|
||
|
||
uint32_t t = (ab & 0x80808080); | ||
uint32_t t2 = (bc & 0x80808080); | ||
uint32_t t3 = (cd & 0x80808080); | ||
|
||
uint32_t abx = (t >> 7) * 27U ^ ((ab^t) << 1); | ||
uint32_t bcx = (t2 >> 7) * 27U ^ ((bc^t2) << 1); | ||
uint32_t cdx = (t3 >> 7) * 27U ^ ((cd^t3) << 1); | ||
|
||
W[i] = abx ^ bc ^ d; | ||
W[i + 4] = bcx ^ a ^ cd; | ||
W[i + 8] = cdx ^ ab ^ d; | ||
W[i +12] = abx ^ bcx ^ cdx ^ ab ^ c; | ||
|
||
a = P[i +12]; | ||
b = h[i + 4]; | ||
c = P[i +16]; | ||
d = P[i +20]; | ||
|
||
ab = a ^ b; | ||
bc = b ^ c; | ||
cd = c ^ d; | ||
|
||
|
||
t = (ab & 0x80808080); | ||
t2 = (bc & 0x80808080); | ||
t3 = (cd & 0x80808080); | ||
|
||
abx = (t >> 7) * 27U ^ ((ab^t) << 1); | ||
bcx = (t2 >> 7) * 27U ^ ((bc^t2) << 1); | ||
cdx = (t3 >> 7) * 27U ^ ((cd^t3) << 1); | ||
|
||
W[16 + i] = bc ^ d ^ abx; | ||
W[16 + i + 4] = a ^ cd ^ bcx; | ||
W[16 + i + 8] = d ^ ab ^ cdx; | ||
W[16 + i + 12] = c ^ ab ^ abx ^ bcx ^ cdx; | ||
|
||
a = h[i]; | ||
b = P[24 + i + 0]; | ||
c = P[24 + i + 4]; | ||
d = P[24 + i + 8]; | ||
|
||
ab = a ^ b; | ||
bc = b ^ c; | ||
cd = c ^ d; | ||
|
||
|
||
t = (ab & 0x80808080); | ||
t2 = (bc & 0x80808080); | ||
t3 = (cd & 0x80808080); | ||
|
||
abx = (t >> 7) * 27U ^ ((ab^t) << 1); | ||
bcx = (t2 >> 7) * 27U ^ ((bc^t2) << 1); | ||
cdx = (t3 >> 7) * 27U ^ ((cd^t3) << 1); | ||
|
||
W[32 + i] = bc ^ d ^ abx; | ||
W[32 + i + 4] = a ^ cd ^ bcx; | ||
W[32 + i + 8] = d ^ ab ^ cdx; | ||
W[32 + i + 12] = c ^ ab ^ abx ^ bcx ^ cdx; | ||
|
||
a = P[36 + i ]; | ||
b = P[36 + i + 4]; | ||
c = P[36 + i + 8]; | ||
d = h[i + 12]; | ||
|
||
ab = a ^ b; | ||
bc = b ^ c; | ||
cd = c ^ d; | ||
|
||
t = (ab & 0x80808080); | ||
t2 = (bc & 0x80808080); | ||
t3 = (cd & 0x80808080); | ||
|
||
abx = (t >> 7) * 27U ^ ((ab^t) << 1); | ||
bcx = (t2 >> 7) * 27U ^ ((bc^t2) << 1); | ||
cdx = (t3 >> 7) * 27U ^ ((cd^t3) << 1); | ||
|
||
W[48 + i] = bc ^ d ^ abx; | ||
W[48 + i + 4] = a ^ cd ^ bcx; | ||
W[48 + i + 8] = d ^ ab ^ cdx; | ||
W[48 + i + 12] = c ^ ab ^ abx ^ bcx ^ cdx; | ||
|
||
} | ||
|
||
for (int k = 1; k < 10; k++) | ||
echo_round_alexis(sharedMemory,W,k0); | ||
|
||
#pragma unroll 4 | ||
for (int i = 0; i < 16; i += 4) | ||
{ | ||
W[i] ^= W[32 + i] ^ 512; | ||
W[i + 1] ^= W[32 + i + 1]; | ||
W[i + 2] ^= W[32 + i + 2]; | ||
W[i + 3] ^= W[32 + i + 3]; | ||
} | ||
*(uint2x4*)&Hash[ 0] = *(uint2x4*)&hash[ 0] ^ *(uint2x4*)&W[ 0]; | ||
*(uint2x4*)&Hash[ 8] = *(uint2x4*)&hash[ 8] ^ *(uint2x4*)&W[ 8]; | ||
} | ||
} | ||
|
||
__host__ | ||
void x16_echo512_cpu_hash_64(int thr_id, uint32_t threads, uint32_t *d_hash){ | ||
|
||
const uint32_t threadsperblock = 128; | ||
|
||
dim3 grid((threads + threadsperblock-1)/threadsperblock); | ||
dim3 block(threadsperblock); | ||
|
||
x16_echo512_gpu_hash_64<<<grid, block>>>(threads, d_hash); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters