From 5bd7cb3944b4164759579c3a090ba2a7d6b34906 Mon Sep 17 00:00:00 2001 From: Erik Olof Gunnar Andersson Date: Thu, 14 Nov 2024 23:26:18 +0100 Subject: [PATCH 1/3] Initial clean create work --- main/tasks/create_jobs_task.c | 94 +++++++---------------------------- 1 file changed, 18 insertions(+), 76 deletions(-) diff --git a/main/tasks/create_jobs_task.c b/main/tasks/create_jobs_task.c index 498947563..020341af6 100644 --- a/main/tasks/create_jobs_task.c +++ b/main/tasks/create_jobs_task.c @@ -11,12 +11,11 @@ static const char *TAG = "create_jobs_task"; #define MAX_EXTRANONCE_2 UINT_MAX -#define TASK_YIELD_THRESHOLD 1000 // Yield after this many iterations +#define TASK_YIELD_THRESHOLD 100 // Yield after this many iterations #define QUEUE_LOW_WATER_MARK 10 // Adjust based on your requirements -static void process_mining_job(GlobalState *GLOBAL_STATE, mining_notify *notification); static bool should_generate_more_work(GlobalState *GLOBAL_STATE); -static void generate_additional_work(GlobalState *GLOBAL_STATE, mining_notify *notification); +static void generate_work(GlobalState *GLOBAL_STATE, mining_notify *notification, uint32_t extranonce_2); void create_jobs_task(void *pvParameters) { @@ -35,30 +34,29 @@ void create_jobs_task(void *pvParameters) (GLOBAL_STATE->ASIC_functions.set_version_mask)(GLOBAL_STATE->version_mask); GLOBAL_STATE->new_stratum_version_rolling_msg = false; } - ESP_LOGI(TAG, "New Work Dequeued %s", mining_notification->job_id); - - // Process this job immediately - process_mining_job(GLOBAL_STATE, mining_notification); - // Now wait for more work or process additional jobs if needed - uint32_t iteration_count = 0; + ESP_LOGI(TAG, "New Work Dequeued %s", mining_notification->job_id); + uint32_t extranonce_2 = 0; while (GLOBAL_STATE->stratum_queue.count < 1 && GLOBAL_STATE->abandon_work == 0) { - // Check if we need to generate more work based on the current job if (should_generate_more_work(GLOBAL_STATE)) { - generate_additional_work(GLOBAL_STATE, mining_notification); + generate_work(GLOBAL_STATE, mining_notification, extranonce_2); + + // Increase extranonce_2 for the next job. + extranonce_2++; + + if (extranonce_2 % TASK_YIELD_THRESHOLD == 0) { + vTaskDelay(1); // Minimal delay, just to yield + } + if (extranonce_2 >= MAX_EXTRANONCE_2) { + extranonce_2 = 0; // Reset to 0 if we've reached the maximum + } } else { - // If no more work needed, wait a bit before checking again - vTaskDelay(pdMS_TO_TICKS(100)); - } - - // Yield periodically to prevent starving other tasks - if (++iteration_count >= TASK_YIELD_THRESHOLD) { - iteration_count = 0; - vTaskDelay(1); // Minimal delay, just to yield + // If no more work needed, wait a bit before checking again. + vTaskDelay(100 / portTICK_PERIOD_MS); } } @@ -73,62 +71,13 @@ void create_jobs_task(void *pvParameters) } } -static void process_mining_job(GlobalState *GLOBAL_STATE, mining_notify *notification) -{ - char *extranonce_2_str = extranonce_2_generate(0, GLOBAL_STATE->extranonce_2_len); - if (extranonce_2_str == NULL) { - ESP_LOGE(TAG, "Failed to generate extranonce_2"); - return; - } - - char *coinbase_tx = construct_coinbase_tx(notification->coinbase_1, notification->coinbase_2, GLOBAL_STATE->extranonce_str, extranonce_2_str); - if (coinbase_tx == NULL) { - ESP_LOGE(TAG, "Failed to construct coinbase_tx"); - free(extranonce_2_str); - return; - } - - char *merkle_root = calculate_merkle_root_hash(coinbase_tx, (uint8_t(*)[32])notification->merkle_branches, notification->n_merkle_branches); - if (merkle_root == NULL) { - ESP_LOGE(TAG, "Failed to calculate merkle_root"); - free(extranonce_2_str); - free(coinbase_tx); - return; - } - - bm_job next_job = construct_bm_job(notification, merkle_root, GLOBAL_STATE->version_mask); - - bm_job *queued_next_job = heap_caps_malloc(sizeof(bm_job), MALLOC_CAP_SPIRAM); - if (queued_next_job == NULL) { - ESP_LOGE(TAG, "Failed to allocate memory for queued_next_job"); - free(extranonce_2_str); - free(coinbase_tx); - free(merkle_root); - return; - } - - memcpy(queued_next_job, &next_job, sizeof(bm_job)); - queued_next_job->extranonce2 = extranonce_2_str; // Transfer ownership - queued_next_job->jobid = strdup(notification->job_id); - queued_next_job->version_mask = GLOBAL_STATE->version_mask; - - queue_enqueue(&GLOBAL_STATE->ASIC_jobs_queue, queued_next_job); - - free(coinbase_tx); - free(merkle_root); - - ESP_LOGI(TAG, "Job processed and queued: %s", notification->job_id); -} - static bool should_generate_more_work(GlobalState *GLOBAL_STATE) { return GLOBAL_STATE->ASIC_jobs_queue.count < QUEUE_LOW_WATER_MARK; } -static void generate_additional_work(GlobalState *GLOBAL_STATE, mining_notify *notification) +static void generate_work(GlobalState *GLOBAL_STATE, mining_notify *notification, uint32_t extranonce_2) { - static uint32_t extranonce_2 = 1; // Start from 1 as 0 was used in the initial job - char *extranonce_2_str = extranonce_2_generate(extranonce_2, GLOBAL_STATE->extranonce_2_len); if (extranonce_2_str == NULL) { ESP_LOGE(TAG, "Failed to generate extranonce_2"); @@ -170,11 +119,4 @@ static void generate_additional_work(GlobalState *GLOBAL_STATE, mining_notify *n free(coinbase_tx); free(merkle_root); - - extranonce_2++; - if (extranonce_2 >= MAX_EXTRANONCE_2) { - extranonce_2 = 1; // Reset to 1 if we've reached the maximum - } - // Logging could cause websocket to crash use with caution - //ESP_LOGI(TAG, "Additional job generated and queued: %s (Extranonce2: %lu)", notification->job_id, (extranonce_2 - 1)); } \ No newline at end of file From 522689b25a4d3ba1afacc2d17b5e2abf5503e4c4 Mon Sep 17 00:00:00 2001 From: Erik Olof Gunnar Andersson Date: Fri, 15 Nov 2024 00:01:24 +0100 Subject: [PATCH 2/3] Updated based on PR feedback --- main/tasks/create_jobs_task.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/main/tasks/create_jobs_task.c b/main/tasks/create_jobs_task.c index 020341af6..12e3e322f 100644 --- a/main/tasks/create_jobs_task.c +++ b/main/tasks/create_jobs_task.c @@ -47,7 +47,7 @@ void create_jobs_task(void *pvParameters) extranonce_2++; if (extranonce_2 % TASK_YIELD_THRESHOLD == 0) { - vTaskDelay(1); // Minimal delay, just to yield + taskYIELD(); } if (extranonce_2 >= MAX_EXTRANONCE_2) { extranonce_2 = 0; // Reset to 0 if we've reached the maximum From 634bca4ea2422d3f739f5b49b51b7b0c177bd9ae Mon Sep 17 00:00:00 2001 From: Erik Olof Gunnar Andersson Date: Thu, 28 Nov 2024 18:47:42 +0100 Subject: [PATCH 3/3] More cleanup based on PR feedback --- main/tasks/create_jobs_task.c | 15 ++++----------- 1 file changed, 4 insertions(+), 11 deletions(-) diff --git a/main/tasks/create_jobs_task.c b/main/tasks/create_jobs_task.c index 12e3e322f..d37afe1b1 100644 --- a/main/tasks/create_jobs_task.c +++ b/main/tasks/create_jobs_task.c @@ -10,8 +10,6 @@ static const char *TAG = "create_jobs_task"; -#define MAX_EXTRANONCE_2 UINT_MAX -#define TASK_YIELD_THRESHOLD 100 // Yield after this many iterations #define QUEUE_LOW_WATER_MARK 10 // Adjust based on your requirements static bool should_generate_more_work(GlobalState *GLOBAL_STATE); @@ -26,16 +24,18 @@ void create_jobs_task(void *pvParameters) mining_notify *mining_notification = (mining_notify *)queue_dequeue(&GLOBAL_STATE->stratum_queue); if (mining_notification == NULL) { ESP_LOGE(TAG, "Failed to dequeue mining notification"); - vTaskDelay(pdMS_TO_TICKS(100)); // Wait a bit before trying again + vTaskDelay(100 / portTICK_PERIOD_MS); // Wait a bit before trying again continue; } + + ESP_LOGI(TAG, "New Work Dequeued %s", mining_notification->job_id); + if (GLOBAL_STATE->new_stratum_version_rolling_msg) { ESP_LOGI(TAG, "Set chip version rolls %i", (int)(GLOBAL_STATE->version_mask >> 13)); (GLOBAL_STATE->ASIC_functions.set_version_mask)(GLOBAL_STATE->version_mask); GLOBAL_STATE->new_stratum_version_rolling_msg = false; } - ESP_LOGI(TAG, "New Work Dequeued %s", mining_notification->job_id); uint32_t extranonce_2 = 0; while (GLOBAL_STATE->stratum_queue.count < 1 && GLOBAL_STATE->abandon_work == 0) { @@ -45,13 +45,6 @@ void create_jobs_task(void *pvParameters) // Increase extranonce_2 for the next job. extranonce_2++; - - if (extranonce_2 % TASK_YIELD_THRESHOLD == 0) { - taskYIELD(); - } - if (extranonce_2 >= MAX_EXTRANONCE_2) { - extranonce_2 = 0; // Reset to 0 if we've reached the maximum - } } else {