Use flip helpers to simplify code for calculation of midstate.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
diff --git a/cgminer.c b/cgminer.c
index b7772a1..cf43719 100644
--- a/cgminer.c
+++ b/cgminer.c
@@ -1473,22 +1473,16 @@ static bool jobj_binary(const json_t *obj, const char *key,
static void calc_midstate(struct work *work)
{
- union {
- unsigned char c[64];
- uint32_t i[16];
- } data;
- int swapcounter;
-
- for (swapcounter = 0; swapcounter < 16; swapcounter++)
- data.i[swapcounter] = swab32(((uint32_t*) (work->data))[swapcounter]);
+ unsigned char data[64];
+ uint32_t *data32 = (uint32_t *)data;
sha2_context ctx;
+
+ flip64(data32, work->data);
sha2_starts(&ctx);
- sha2_update(&ctx, data.c, 64);
- memcpy(work->midstate, ctx.state, sizeof(work->midstate));
+ sha2_update(&ctx, data, 64);
+ memcpy(work->midstate, ctx.state, 32);
#if defined(__BIG_ENDIAN__) || defined(MIPSEB)
- int i;
- for (i = 0; i < 8; i++)
- (((uint32_t*) (work->midstate))[i]) = swab32(((uint32_t*) (work->midstate))[i]);
+ flip32(work->midstate, work->midstate);
#endif
}
diff --git a/miner.h b/miner.h
index c76e725..2d2e709 100644
--- a/miner.h
+++ b/miner.h
@@ -640,6 +640,16 @@ static inline void flip32(void *dest_p, const void *src_p)
dest[i] = swab32(src[i]);
}
+static inline void flip64(void *dest_p, const void *src_p)
+{
+ uint32_t *dest = dest_p;
+ const uint32_t *src = src_p;
+ int i;
+
+ for (i = 0; i < 16; i++)
+ dest[i] = swab32(src[i]);
+}
+
static inline void flip80(void *dest_p, const void *src_p)
{
uint32_t *dest = dest_p;