[Pdbg] [PATCH 06/10] thread.c: threadstatus improve output and implement P9 stop
Nicholas Piggin
npiggin at gmail.com
Tue May 1 22:00:41 AEST 2018
There's no point compressing status down to a single letter. Add
letters for each mode we are intereted in. Add the P9 stop state.
Signed-off-by: Nicholas Piggin <npiggin at gmail.com>
---
src/thread.c | 102 +++++++++++++++++++++++++++++++--------------------
1 file changed, 63 insertions(+), 39 deletions(-)
diff --git a/src/thread.c b/src/thread.c
index a5fff33..67ce281 100644
--- a/src/thread.c
+++ b/src/thread.c
@@ -27,60 +27,84 @@
static int print_thread_status(struct pdbg_target *target, uint32_t index, uint64_t *status, uint64_t *unused1)
{
- *status = SETFIELD(0xffULL << (index * 8), *status, thread_status(target) & 0xffULL);
+ status[index] = thread_status(target);
return 1;
}
-static int print_core_thread_status(struct pdbg_target *core_target, uint32_t index, uint64_t *unused, uint64_t *unused1)
+static int print_core_thread_status(struct pdbg_target *core_target, uint32_t index, uint64_t *maxindex, uint64_t *unused1)
{
- uint64_t status = -1UL;
+ uint64_t status[8];
int i, rc;
- printf("c%02d:", index);
- rc = for_each_child_target("thread", core_target, print_thread_status, &status, NULL);
- for (i = 0; i < 8; i++) {
- switch ((status >> (i * 8)) & 0xf) {
- case THREAD_STATUS_ACTIVE:
- printf(" A");
- break;
-
- case THREAD_STATUS_DOZE:
- case THREAD_STATUS_QUIESCE | THREAD_STATUS_DOZE:
- printf(" D");
- break;
-
- case THREAD_STATUS_NAP:
- case THREAD_STATUS_QUIESCE | THREAD_STATUS_NAP:
- printf(" N");
- break;
-
- case THREAD_STATUS_SLEEP:
- case THREAD_STATUS_QUIESCE | THREAD_STATUS_SLEEP:
- printf(" S");
- break;
-
- case THREAD_STATUS_ACTIVE | THREAD_STATUS_QUIESCE:
- printf(" Q");
- break;
-
- case 0xf:
- printf(" ");
- break;
-
- default:
- printf(" U");
- break;
+ memset(status, 0xff, sizeof(status));
+
+ printf("c%02d: ", index);
+ rc = for_each_child_target("thread", core_target, print_thread_status, &status[0], NULL);
+ for (i = 0; i <= *maxindex; i++) {
+ if (status[i] == -1ULL) {
+ printf(" ");
+ continue;
+ }
+ if (status[i] & ~(THREAD_STATUS_ACTIVE|THREAD_STATUS_DOZE|
+ THREAD_STATUS_NAP|THREAD_STATUS_SLEEP|
+ THREAD_STATUS_STOP|THREAD_STATUS_QUIESCE)) {
+ printf("%llx ", status[i]);
+ continue;
}
+
+ if (status[i] & THREAD_STATUS_ACTIVE)
+ printf("A");
+ else
+ printf(".");
+
+ if (status[i] & THREAD_STATUS_DOZE)
+ printf("D");
+ else if (status[i] & THREAD_STATUS_NAP)
+ printf("N");
+ else if (status[i] & THREAD_STATUS_SLEEP)
+ printf("S");
+ else if (status[i] & THREAD_STATUS_STOP)
+ printf("S");
+ else
+ printf(".");
+
+ if (status[i] & THREAD_STATUS_QUIESCE)
+ printf("Q");
+ else
+ printf(".");
+ printf(" ");
+
}
printf("\n");
return rc;
}
+static int get_thread_max_index(struct pdbg_target *target, uint32_t index, uint64_t *maxindex, uint64_t *unused)
+{
+ if (index > *maxindex)
+ *maxindex = index;
+ return 1;
+}
+
+static int get_core_max_threads(struct pdbg_target *core_target, uint32_t index, uint64_t *maxindex, uint64_t *unused1)
+{
+ return for_each_child_target("thread", core_target, get_thread_max_index, maxindex, NULL);
+}
+
static int print_proc_thread_status(struct pdbg_target *pib_target, uint32_t index, uint64_t *unused, uint64_t *unused1)
{
- printf("\np%01dt: 0 1 2 3 4 5 6 7\n", index);
- return for_each_child_target("core", pib_target, print_core_thread_status, NULL, NULL);
+ int i;
+ uint64_t maxindex = 0;
+
+ for_each_child_target("core", pib_target, get_core_max_threads, &maxindex, NULL);
+
+ printf("\np%01dt:", index);
+ for (i = 0; i <= maxindex; i++)
+ printf(" %d", i);
+ printf("\n");
+
+ return for_each_child_target("core", pib_target, print_core_thread_status, &maxindex, NULL);
};
static int start_thread(struct pdbg_target *thread_target, uint32_t index, uint64_t *unused, uint64_t *unused1)
--
2.17.0
More information about the Pdbg
mailing list