-
Notifications
You must be signed in to change notification settings - Fork 28
/
Copy pathClayXMRautorun.bat
856 lines (856 loc) · 49.5 KB
/
ClayXMRautorun.bat
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
REM Developer acrefawn. Contact me: t.me/acrefawn
REM I recommend that you do not touch the options below unless you know what you are doing.
@ECHO off
pushd "%~dp0"
SETLOCAL EnableExtensions EnableDelayedExpansion
MODE CON cols=70 lines=40
shutdown.exe /A 2>NUL 1>&2
SET ver=2.2.0
SET mn=Clay
SET firstrun=0
FOR /F "tokens=1 delims=." %%A IN ('wmic.exe OS GET localdatetime^|Find "."') DO SET dt0=%%A
TITLE %mn%_autorun(%dt0%)
:hardstart
COLOR 1F
CALL :copyright
ECHO +===================================================================+
REM Attention. Change the options below only if you really need to.
REM Name miner .log file. [in English, without any special symbols and spaces. Please do not use long names]
SET log=miner.log
REM Name config .ini file. [in English, without any special symbols and spaces. Please do not use long names]
SET config=Config_x%mn%.ini
REM Check to see if autorun.bat has already been started. [0 - false, 1 - true]
SET cmddoubleruncheck=1
REM Allow computer to be restarted. [0 - false, 1 - true]
SET pcreboot=1
REM Default config.
SET gpus=0
SET gpurestart=1
SET hashrate=0
SET minerprocess=NsGpuCNMiner.exe
SET minerpath=%minerprocess%
SET commandserver1=%minerpath% -xpool stratum+ssl://xmr-eu1.nanopool.org:14433 -xwal 4JUdGzvrMFDWrUUwY3toJATSeNwjn54LkCnKBPRzDuhzi5vSepHfUckJNxRL2gjkNrSqtCoRUrEDAgRwsQvVCjZbS5VF8ypv8VF3GUiS1J.%ver:.=% -xpsw x -allpools 1 -tstop 80 -logfile %log% -wd 0
SET commandserver2=%minerpath% -xpool stratum+ssl://xmr-eu1.nanopool.org:14433 -xwal 4JUdGzvrMFDWrUUwY3toJATSeNwjn54LkCnKBPRzDuhzi5vSepHfUckJNxRL2gjkNrSqtCoRUrEDAgRwsQvVCjZbS5VF8ypv8VF3GUiS1J.%ver:.=% -xpsw x -allpools 1 -tstop 80 -logfile %log% -wd 0
SET commandserver3=%minerpath% -xpool stratum+ssl://xmr-eu1.nanopool.org:14433 -xwal 4JUdGzvrMFDWrUUwY3toJATSeNwjn54LkCnKBPRzDuhzi5vSepHfUckJNxRL2gjkNrSqtCoRUrEDAgRwsQvVCjZbS5VF8ypv8VF3GUiS1J.%ver:.=% -xpsw x -allpools 1 -tstop 80 -logfile %log% -wd 0
SET commandserver4=%minerpath% -xpool stratum+ssl://xmr-eu1.nanopool.org:14433 -xwal 4JUdGzvrMFDWrUUwY3toJATSeNwjn54LkCnKBPRzDuhzi5vSepHfUckJNxRL2gjkNrSqtCoRUrEDAgRwsQvVCjZbS5VF8ypv8VF3GUiS1J.%ver:.=% -xpsw x -allpools 1 -tstop 80 -logfile %log% -wd 0
SET commandserver5=%minerpath% -xpool stratum+ssl://xmr-eu1.nanopool.org:14433 -xwal 4JUdGzvrMFDWrUUwY3toJATSeNwjn54LkCnKBPRzDuhzi5vSepHfUckJNxRL2gjkNrSqtCoRUrEDAgRwsQvVCjZbS5VF8ypv8VF3GUiS1J.%ver:.=% -xpsw x -allpools 1 -tstop 80 -logfile %log% -wd 0
SET ocprogram=0
SET profile=0
SET additionalprofile=0
SET octimeout=120
SET restartocprogram=0
SET lauchocprogram=0
SET restartminer=48
SET restartpc=0
SET noonrestart=0
SET midnightrestart=0
SET afterstarttimeout=0
SET internetcheck=1
SET tempcheck=0
SET globaltempcheck=1
SET environments=1
SET sharetimeout=1
SET runtimeerrors=5
SET hashrateerrors=5
SET bat=%mn%x_miner.bat
SET pingserver=google.com
SET cputimeout=5
SET logfilesize=70000000
SET rigname=%COMPUTERNAME%
SET groupname=x%mn%
SET link=https://api.telegram.org
SET chatid=0
SET reports=0
SET ap=0
SET approcessname=TeamViewer.exe
SET approcesspath=C:\Program Files (x86)\TeamViewer\TeamViewer.exe
REM I recommend that you do not touch the options below unless you know what you are doing.
SET ptos=0
SET hrdiff=00
SET mediff=00
SET ssdiff=00
SET allowsend=0
SET queue=1
SET lastsharediff=0
SET serversamount=0
SET errorscounter=0
SET switchtodefault=0
SET tprt=WYHfeJU
SET rtpt=d2a
SET prt=AAFWKz6wv7
SET rtp=%rtpt%eV6i
SET tpr=C8go_jp8%tprt%
SET /A num=(3780712+3780711)*6*9
SET errorscancel=/C:".*Connected.*"
SET criticalerrorslist=/C:".*No AMD OPENCL or NVIDIA CUDA GPUs found.*" /C:".*Restarting failed.*" /C:".*got incorrect temperature.*"
SET errorslist=/C:".*GPU.*hangs.*" /C:".*restart miner.*"
SET interneterrorslist=/C:".*Connection.*lost.*" /C:".*not resolve.*" /C:".*Failed to.*" /C:".*disconnect.*" /C:".*No pool.*"
IF %cmddoubleruncheck% EQU 1 (
tasklist.exe /V /NH /FI "imagename eq cmd.exe"| findstr.exe /V /R /C:".*%mn%_autorun(%dt0%)"| findstr.exe /R /C:".*%mn%_autorun.*" 2>NUL 1>&2 && (
ECHO This script is already running...
ECHO Current window will close in 15 seconds.
timeout.exe /T 15 /nobreak >NUL
EXIT
)
)
:checkconfig
timeout.exe /T 3 /nobreak >NUL
IF NOT EXIST "%config%" (
SET serversamount=5
GOTO createconfig
)
FOR /F "eol=# delims=" %%a IN (%config%) DO SET "%%a"
FOR %%A IN (gpus gpurestart hashrate commandserver1 ocprogram profile additionalprofile octimeout restartocprogram lauchocprogram restartminer restartpc noonrestart noonrestart midnightrestart afterstarttimeout internetcheck tempcheck globaltempcheck environments sharetimeout runtimeerrors hashrateerrors minerprocess minerpath bat pingserver cputimeout rigname groupname link chatid reports ap approcessname approcesspath) DO IF NOT DEFINED %%A GOTO corruptedconfig
FOR /F "eol=# delims=" %%A IN ('findstr.exe /R /C:"commandserver.*" %config%') DO SET /A serversamount+=1
FOR /L %%A IN (1,1,%serversamount%) DO (
FOR %%B IN (commandserver%%A) DO IF NOT DEFINED %%B GOTO corruptedconfig
)
findstr.exe /C:"%ver%" %config% >NUL || (
timeout.exe /T 3 /nobreak >NUL
CALL :inform "1" "false" "0" "Your %config% is out of date." "2"
GOTO createconfig
)
IF EXIST "%~n0.log" FOR %%A IN (%~n0.log) DO IF %%~ZA GEQ 1000000 DEL /F /Q "%~n0.log" 2>NUL 1>&2
FOR %%A IN (%~n0.bat) DO IF %%~ZA LSS 45000 EXIT
FOR %%B IN (%config%) DO IF %%~ZB LSS 5200 GOTO corruptedconfig
timeout.exe /T 3 /nobreak >NUL
CALL :inform "1" "false" "0" "%config% loaded." "2"
IF %queue% GTR %serversamount% SET queue=1
GOTO start
:corruptedconfig
CALL :inform "1" "false" "%config% file error. The file is corrupted. Please check it..." "1" "1"
:createconfig
IF DEFINED allowrestart SET gpurestart=%allowrestart%
IF DEFINED overclockprogram SET ocprogram=%overclockprogram%
IF DEFINED msiaprofile SET profile=%msiaprofile%
IF DEFINED msiatimeout SET octimeout=%msiatimeout%
IF DEFINED restartoverclockprogram SET restartocprogram=%restartoverclockprogram%
IF DEFINED minertimeoutrestart SET restartminer=%minertimeoutrestart%
IF DEFINED computertimeoutrestart SET restartpc=%computertimeoutrestart%
IF DEFINED everyhourinfo SET reports=%everyhourinfo%
IF DEFINED approgram SET ap=%approgram%
IF EXIST "%config%" MOVE /Y %config% Backup_%config% >NUL && ECHO Created backup of your old %config%.
> %config% ECHO # Configuration file v. %ver%
>> %config% ECHO # =================================================== [GPU]
>> %config% ECHO # Set how many GPU devices are enabled.
>> %config% ECHO gpus=%gpus%
>> %config% ECHO # Allow computer restart if number of loaded GPUs is not equal to number of enabled GPUs. [0 - false, 1 - true]
>> %config% ECHO gpurestart=%gpurestart%
>> %config% ECHO # Set the total average hashrate of this Rig. Best to set slightly below your reported hashrate. If your miners hasrate drops below the value you set here the script will restart your miner.
>> %config% ECHO hashrate=%hashrate%
>> %config% ECHO # =================================================== [Miner]
>> %config% ECHO # Set the main server mining command here to auto-create %bat% file if it is missing or wrong. [keep default order]
>> %config% ECHO commandserver1=%commandserver1%
IF DEFINED commandserver2 >> %config% ECHO # When the main server fails, %~n0.bat will switch to the additional server below immediately. [in order]
IF DEFINED commandserver2 >> %config% ECHO # Configure miner command here. Old %bat% will be removed and a new one will be created with this value. [keep default order] internetcheck=1 required.
IF DEFINED commandserver2 >> %config% ECHO # The default number of servers is 5, however, you can add or remove as many as you need. e.g. you can have servers 1 2 3 or you can have 1 2 3 4 5 6 7 8 9. [limits are 1-99]
IF %serversamount% GTR 1 FOR /L %%A IN (2,1,%serversamount%) DO (
FOR %%B IN (commandserver%%A) DO IF DEFINED %%B >> %config% ECHO %%B=!commandserver%%A!
)
>> %config% ECHO # =================================================== [Overclock program]
>> %config% ECHO # Autorun and check to see if already running of GPU Overclock program. [0 - false, 1 - true XTREMEGE, 2 - true AFTERBURNER, 3 - true GPUTWEAK, 4 - true PRECISION, 5 - true AORUSGE, 6 - true THUNDERMASTER]
>> %config% ECHO ocprogram=%ocprogram%
>> %config% ECHO # Additional option to auto-enable Overclock Profile for MSI Afterburner. Please, do not use this option if it is not needed. [0 - false, 1 - Profile 1, 2 - Profile 2, 3 - Profile 3, 4 - Profile 4, 5 - Profile 5]
>> %config% ECHO profile=%profile%
>> %config% ECHO # Extra option to enable OC Profile for MSI Afterburner second time. Please, do not use this option if it is not needed. [0 - false, 1 - Profile 1, 2 - Profile 2, 3 - Profile 3, 4 - Profile 4, 5 - Profile 5]
>> %config% ECHO additionalprofile=%additionalprofile%
>> %config% ECHO # Set MSI Afterburner wait timer after start. Important on weak processors. This option is also used to delay extra profile activation by default. [default - 120 sec, min value - 1 sec]
IF %octimeout% EQU 120 IF %gpus% GEQ 1 SET /A octimeout=%gpus%*15
>> %config% ECHO octimeout=%octimeout%
>> %config% ECHO # Allow Overclock program to be restarted when miner is restarted. Please, do not use this option if it is not needed. [0 - false, 1 - true]
>> %config% ECHO restartocprogram=%restartocprogram%
>> %config% ECHO # Launch Overclock program after miner was started. Please, do not use this option if it is not needed. [0 - false, 1 - true]
>> %config% ECHO lauchocprogram=%lauchocprogram%
>> %config% ECHO # =================================================== [Timers]
>> %config% ECHO # Restart MINER every X hours. Set value of delay [in hours] between miner restarts. Note - this will be the number of hours the miner has been running. [0 - false, 1-96 - scheduled hours delay]
>> %config% ECHO restartminer=%restartminer%
>> %config% ECHO # Restart COMPUTER every X hours. Set value of delay [in hours] between computer restarts. Note - this will be the number of hours the miner has been running. [0 - false, 1-96 - scheduled hours delay]
>> %config% ECHO restartpc=%restartpc%
>> %config% ECHO # Restart miner or computer every day at 12:00. [1 - true miner, 2 - true computer, 0 - false]
>> %config% ECHO noonrestart=%noonrestart%
>> %config% ECHO # Restart miner or computer every day at 00:00. [1 - true miner, 2 - true computer, 0 - false]
>> %config% ECHO midnightrestart=%midnightrestart%
>> %config% ECHO # Timeout after miner was started [min value - 1 sec]
>> %config% ECHO afterstarttimeout=%afterstarttimeout%
>> %config% ECHO # =================================================== [Other]
>> %config% ECHO # Enable Internet connectivity check. [0 - false, 1 - true full, 2 - true without server switching]
>> %config% ECHO # Disable Internet connectivity check only if you have difficulties with your connection. [ie. high latency, intermittent connectivity]
>> %config% ECHO internetcheck=%internetcheck%
>> %config% ECHO # Enable 0C - 5C temperature error check. [0 - false, 1 - true]
>> %config% ECHO tempcheck=%tempcheck%
>> %config% ECHO # Enable global temperature error check. [0 - false, 1 - true]
>> %config% ECHO globaltempcheck=%globaltempcheck%
>> %config% ECHO # Enable additional environments. Please do not use this option if it is not needed, or if you do not understand its function. [0 - false, 1 - true]
>> %config% ECHO # GPU_FORCE_64BIT_PTR 1, GPU_MAX_HEAP_SIZE 100, GPU_USE_SYNC_OBJECTS 1, GPU_MAX_ALLOC_PERCENT 100, GPU_SINGLE_ALLOC_PERCENT 100
>> %config% ECHO environments=%environments%
>> %config% ECHO # Enable last share timeout check. Your miner sends and receives shares - if there is a delay of more than sharetimeout value [2 - 59] in minutes between the send/receive, the script will think that the miner is stuck and restart the miner. [0 - false, 1 - true, default value is 15]
>> %config% ECHO sharetimeout=%sharetimeout%
>> %config% ECHO # Number of errors before computer restart. Once the threshold is reached, the computer will restart. [5 - default, only numeric values]
>> %config% ECHO runtimeerrors=%runtimeerrors%
>> %config% ECHO # Number of hashrate errors before miner restart. Once the threshold is reached, the miner will restart. [5 - default, only numeric values]
>> %config% ECHO hashrateerrors=%hashrateerrors%
>> %config% ECHO # Name miner file process. Only change this if you have changed the default name of your %minerprocess% file. [in English, without any special symbols and spaces. Please do not use long names]
>> %config% ECHO minerprocess=%minerprocess%
>> %config% ECHO # Path to miner. Do not change if the script and miner are in the same folder. Only use this option if you plan to switch between multiple miners. [in English, without any special symbols and spaces. Please do not use long names]
>> %config% ECHO minerpath=%minerpath%
>> %config% ECHO # Name start mining .bat file. [in English, without any special symbols and spaces. Please do not use long names]
>> %config% ECHO bat=%bat%
>> %config% ECHO # Name server for ping. Default is google.com - change if you have difficulty reaching Google servers. [in English, without any special symbols and spaces. Please do not use long names]
>> %config% ECHO pingserver=%pingserver%
>> %config% ECHO # Slowdown script for weak CPUs. Increase this value incrementally [1 by 1] if your hashrate drops because of script. This may slow down the responsiveness of the script. [5 - default, only numeric values]
>> %config% ECHO cputimeout=%cputimeout%
>> %config% ECHO # Maximum allowable log file size. [default - 70000000 bytes]
>> %config% ECHO logfilesize=%logfilesize%
>> %config% ECHO # =================================================== [Telegram notifications]
>> %config% ECHO # To enable Telegram proxy or mirror use this option. [https://api.telegram.org - default, http://api.telegram.org.https.s93.wbprx.com - example]
>> %config% ECHO link=%link%
>> %config% ECHO # To enable Telegram notifications enter here your chatid, from Telegram @FarmWatchBot. [0 - disable]
>> %config% ECHO chatid=%chatid%
>> %config% ECHO # Name your Rig. [in English, without any special symbols and spaces. Please do not use long names]
>> %config% ECHO rigname=%rigname%
>> %config% ECHO # Name your group of Rigs. [in English, without any special symbols and spaces. Please do not use long names]
>> %config% ECHO groupname=%groupname%
>> %config% ECHO # Enable hourly statistics through Telegram. [0 - false, 1 - true full, 2 - true full in silent mode, 3 - true short, 4 - true short in silent mode, 5 - disable useless Telegram notifications, 6 - false other notifications in silent mode]
>> %config% ECHO reports=%reports%
>> %config% ECHO # =================================================== [Additional program]
>> %config% ECHO # Enable additional program check on startup. [ie. TeamViewer, Minergate, Storj, OhGodAnETHlargementPill-r2 etc] [0 - false, 1 - true]
>> %config% ECHO ap=%ap%
>> %config% ECHO # Process name of additional program. [Press CTRL+ALT+DEL to find the process name][in English, without any special symbols and spaces. Please do not use long names]
>> %config% ECHO approcessname=%approcessname%
>> %config% ECHO # Path to file of additional program. [ie. approcesspath=C:\Program Files\TeamViewer\TeamViewer.exe or move the .exe file in miners folder and use only the .exe file name ie. approcesspath=Pill.exe]
>> %config% ECHO approcesspath=%approcesspath%
CALL :inform "1" "false" "0" "Default %config% created. Please check it." "2"
timeout.exe /T 3 /nobreak >NUL
GOTO hardstart
:ctimer
CALL :copyright
ECHO +===================================================================+
ECHO Scheduled computer restart, please wait...
ECHO Restarting...
ECHO +============================[%hrdiff%:%mediff%:%ssdiff%]=============================+
CALL :inform "0" "true" "Scheduled computer restart, please wait... Miner ran for *%hrdiff%:%mediff%:%ssdiff%*." "1" "For detailed information please read %~n0.log file."
timeout.exe /T 3 /nobreak >NUL
:restart
IF %pcreboot% EQU 0 GOTO hardstart
COLOR 4F
CALL :screenshot
CALL :inform "1" "false" "Computer restarting..." "1" "0"
CALL :kill "1" "0" "1" "1"
shutdown.exe /T 60 /R /F /C "Your computer will restart after 60 seconds. To cancel restart, close this window and run %~n0.bat manually."
EXIT
:switch
CALL :copyright
ECHO +===================================================================+
ECHO Attempting to switch to the main pool server...
ECHO Miner restarting...
ECHO +============================[%hrdiff%:%mediff%:%ssdiff%]=============================+
CALL :inform "1" "true" "Attempting to switch to the main pool server... Miner ran for *%hrdiff%:%mediff%:%ssdiff%*." "1" "For detailed information please read %~n0.log file."
SET switchtodefault=0
SET queue=1
timeout.exe /T 3 /nobreak >NUL
GOTO start
:mtimer
CALL :copyright
ECHO +===================================================================+
ECHO Scheduled miner restart, please wait...
ECHO Restarting...
ECHO +============================[%hrdiff%:%mediff%:%ssdiff%]=============================+
CALL :inform "0" "true" "Scheduled miner restart, please wait... Miner ran for *%hrdiff%:%mediff%:%ssdiff%*." "1" "For detailed information please read %~n0.log file."
timeout.exe /T 3 /nobreak >NUL
GOTO start
:error
CALL :copyright
COLOR 4F
SET /A errorscounter+=1
IF %errorscounter% GTR %runtimeerrors% (
ECHO +===================================================================+
ECHO Too many errors, need clear GPU cache...
ECHO Computer restarting...
ECHO +============================[%hrdiff%:%mediff%:%ssdiff%]=============================+
CALL :inform "1" "true" "Too many errors. Threshold of %runtimeerrors% runtime errors reached. A restart of the computer to clear GPU cache is required. Restarting... Miner ran for *%hrdiff%:%mediff%:%ssdiff%*." "1" "For detailed information please read %~n0.log file."
timeout.exe /T 3 /nobreak >NUL
GOTO restart
)
ECHO +===================================================================+
ECHO Something is wrong...
ECHO Miner restarting...
ECHO +============================[%hrdiff%:%mediff%:%ssdiff%]=============================+
CALL :inform "1" "false" "Miner restarting, please wait... Miner ran for *%hrdiff%:%mediff%:%ssdiff%*." "1" "For detailed information please read %~n0.log file."
CALL :screenshot
timeout.exe /T 3 /nobreak >NUL
:start
SET secondoclaunch=0
SET chatid=%chatid: =%
SET gpus=%gpus: =%
SET hashrate=%hashrate: =%
IF %tempcheck% EQU 1 SET errorslist=%errorslist% /C:".*t=[0-5]C.*"
IF %globaltempcheck% EQU 1 SET warningslist=/C:".*reached.*"
IF %environments% EQU 1 FOR %%a IN ("GPU_FORCE_64BIT_PTR 1" "GPU_MAX_HEAP_SIZE 100" "GPU_USE_SYNC_OBJECTS 1" "GPU_MAX_ALLOC_PERCENT 100" "GPU_SINGLE_ALLOC_PERCENT 100") DO SETX %%~a 2>NUL 1>&2 && ECHO %%~a.
IF %environments% EQU 0 FOR %%a IN ("GPU_FORCE_64BIT_PTR" "GPU_MAX_HEAP_SIZE" "GPU_USE_SYNC_OBJECTS" "GPU_MAX_ALLOC_PERCENT" "GPU_SINGLE_ALLOC_PERCENT") DO REG DELETE HKCU\Environment /F /V %%~a 2>NUL 1>&2 && ECHO %%~a successfully removed from environments.
FOR /F "tokens=1 delims=." %%A IN ('wmic.exe OS GET localdatetime^|Find "."') DO SET dt1=%%A
SET mh1=1%dt1:~4,2%
SET dy1=1%dt1:~6,2%
SET hr1=1%dt1:~8,2%
SET me1=1%dt1:~10,2%
SET ss1=1%dt1:~12,2%
SET /A mh1=%mh1%-100
SET /A dy1=%dy1%-100
SET /A hr1=%hr1%-100
SET /A me1=%me1%-100
SET /A ss1=%ss1%-100
SET /A dtdiff1=%hr1%*60*60+%me1%*60+%ss1%
IF NOT EXIST "%minerpath%" (
CALL :inform "1" "false" "%minerprocess% is missing. Please check the directory for missing files." "1" "1"
PAUSE
EXIT
)
IF NOT EXIST "Logs" MD Logs && ECHO Folder Logs created.
IF NOT EXIST "Screenshots" MD Screenshots && ECHO Folder Screenshots created.
IF %ocprogram% GEQ 1 IF %ocprogram% LEQ 6 (
FOR /F "tokens=%ocprogram% delims=," %%A IN ("Xtreme,MSIAfterburner,GPUTweakII,PrecisionX_x64,AORUS,THPanel") DO SET ocprocessname=%%A
FOR /F "tokens=%ocprogram% delims=," %%A IN ("\GIGABYTE\XTREME GAMING ENGINE\,\MSI Afterburner\,\ASUS\GPU TweakII\,\EVGA\Precision XOC\,\GIGABYTE\AORUS GRAPHICS ENGINE\,\Thunder Master\") DO SET ocprocesspath=%%A
)
IF DEFINED ocprocessname IF DEFINED ocprocesspath (
IF NOT EXIST "%programfiles(x86)%%ocprocesspath%" (
ECHO Incorrect path to %ocprocessname%.exe. Default install path required to function. Please reinstall the software using the default path.
SET ocprogram=0
)
IF EXIST "%programfiles(x86)%%ocprocesspath%" IF %firstrun% NEQ 0 IF %restartocprogram% GEQ 1 (
IF %profile% GEQ 1 IF %profile% LEQ 5 IF %ocprogram% EQU 2 (
IF %restartocprogram% GEQ 2 "%programfiles(x86)%%ocprocesspath%%ocprocessname%.exe" -Profile%restartocprogram% >NUL
IF %restartocprogram% EQU 1 (
tskill.exe /A /V %ocprocessname% 2>NUL 1>&2
timeout.exe /T 15 /nobreak >NUL
START "" "%programfiles(x86)%%ocprocesspath%%ocprocessname%.exe" || (
CALL :inform "1" "false" "Unable to start %ocprocessname%.exe." "1" "1"
SET ocprogram=0
GOTO error
)
)
timeout.exe /T 5 /nobreak >NUL
)
tskill.exe /A /V %ocprocessname% 2>NUL 1>&2
CALL :inform "1" "false" "0" "Process %ocprocessname%.exe was successfully killed." "2"
)
)
tasklist.exe /FI "IMAGENAME eq werfault.exe" 2>NUL| find.exe /I /N "werfault.exe" >NUL && CALL :killwerfault
tasklist.exe /FI "IMAGENAME eq %minerprocess%" 2>NUL| find.exe /I /N "%minerprocess%" >NUL && (
taskkill.exe /T /F /IM "%minerprocess%" 2>NUL 1>&2 || (
CALL :inform "1" "false" "Unable to kill %minerprocess%. Retrying..." "1" "1"
GOTO error
)
timeout.exe /T 4 /nobreak >NUL && taskkill.exe /T /F /FI "IMAGENAME eq cmd.exe" /FI "WINDOWTITLE eq *%bat%*" 2>NUL 1>&2
CALL :inform "1" "false" "0" "Process %minerprocess% was successfully killed." "2"
)
ECHO Please wait 30 seconds or press any key to continue...
ECHO This wait is needed to prevent GPUs crashes. It also allows you to connect via TeamViewer to close the script before the miner launches in case of critical errors or BSOD.
timeout.exe /T 30 >NUL
IF %ap% NEQ 0 IF NOT EXIST "%approcesspath%" (
ECHO Incorrect path to %approcessname%.
SET ap=0
)
IF %ap% NEQ 0 (
timeout.exe /T 5 /nobreak >NUL
tasklist.exe /FI "IMAGENAME eq %approcessname%" 2>NUL| find.exe /I /N "%approcessname%" >NUL || (
START /MIN "%approcessname%" "%approcesspath%" && (
CALL :inform "0" "true" "%approcessname% was started." "1" "1"
) || (
CALL :inform "1" "false" "Unable to start %approcessname%." "1" "1"
SET ap=0
GOTO error
)
)
)
IF %lauchocprogram% EQU 0 CALL :oclauch
IF EXIST "%log%" (
MOVE /Y %log% Logs\miner_%mh1%.%dy1%_%hr1%.%me1%.log 2>NUL 1>&2 && (
CALL :inform "1" "false" "0" "%log% moved to Logs folder as miner_%mh1%.%dy1%_%hr1%.%me1%.log" "2"
IF EXIST "%~dp0Logs\*.log" FOR /F "skip=30 usebackq delims=" %%a IN (`DIR /B /A:-D /O:-D /T:W "%~dp0Logs\"`) DO DEL /F /Q "%~dp0Logs\%%~a" 2>NUL 1>&2
IF EXIST "%~dp0Logs\*.jpg" FOR /F "skip=30 usebackq delims=" %%a IN (`DIR /B /A:-D /O:-D /T:W "%~dp0Screenshots\"`) DO DEL /F /Q "%~dp0Screenshots\%%~a" 2>NUL 1>&2
) || (
CALL :inform "1" "false" "Unable to rename or access %log%. Attempting to delete %log% and continue..." "1" "1"
DEL /Q /F "%log%" 2>NUL 1>&2
IF EXIST "%log%" (
CALL :inform "1" "false" "Unable to delete %log%." "1" "1"
GOTO error
)
)
)
> %bat% ECHO @ECHO off
>> %bat% ECHO TITLE %bat%
>> %bat% ECHO pushd "%~dp0"
>> %bat% ECHO REM Configure the miners command line in %config% file. Not in %bat% - any values in %bat% will not be used.
IF %queue% GEQ 1 IF %queue% LEQ %serversamount% >> %bat% ECHO !commandserver%queue%!
REM Default pool server settings for debugging. Will be activated only in case of mining failed on all user pool servers, to detect errors in the configuration file. Will be deactivated automatically in 30 minutes and switched back to settings of main pool server. To be clear, this will mean you are mining to my address for 30 minutes, at which point the script will then iterate through the pools that you have configured in the configuration file. I have used this address because I know these settings work. If the script has reached this point, CHECK YOUR CONFIGURATION FILE or all pools you have specified are offline. You can also change the address here to your own.
IF %queue% EQU 0 >> %bat% ECHO %minerpath% -xpool stratum+ssl://xmr-eu1.nanopool.org:14433 -xwal 4JUdGzvrMFDWrUUwY3toJATSeNwjn54LkCnKBPRzDuhzi5vSepHfUckJNxRL2gjkNrSqtCoRUrEDAgRwsQvVCjZbS5VF8ypv8VF3GUiS1J.%ver:.=% -xpsw x -allpools 1 -tstop 80 -logfile %log% -wd 0
>> %bat% ECHO EXIT
timeout.exe /T 3 /nobreak >NUL
START "%bat%" "%bat%" && (
CALL :inform "1" "false" "Miner was started." "Miner was started. Script v.%ver%." "Miner was started at %Time:~-11,8%"
FOR /F "tokens=3,4 delims=/:= " %%a IN ('findstr.exe /R /C:".*%minerprocess%" %bat%') DO (
ECHO %%b| findstr.exe /V /I /R /C:".*stratum.*ssl.*" /C:".*stratum.*tcp.*" /C:".*stratum.*tls.*" /C:".*http.*" /C:".*https.*" /C:".*log.*"| findstr.exe /R /C:".*\..*" >NUL && (
SET curservername=%%b
)
ECHO %%a| findstr.exe /V /I /R /C:".*stratum.*ssl.*" /C:".*stratum.*tcp.*" /C:".*stratum.*tls.*" /C:".*http.*" /C:".*https.*" /C:".*log.*"| findstr.exe /R /C:".*\..*" >NUL && (
SET curservername=%%a
)
)
timeout.exe /T 15 /nobreak >NUL
) || (
CALL :inform "1" "false" "Unable to start miner." "1" "1"
GOTO error
)
IF %lauchocprogram% EQU 1 CALL :oclauch
IF %additionalprofile% GEQ 1 IF %additionalprofile% LEQ 5 IF !secondoclaunch! EQU 1 CALL :oclauch
IF %afterstarttimeout% GEQ 1 (
ECHO Please wait %afterstarttimeout% seconds or press any key to continue...
timeout.exe /T %afterstarttimeout% >NUL
)
IF NOT DEFINED curservername SET curservername=unknown
IF NOT EXIST "%log%" (
findstr.exe /R /C:".*-logfile %log%.*" %bat% 2>NUL 1>&2 || (
CALL :inform "1" "false" "%log% is missing. Ensure *-logfile %log%* option is added to the miners command line in *%config%* file." "%log% is missing. Ensure -logfile %log% option is added to the miners command line in %config% file." "2"
PAUSE
EXIT
)
CALL :inform "1" "false" "%log% is missing. Probably %minerprocess% hangs..." "1" "1"
GOTO restart
) ELSE (
findstr.exe /R /C:".*%minerprocess% -xpool.*-tstop.*-logfile %log%.*" %bat% 2>NUL 1>&2 || (
CALL :inform "1" "false" "Ensure *%minerpath% -xpool -tstop -logfile %log%* options added to the miners command line in this order." "Ensure %minerpath% -xpool -tstop -logfile %log% options added to the miners command line in this order." "2"
)
ECHO log monitoring started.
ECHO Collecting information. Please wait...
timeout.exe /T 25 /nobreak >NUL
)
SET hashrateerrorscount=0
SET oldhashrate=0
SET firstrun=0
SET gpucount=0
:check
SET interneterrorscount=1
SET lastinterneterror=0
SET minhashrate=0
SET hashcount=0
SET lasterror=0
SET sumresult=0
SET sumhash=0
FOR /F "tokens=1 delims=." %%A IN ('wmic.exe OS GET localdatetime^|Find "."') DO SET dt2=%%A
SET mh2=1%dt2:~4,2%
SET dy2=1%dt2:~6,2%
SET hr2=1%dt2:~8,2%
SET me2=1%dt2:~10,2%
SET ss2=1%dt2:~12,2%
SET /A mh2=%mh2%-100
SET /A dy2=%dy2%-100
SET /A hr2=%hr2%-100
SET /A me2=%me2%-100
SET /A ss2=%ss2%-100
SET /A dtdiff2=%hr2%*60*60+%me2%*60+%ss2%
SET /A nextreqtime=%me2%+7
IF %ptos% GTR %nextreqtime% SET ptos=0
IF %dy2% GTR %dy1% (
SET /A dtdiff=^(%dy2%-%dy1%^)*86400-%dtdiff1%+%dtdiff2%
) ELSE (
IF %mh2% NEQ %mh1% (
CALL :inform "0" "true" "New month reached - Miner must be restarted to ensure accurate runtime, please wait..." "1" "1"
GOTO hardstart
)
IF %dtdiff2% GEQ %dtdiff1% (
SET /A dtdiff=%dtdiff2%-%dtdiff1%
) ELSE (
SET /A dtdiff=%dtdiff1%-%dtdiff2%
)
)
SET /A hrdiff=%dtdiff%/60/60
SET /A mediff=%dtdiff% %% 3600/60
SET /A ssdiff=%dtdiff% %% 60
IF %hrdiff% LSS 10 SET hrdiff=0%hrdiff%
IF %mediff% LSS 10 SET mediff=0%mediff%
IF %ssdiff% LSS 10 SET ssdiff=0%ssdiff%
IF %midnightrestart% EQU 1 IF %dy2% NEQ %dy1% GOTO mtimer
IF %midnightrestart% EQU 2 IF %dy2% NEQ %dy1% GOTO ctimer
IF %restartminer% GEQ 1 IF %hrdiff% GEQ %restartminer% GOTO mtimer
IF %restartpc% GEQ 1 IF %hrdiff% GEQ %restartpc% GOTO ctimer
IF %hrdiff% GEQ 1 IF %hr2% EQU 12 (
IF %noonrestart% EQU 1 GOTO mtimer
IF %noonrestart% EQU 2 GOTO ctimer
)
IF %switchtodefault% EQU 1 IF %hrdiff% EQU 0 IF %mediff% GEQ 30 GOTO switch
FOR %%A IN (%log%) DO (
IF %%~ZA GTR %logfilesize% (
CALL :inform "0" "true" "Miner must be restarted, large log file size, please wait..." "1" "1"
GOTO hardstart
)
)
IF %hrdiff% GEQ 96 (
CALL :inform "0" "true" "Miner must be restarted, large log file size, please wait..." "1" "1"
GOTO hardstart
)
timeout.exe /T %cputimeout% /nobreak >NUL
FOR /F "delims=" %%N IN ('findstr.exe /I /R %criticalerrorslist% %errorslist% %warningslist% %interneterrorslist% %log% ^| findstr.exe /V /R /I /C:".*DevFee.*"') DO (
SET "lasterror=%%N"
SET lasterror=!lasterror:"=!
)
IF !lasterror! NEQ 0 (
IF %internetcheck% GEQ 1 (
ECHO !lasterror!| findstr.exe /I /R %interneterrorslist% 2>NUL 1>&2 && (
FOR /F "delims=" %%n IN ('findstr.exe /I /R %interneterrorslist% %errorscancel% %log% ^| findstr.exe /V /R /I /C:".*DevFee.*"') DO SET "lastinterneterror=%%n"
ECHO !lastinterneterror!| findstr.exe /I /R %interneterrorslist% >NUL && (
ECHO Something is wrong with your Internet connection. Waiting for confirmation of connection error in case miner cannot automatically reconnect...
timeout.exe /T 120 >NUL
FOR /F "delims=" %%n IN ('findstr.exe /I /R %interneterrorslist% %errorscancel% %log% ^| findstr.exe /V /R /I /C:".*DevFee.*"') DO SET "lastinterneterror=%%n"
ECHO !lastinterneterror!| findstr.exe /I /R %interneterrorslist% >NUL && (
CALL :inform "1" "false" "!lasterror!" "1" "0"
ping.exe %pingserver%| find.exe /I "TTL=" >NUL && (
CALL :copyright
COLOR 4F
CALL :kill "0" "0" "1" "1"
IF %internetcheck% NEQ 2 IF %switchtodefault% NEQ 2 SET switchtodefault=1
IF %internetcheck% NEQ 2 SET /A queue+=1
SET /A errorscounter+=1
ECHO +===================================================================+
ECHO Check %config% file for errors or pool is offline...
IF %internetcheck% NEQ 2 ECHO Miner restarting with changed values...
IF %internetcheck% EQU 2 ECHO Miner restarting...
ECHO +============================[%hrdiff%:%mediff%:%ssdiff%]=============================+
IF !queue! GTR %serversamount% SET queue=0
IF %internetcheck% NEQ 2 CALL :inform "1" "false" "Pool server was switched to *!queue!*. Please check your *%config%* file carefully for spelling errors or incorrect parameters. Otherwise check if the pool you are connecting to is online." "Pool server was switched to !queue!. Please check your %config% file carefully for spelling errors or incorrect parameters. Otherwise check if the pool you are connecting to is online." "2"
IF %internetcheck% EQU 2 CALL :inform "1" "false" "Please check your *%config%* file carefully for spelling errors or incorrect parameters. Otherwise check if the pool you are connecting to is online. Miner restarting..." "Please check your %config% file carefully for spelling errors or incorrect parameters. Otherwise check if the pool you are connecting to is online. Miner restarting..." "2"
GOTO start
) || (
CALL :inform "1" "false" "Something is wrong with your Internet connection. Please check your connection. Miner ran for *%hrdiff%:%mediff%:%ssdiff%*." "1" "0"
:tryingreconnect
CALL :copyright
COLOR 4F
ECHO +===================================================================+
ECHO Something is wrong with your Internet...
ECHO Attempting to reconnect...
ECHO +============================[%hrdiff%:%mediff%:%ssdiff%]=============================+
IF %hrdiff% EQU 0 IF %mediff% LEQ 15 IF %interneterrorscount% GTR 60 GOTO restart
IF %hrdiff% EQU 0 IF %mediff% GTR 15 IF %interneterrorscount% GTR 15 GOTO restart
IF %hrdiff% GTR 0 IF %interneterrorscount% GTR 15 GOTO restart
ECHO Attempt %interneterrorscount% to restore Internet connection.
SET /A interneterrorscount+=1
FOR /F "delims=" %%n IN ('findstr.exe /I /R %interneterrorslist% %errorscancel% %log% ^| findstr.exe /V /R /I /C:".*DevFee.*"') DO SET "lastinterneterror=%%n"
ECHO !lastinterneterror!| findstr.exe /I /R %errorscancel% && (
ECHO +===================================================================+
ECHO Connection has been restored...
ECHO Continue mining...
ECHO +===================================================================+
CALL :inform "1" "true" "Something was wrong with your Internet connection. Connection has been restored. Continue mining..." "1" "0"
GOTO check
)
ping.exe %pingserver%| find.exe /I "TTL=" >NUL && GOTO reconnected || (
timeout.exe /T 60 /nobreak >NUL
GOTO tryingreconnect
)
:reconnected
ECHO +===================================================================+
ECHO Connection has been restored...
ECHO Miner restarting...
ECHO +===================================================================+
CALL :inform "1" "false" "Something was wrong with your Internet connection. Connection has been restored. Miner restarting... Miner ran for *%hrdiff%:%mediff%:%ssdiff%*." "1" "0"
GOTO start
)
)
)
)
)
ECHO !lasterror!| findstr.exe /I /R %errorslist% 2>NUL && (
CALL :inform "1" "false" "!lasterror!" "1" "0"
GOTO error
)
ECHO !lasterror!| findstr.exe /I /R %criticalerrorslist% 2>NUL && (
CALL :inform "1" "false" "!lasterror!" "1" "0"
GOTO restart
)
ECHO !lasterror!| findstr.exe /I /R %warningslist% 2>NUL && (
CALL :copyright
COLOR 4F
ECHO +===================================================================+
ECHO Temperature limit reached...
ECHO +============================[%hrdiff%:%mediff%:%ssdiff%]=============================+
CALL :inform "1" "false" "0" "%curtemp%." "2"
IF %hrdiff% EQU 0 IF %mediff% LEQ 10 (
CALL :kill "1" "0" "1" "1"
CALL :inform "1" "false" "%curtemp%.%%%%0A%%%%0ATemperature limit reached. Process %minerprocess% was successfully killed. GPUs will now *STOP MINING*. Please ensure your GPUs have enough air flow.%%%%0A%%%%0A*Waiting for users input...*" "Please ensure your GPUs have enough air flow. GPUs will now STOP MINING." "Please ensure your GPUs have enough air flow. GPUs will now STOP MINING. Waiting for users input..."
PAUSE
GOTO hardstart
)
CALL :inform "1" "false" "%curtemp%.%%%%0A%%%%0ATemperature limit reached. Fans may be stuck. Attempting to restart computer... Miner ran for *%hrdiff%:%mediff%:%ssdiff%*." "Temperature limit reached. Fans may be stuck." "2"
GOTO restart
)
)
timeout.exe /T %cputimeout% /nobreak >NUL
tasklist.exe /FI "IMAGENAME eq werfault.exe" 2>NUL| find.exe /I /N "werfault.exe" >NUL && CALL :killwerfault
tasklist.exe /FI "IMAGENAME eq %minerprocess%" 2>NUL| find.exe /I /N "%minerprocess%" >NUL || (
CALL :inform "1" "false" "Process %minerprocess% crashed..." "1" "1"
GOTO error
)
IF DEFINED ocprocessname IF DEFINED ocprocesspath IF %ocprogram% NEQ 0 (
timeout.exe /T %cputimeout% /nobreak >NUL
tasklist.exe /FI "IMAGENAME eq %ocprocessname%.exe" 2>NUL| find.exe /I /N "%ocprocessname%.exe" >NUL || (
CALL :inform "1" "false" "Process %ocprocessname%.exe crashed..." "1" "1"
GOTO error
)
)
IF %ap% EQU 1 (
timeout.exe /T %cputimeout% /nobreak >NUL
tasklist.exe /FI "IMAGENAME eq %approcessname%" 2>NUL| find.exe /I /N "%approcessname%" >NUL || (
CALL :inform "1" "false" "%approcessname% crashed..." "1" "1"
START /MIN "%approcessname%" "%approcesspath%" && (
CALL :inform "0" "true" "%approcessname% was started." "1" "1"
) || (
CALL :inform "1" "false" "Unable to start %approcessname%." "1" "1"
SET ap=0
GOTO error
)
)
)
IF %firstrun% EQU 0 (
timeout.exe /T %cputimeout% /nobreak >NUL
FOR /F "tokens=3 delims= " %%A IN ('findstr.exe /R /C:"Total cards: .*" %log%') DO SET /A gpucount=%%A
IF !gpucount! EQU 0 SET gpucount=1
IF %gpus% EQU 0 SET gpus=!gpucount!
)
IF %firstrun% EQU 0 (
IF %gpus% GTR %gpucount% (
IF %gpurestart% EQU 1 (
CALL :copyright
COLOR 4F
ECHO +===================================================================+
ECHO Failed to load all GPUs. Number of GPUs: !gpucount!/%gpus%
ECHO Computer restarting...
ECHO +============================[%hrdiff%:%mediff%:%ssdiff%]=============================+
CALL :inform "1" "false" "Failed to load all GPUs. Number of GPUs *%gpucount%/%gpus%*." "Failed to load all GPUs. Number of GPUs %gpucount%/%gpus%." "2"
GOTO restart
) ELSE (
CALL :inform "1" "false" "Failed to load all GPUs. Number of GPUs *%gpucount%/%gpus%*." "Failed to load all GPUs. Number of GPUs %gpucount%/%gpus%." "2"
SET /A hashrate=%hashrate%/%gpus%*%gpucount%
)
)
IF %gpus% LSS %gpucount% (
CALL :inform "1" "false" "Loaded too many GPUs. This must be set to a number higher than *%gpus%* in your *%config%* file under *gpus*. Number of GPUs *%gpucount%/%gpus%*." "Loaded too many GPUs. This must be set to a number higher than %gpus% in your %config% file under gpus. Number of GPUs: %gpucount%/%gpus%." "2"
IF %gpurestart% EQU 1 GOTO restart
)
SET firstrun=1
)
timeout.exe /T %cputimeout% /nobreak >NUL
FOR /F "tokens=5 delims=. " %%A IN ('findstr.exe /R /C:".*- Total Speed: .*/s.*" %log% ^| findstr.exe /V /R /C:".*DevFee.*"') DO (
SET lasthashrate=%%A
IF !lasthashrate! NEQ 0 IF !lasthashrate! LSS %hashrate% SET /A minhashrate+=1
IF !lasthashrate! EQU 0 SET /A minhashrate+=1
SET /A hashcount+=1
SET /A sumhash=sumhash+%%A
SET /A sumresult=sumhash/hashcount
IF !minhashrate! GEQ 99 GOTO passaveragecheck
)
timeout.exe /T %cputimeout% /nobreak >NUL
FOR /F "delims=" %%A IN ('findstr.exe /R /C:".*GPU.* t=.*C fan=.*" %log%') DO SET curtempcache=%%A
IF DEFINED curtempcache (
FOR /F "tokens=2-20 delims=t" %%a IN ("%curtempcache%") DO (
SET curtemp=Temp:
SET gpunum=0
FOR %%A IN ("%%a" "%%b" "%%c" "%%d" "%%e" "%%f" "%%g" "%%h" "%%i" "%%j" "%%k" "%%l" "%%m" "%%n" "%%o" "%%p" "%%q" "%%r" "%%s") DO (
IF !gpunum! LSS %gpus% (
FOR /F "tokens=1 delims==C" %%B IN (%%A) DO (
IF "%%B" NEQ "" IF %%B GEQ 0 (
IF %%B LSS 70 SET curtemp=!curtemp! G!gpunum! %%BC,
IF %%B GEQ 70 SET curtemp=!curtemp! G!gpunum! *%%BC*,
SET /A gpunum+=1
)
)
)
)
IF "!curtemp!" EQU "Temp:" SET curtemp=unknown
IF "!curtemp!" NEQ "unknown" SET curtemp=!curtemp:~0,-1!
)
)
timeout.exe /T %cputimeout% /nobreak >NUL
FOR /F "delims=" %%A IN ('findstr.exe /R /C:".*GPU.* .*/s.*" %log% ^| findstr.exe /V /R /C:".*DevFee.*"') DO SET curspeedcache=%%A
IF DEFINED curspeedcache (
FOR /F "tokens=2-20 delims=GPU" %%a IN ("%curspeedcache%") DO (
SET curspeed=Speed:
SET gpunum=0
FOR %%A IN ("%%a" "%%b" "%%c" "%%d" "%%e" "%%f" "%%g" "%%h" "%%i" "%%j" "%%k" "%%l" "%%m" "%%n" "%%o" "%%p" "%%q" "%%r" "%%s") DO (
IF !gpunum! LSS %gpus% (
FOR /F "tokens=2 delims=HKMhkm/s,. " %%B IN (%%A) DO (
IF "%%B" NEQ "" IF %%B GEQ 0 (
SET curspeed=!curspeed! G!gpunum! %%B,
SET /A gpunum+=1
)
)
)
)
IF "!curspeed!" EQU "Speed:" SET curspeed=unknown
IF "!curspeed!" NEQ "unknown" SET curspeed=!curspeed:~0,-1!
ECHO !curspeed!| findstr.exe /R /C:".* 0\..*" 2>NUL 1>&2 && SET /A minhashrate+=1
IF !minhashrate! GEQ 99 GOTO passaveragecheck
)
)
timeout.exe /T %cputimeout% /nobreak >NUL
IF "%sumresult%" NEQ "0" IF %sumresult% LSS %oldhashrate% IF %sumresult% LSS %hashrate% (
IF %hashrateerrorscount% GEQ %hashrateerrors% (
:passaveragecheck
CALL :inform "1" "false" "Low hashrate. Average: *%sumresult%/%hashrate%* Last: *%lasthashrate%/%hashrate%*." "Low hashrate. Average: %sumresult%/%hashrate% Last: %lasthashrate%/%hashrate%." "2"
GOTO error
)
CALL :inform "0" "true" "Abnormal hashrate. Average: *%sumresult%/%hashrate%* Last: *%lasthashrate%/%hashrate%*." "Abnormal hashrate. Average: %sumresult%/%hashrate% Last: %lasthashrate%/%hashrate%." "2"
SET /A hashrateerrorscount+=1
)
IF "%sumresult%" NEQ "0" IF %sumresult% NEQ %oldhashrate% SET oldhashrate=%sumresult%
IF %sharetimeout% GEQ 1 IF %sharetimeout% LEQ 59 IF %ptos% LSS %me2% (
timeout.exe /T %cputimeout% /nobreak >NUL
IF %sharetimeout% EQU 1 SET sharetimeout=15
SET /A ptos=%me2%+7
SET lastsharediff=0
SET lastsharemin=1%dt1:~10,2%
FOR /F "tokens=2 delims=:" %%A IN ('findstr.exe /R /C:".*SHARE FOUND.*" /C:".*Share accepted.*" %log%') DO SET lastsharemin=1%%A
SET /A lastsharemin=!lastsharemin!-100
IF !lastsharemin! GEQ 0 IF %me2% GTR 0 (
IF !lastsharemin! EQU 0 SET lastsharemin=59
IF !lastsharemin! LSS %me2% SET /A lastsharediff=%me2%-!lastsharemin!
IF !lastsharemin! GTR %me2% SET /A lastsharediff=!lastsharemin!-%me2%
IF !lastsharemin! GTR 50 IF %me2% LEQ 10 SET /A lastsharediff=60-!lastsharemin!+%me2%
IF !lastsharemin! LEQ 10 IF %me2% GTR 50 SET /A lastsharediff=60-%me2%+!lastsharemin!
IF !lastsharediff! GTR !sharetimeout! (
CALL :inform "0" "false" "Long share timeout... *!lastsharemin!/%me2%*." "Long share timeout... !lastsharemin!/%me2%." "2"
GOTO error
)
)
)
IF NOT DEFINED curtemp SET curtemp=unknown
IF NOT DEFINED curspeed SET curspeed=unknown
CLS
COLOR 1F
ECHO +===================================================================+
ECHO AutoRun v.%ver% for %mn% Miner - by Acrefawn
ECHO ETH: 0x4a98909270621531dda26de63679c1c6fdcf32ea
ECHO USDT: TDwbaARpdsoD36RpLPSyqxcF3JY8KncajY
ECHO BTC: 1wdJBYkVromPoiYk82JfSGSSVVyFJnenB
ECHO +===================================================[%Time%]===+
ECHO Process %minerprocess% is running for %hrdiff%:%mediff%:%ssdiff% [%errorscounter%/%runtimeerrors%].
ECHO Rig [%rigname%] group [%groupname%] using [%gpucount%/%gpus%] GPUs.
IF "%curservername%" NEQ "unknown" ECHO Server: [%queue%] %curservername%
IF "%sumresult%" NEQ "0" IF DEFINED lasthashrate (
ECHO +===================================================================+
ECHO Total current speed: %lasthashrate%/%hashrate% [%minhashrate%/99]
ECHO Total average speed: %sumresult%/%hashrate% [%hashrateerrorscount%/%hashrateerrors%]
IF "%curspeed%" NEQ "unknown" (
ECHO Current GPU speed:
ECHO - %curspeed:~7%.
)
IF "%curtemp%" NEQ "unknown" (
ECHO Current GPU temp:
ECHO - %curtemp:~6%.
)
)
ECHO +===================================================================+
IF DEFINED ocprocessname IF DEFINED ocprocesspath (
IF %ocprogram% NEQ 0 IF %ocprogram% NEQ 2 ECHO Process %ocprocessname%.exe is running...
IF %ocprogram% EQU 2 (
IF %profile% GEQ 1 IF %profile% LEQ 5 IF %additionalprofile% EQU 0 (
ECHO Process %ocprocessname%.exe [Profile %profile%] is running...
)
IF %profile% GEQ 1 IF %profile% LEQ 5 IF %additionalprofile% GEQ 1 IF %additionalprofile% LEQ 5 (
ECHO Process %ocprocessname%.exe [Profile %profile% and %additionalprofile%] is running...
)
IF %profile% LSS 1 IF %profile% GTR 5 ECHO Process %ocprocessname%.exe is running...
)
)
IF %ocprogram% EQU 0 ECHO [Disabled] GPU Overclock monitor
IF "%midnightrestart%" EQU "0" ECHO [Disabled] Autorestart at 00:00
IF "%midnightrestart%" NEQ "0" ECHO [Enabled] Autorestart at 00:00
IF "%noonrestart%" EQU "0" ECHO [Disabled] Autorestart at 12:00
IF "%noonrestart%" NEQ "0" ECHO [Enabled] Autorestart at 12:00
IF "%restartminer%" EQU "0" ECHO [Disabled] Autorestart miner every hour
IF "%restartminer%" NEQ "0" ECHO [Enabled] Autorestart miner every %restartminer%h
IF "%restartpc%" EQU "0" ECHO [Disabled] Autorestart computer every hour
IF "%restartpc%" NEQ "0" ECHO [Enabled] Autorestart computer every %restartpc%h
IF %sharetimeout% EQU 0 ECHO [Disabled] Last share timeout check
IF %sharetimeout% EQU 1 ECHO [Enabled] Last share timeout check [!lastsharemin!/%me2%]
IF "%chatid%" EQU "0" ECHO [Disabled] Telegram notifications
IF "%chatid%" NEQ "0" ECHO [Enabled] Telegram notifications using chatid [%chatid%]
IF "%ap%" EQU "0" ECHO [Disabled] Additional program autorun
IF "%ap%" EQU "1" ECHO [Enabled] Additional program autorun using [%approcessname%]
ECHO +===================================================================+
ECHO Now I will take care of your miner and you can relax...
SET statusmessage=Running for *%hrdiff%:%mediff%:%ssdiff%*
IF "%curservername%" NEQ "unknown" SET statusmessage=%statusmessage% on %curservername%
IF DEFINED lasthashrate IF "%sumresult%" NEQ "0" SET statusmessage=%statusmessage%%%%%0AAverage hash: *%sumresult%*%%%%0ALast hash: *%lasthashrate%*
IF "%curspeed%" NEQ "unknown" SET statusmessage=%statusmessage%%%%%0A%curspeed%
IF "%curtemp%" NEQ "unknown" SET statusmessage=%statusmessage%%%%%0A%curtemp%
IF "%chatid%" NEQ "0" (
IF %me2% LSS 30 SET allowsend=1
IF %me2% GEQ 30 IF %allowsend% EQU 1 (
IF %reports% EQU 1 CALL :inform "1" "false" "%statusmessage%" "0" "0"
IF %reports% EQU 2 CALL :inform "1" "true" "%statusmessage%" "0" "0"
IF %reports% EQU 3 CALL :inform "1" "false" "Online, *%hrdiff%:%mediff%:%ssdiff%*, *%lasthashrate%*" "0" "0"
IF %reports% EQU 4 CALL :inform "1" "true" "Online, *%hrdiff%:%mediff%:%ssdiff%*, *%lasthashrate%*" "0" "0"
SET allowsend=0
)
)
GOTO check
:screenshot
powershell.exe -command "Add-Type -AssemblyName System.Windows.Forms; Add-type -AssemblyName System.Drawing; $Screen = [System.Windows.Forms.SystemInformation]::VirtualScreen; $bitmap = New-Object System.Drawing.Bitmap $Screen.Width, $Screen.Height; $graphic = [System.Drawing.Graphics]::FromImage($bitmap); $graphic.CopyFromScreen($Screen.Left, $Screen.Top, 0, 0, $bitmap.Size); $bitmap.Save('Screenshots\miner_%mh1%.%dy1%_%hr1%.%me1%.jpg');" 2>NUL 1>&2
EXIT /b
:kill
IF "%~1" EQU "1" IF %ocprogram% NEQ 0 timeout.exe /T 2 /nobreak >NUL && taskkill.exe /T /F /IM "%ocprocessname%" 2>NUL 1>&2 && ECHO Process %ocprocessname% was successfully killed.
IF "%~2" EQU "1" IF %ap% EQU 1 timeout.exe /T 2 /nobreak >NUL && taskkill.exe /F /IM "%approcessname%" 2>NUL 1>&2 && ECHO Process %approcessname% was successfully killed.
IF "%~3" EQU "1" timeout.exe /T 2 /nobreak >NUL && taskkill.exe /T /F /IM "%minerprocess%" 2>NUL 1>&2 && ECHO Process %minerprocess% was successfully killed.
IF "%~4" EQU "1" timeout.exe /T 4 /nobreak >NUL && taskkill.exe /T /F /FI "IMAGENAME eq cmd.exe" /FI "WINDOWTITLE eq *%bat%*" 2>NUL 1>&2
timeout.exe /T 5 /nobreak >NUL
EXIT /b
:killwerfault
taskkill.exe /T /F /IM "werfault.exe" 2>NUL 1>&2 && ECHO Process werfault.exe was successfully killed.
tskill.exe /A /V werfault 2>NUL 1>&2 && ECHO Process werfault.exe was successfully killed.
EXIT /b
:inform
IF "%~5" NEQ "0" IF "%~5" NEQ "1" IF "%~5" NEQ "2" ECHO %~5
IF "%~5" EQU "1" ECHO %~3
IF "%~5" EQU "2" ECHO %~4
IF "%~4" NEQ "0" IF "%~4" NEQ "1" >> %~n0.log ECHO [%Date%][%Time:~-11,8%] %~4
IF "%~4" EQU "1" >> %~n0.log ECHO [%Date%][%Time:~-11,8%] %~3
IF "%reports%" EQU "5" IF "%~1" EQU "0" EXIT /b
IF "%reports%" NEQ "6" IF "%~3" NEQ "0" IF "%~3" NEQ "" IF "%chatid%" NEQ "0" powershell.exe -command "[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (new-object net.webclient).DownloadString('%link%/bot%num%:%prt%-%rtp%dp%tpr%/sendMessage?parse_mode=markdown&disable_notification=%~2&chat_id=%chatid%&text=*%rigname%:* %~3')" 2>NUL 1>&2
IF "%reports%" EQU "6" IF "%~3" NEQ "0" IF "%~3" NEQ "" IF "%chatid%" NEQ "0" powershell.exe -command "[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; (new-object net.webclient).DownloadString('%link%/bot%num%:%prt%-%rtp%dp%tpr%/sendMessage?parse_mode=markdown&disable_notification=false&chat_id=%chatid%&text=*%rigname%:* %~3')" 2>NUL 1>&2
EXIT /b
:copyright
CLS
ECHO +===================================================================+
ECHO AutoRun v.%ver% for %mn% Miner - by Acrefawn
ECHO ETH: 0x4a98909270621531dda26de63679c1c6fdcf32ea
ECHO USDT: TDwbaARpdsoD36RpLPSyqxcF3JY8KncajY
ECHO BTC: 1wdJBYkVromPoiYk82JfSGSSVVyFJnenB
EXIT /b
:oclauch
IF DEFINED ocprocessname IF DEFINED ocprocesspath IF %ocprogram% NEQ 0 (
timeout.exe /T 5 /nobreak >NUL
tasklist.exe /FI "IMAGENAME eq %ocprocessname%.exe" 2>NUL| find.exe /I /N "%ocprocessname%.exe" >NUL || (
START "" "%programfiles(x86)%%ocprocesspath%%ocprocessname%.exe" && (
CALL :inform "0" "true" "%ocprocessname%.exe was started." "1" "1"
IF %profile% GEQ 1 IF %profile% LEQ 5 IF %ocprogram% EQU 2 (
ECHO Waiting %octimeout% sec. MSI Afterburner to fully load the profile for each GPU or press any key to continue...
timeout.exe /T %octimeout% >NUL
)
) || (
CALL :inform "1" "false" "Unable to start %ocprocessname%.exe." "1" "1"
SET ocprogram=0
GOTO error
)
)
IF %profile% GEQ 1 IF %profile% LEQ 5 IF %ocprogram% EQU 2 (
IF %secondoclaunch% EQU 1 (
ECHO Waiting %octimeout% sec. MSI Afterburner to fully load the extra profile for each GPU or press any key to continue...
timeout.exe /T %octimeout% >NUL
IF %additionalprofile% GEQ 1 IF %additionalprofile% LEQ 5 "%programfiles(x86)%%ocprocesspath%%ocprocessname%.exe" -Profile%additionalprofile% >NUL && ECHO MSI Afterburner extra profile %additionalprofile% activated.
SET secondoclaunch=0
) ELSE (
timeout.exe /T 5 /nobreak >NUL
"%programfiles(x86)%%ocprocesspath%%ocprocessname%.exe" -Profile%profile% >NUL && ECHO MSI Afterburner profile %profile% activated.
SET secondoclaunch=1
)
)
)
EXIT /b