Browse Source

test

release/v0.1
jl777 9 years ago
parent
commit
92b4374560
  1. 4
      basilisk/basilisk.c
  2. 12
      datachain/datachain_KOMODO.c
  3. 6
      gecko/gecko_miner.c

4
basilisk/basilisk.c

@ -23,7 +23,9 @@ uint32_t basilisk_calcnonce(struct supernet_info *myinfo,uint8_t *data,int32_t d
{ {
int32_t i,numiters = 0; bits256 hash,hash2,threshold; uint32_t basilisktag; int32_t i,numiters = 0; bits256 hash,hash2,threshold; uint32_t basilisktag;
vcalc_sha256(0,hash.bytes,data,datalen); vcalc_sha256(0,hash.bytes,data,datalen);
threshold = bits256_from_compact(nBits); if ( nBits >= GECKO_EASIESTDIFF )
threshold = bits256_from_compact(GECKO_EASIESTDIFF);
else threshold = bits256_from_compact(nBits);
for (i=0; i<numiters; i++) for (i=0; i<numiters; i++)
{ {
//OS_randombytes((void *)hash.uints,sizeof(basilisktag)); //OS_randombytes((void *)hash.uints,sizeof(basilisktag));

12
datachain/datachain_KOMODO.c

@ -80,7 +80,9 @@ int32_t datachain_genesis_verify(struct gecko_genesis_opreturn *opret)
{ {
int32_t txlen,datalen; bits256 txid,threshold,hash2; uint8_t serialized[1024],txidbytes[1024]; struct iguana_msgblock msg; char str[65],str2[65]; int32_t txlen,datalen; bits256 txid,threshold,hash2; uint8_t serialized[1024],txidbytes[1024]; struct iguana_msgblock msg; char str[65],str2[65];
txid = datachain_opreturn_convert(txidbytes,&txlen,&msg,opret); txid = datachain_opreturn_convert(txidbytes,&txlen,&msg,opret);
threshold = bits256_from_compact(opret->nBits); if ( opret->nBits >= GECKO_EASIESTDIFF )
threshold = bits256_from_compact(GECKO_EASIESTDIFF);
else threshold = bits256_from_compact(opret->nBits);
datalen = iguana_rwblockhdr(1,0,serialized,&msg); datalen = iguana_rwblockhdr(1,0,serialized,&msg);
hash2 = iguana_calcblockhash("virtual",blockhash_sha256,serialized,datalen); hash2 = iguana_calcblockhash("virtual",blockhash_sha256,serialized,datalen);
//for (i=0; i<datalen; i++) //for (i=0; i<datalen; i++)
@ -116,7 +118,9 @@ int32_t datachain_opreturn_create(uint8_t *serialized,char *symbol,char *name,ch
OS_randombytes((void *)&opret.netmagic,sizeof(opret.netmagic)); OS_randombytes((void *)&opret.netmagic,sizeof(opret.netmagic));
bitcoin_addr2rmd160(&opret.pubval,opret.rmd160,coinaddr); bitcoin_addr2rmd160(&opret.pubval,opret.rmd160,coinaddr);
txid = datachain_opreturn_convert(txidbytes,&txlen,&msg,&opret); txid = datachain_opreturn_convert(txidbytes,&txlen,&msg,&opret);
threshold = bits256_from_compact(nBits); if ( nBits >= GECKO_EASIESTDIFF )
threshold = bits256_from_compact(GECKO_EASIESTDIFF);
else threshold = bits256_from_compact(nBits);
for (i=0; i<100000000; i++) for (i=0; i<100000000; i++)
{ {
opret.nonce = msg.H.nonce = i; opret.nonce = msg.H.nonce = i;
@ -148,7 +152,9 @@ void datachain_events_processKOMODO(struct supernet_info *myinfo,struct datachai
memset(symbol,0,sizeof(symbol)), memcpy(symbol,opret.symbol,sizeof(opret.symbol)); memset(symbol,0,sizeof(symbol)), memcpy(symbol,opret.symbol,sizeof(opret.symbol));
memset(name,0,sizeof(name)), memcpy(name,opret.name,sizeof(opret.name)); memset(name,0,sizeof(name)), memcpy(name,opret.name,sizeof(opret.name));
hash2 = datachain_opreturn_convert(txidbytes,&txlen,&msg,&opret); hash2 = datachain_opreturn_convert(txidbytes,&txlen,&msg,&opret);
threshold = bits256_from_compact(opret.nBits); if ( opret.nBits >= GECKO_EASIESTDIFF )
threshold = bits256_from_compact(GECKO_EASIESTDIFF);
else threshold = bits256_from_compact(opret.nBits);
msg.txn_count = 1; msg.txn_count = 1;
//n = iguana_serialize_block(virt->chain,&hash2,serialized,newblock); //n = iguana_serialize_block(virt->chain,&hash2,serialized,newblock);
datalen = iguana_rwblockhdr(1,0,serialized,&msg); datalen = iguana_rwblockhdr(1,0,serialized,&msg);

6
gecko/gecko_miner.c

@ -43,6 +43,8 @@ int32_t gecko_blocknonce_verify(struct iguana_info *virt,uint8_t *serialized,int
return(-1); return(-1);
} }
} }
if ( nBits >= GECKO_EASIESTDIFF )
nBits = GECKO_EASIESTDIFF;
threshold = bits256_from_compact(nBits); threshold = bits256_from_compact(nBits);
hash2 = iguana_calcblockhash(virt->symbol,virt->chain->hashalgo,serialized,datalen); hash2 = iguana_calcblockhash(virt->symbol,virt->chain->hashalgo,serialized,datalen);
if ( bits256_cmp(threshold,hash2) > 0 ) if ( bits256_cmp(threshold,hash2) > 0 )
@ -203,7 +205,9 @@ char *gecko_blockconstruct(struct supernet_info *myinfo,struct iguana_info *virt
{ {
printf("%s %s\n",bits256_str(str,txids[0]),bits256_str(str2,txids[1])); printf("%s %s\n",bits256_str(str,txids[0]),bits256_str(str2,txids[1]));
} }
threshold = bits256_from_compact(newblock->RO.bits); if ( newblock->RO.bits >= GECKO_EASIESTDIFF )
bits256_from_compact(GECKO_EASIESTDIFF);
else threshold = bits256_from_compact(newblock->RO.bits);
if ( (newblock->RO.nonce= *noncep) == 0 ) if ( (newblock->RO.nonce= *noncep) == 0 )
{ {
for (i=0; i<GECKO_MAXMINERITERS; i++) for (i=0; i<GECKO_MAXMINERITERS; i++)

Loading…
Cancel
Save