mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-10-26 11:39:30 +00:00 
			
		
		
		
	esp_pm: esp_pm_dump_locks: don't print from a critical section
This commit is contained in:
		| @@ -173,26 +173,35 @@ esp_err_t esp_pm_dump_locks(FILE* stream) | ||||
|  | ||||
|     fprintf(stream, "Lock stats:\n"); | ||||
|     esp_pm_lock_t* it; | ||||
|     char line[64]; | ||||
|     SLIST_FOREACH(it, &s_list, next) { | ||||
|         char *buf = line; | ||||
|         size_t len = sizeof(line) - 1; | ||||
|         line[len] = 0; | ||||
|         size_t cb; | ||||
|  | ||||
|         portENTER_CRITICAL(&it->spinlock); | ||||
|         if (it->name == NULL) { | ||||
|             fprintf(stream, "lock@%p ", it); | ||||
|             cb = snprintf(buf, len, "lock@%p ", it); | ||||
|         } else { | ||||
|             fprintf(stream, "%-15s ", it->name); | ||||
|             cb = snprintf(buf, len, "%-15s ", it->name); | ||||
|         } | ||||
|         buf += cb; | ||||
|         len -= cb; | ||||
| #ifdef WITH_PROFILING | ||||
|         pm_time_t time_held = it->time_held; | ||||
|         if (it->count > 0) { | ||||
|             time_held += cur_time - it->last_taken; | ||||
|         } | ||||
|         fprintf(stream, "%10s  %3d  %3d  %9d  %9lld  %3lld%%\n", | ||||
|         snprintf(buf, len, "%10s  %3d  %3d  %9d  %9lld  %3lld%%\n", | ||||
|                 s_lock_type_names[it->type], it->arg, | ||||
|                 it->count, it->times_taken, time_held, | ||||
|                 (time_held + cur_time_d100 - 1) / cur_time_d100); | ||||
| #else | ||||
|         fprintf(stream, "%10s  %3d  %3d\n", s_lock_type_names[it->type], it->arg, it->count); | ||||
|         snprintf(buf, len, "%10s  %3d  %3d\n", s_lock_type_names[it->type], it->arg, it->count); | ||||
| #endif // WITH_PROFILING | ||||
|         portEXIT_CRITICAL(&it->spinlock); | ||||
|         fputs(line, stream); | ||||
|     } | ||||
|     _lock_release(&s_list_lock); | ||||
| #ifdef WITH_PROFILING | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Ivan Grokhotkov
					Ivan Grokhotkov