|
@@ -71,3 +71,38 @@ return that task_struct variable which PID matches."""
|
|
|
|
|
|
|
|
|
|
LxTaskByPidFunc()
|
|
LxTaskByPidFunc()
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+thread_info_type = utils.CachedType("struct thread_info")
|
|
|
|
+
|
|
|
|
+ia64_task_size = None
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+def get_thread_info(task):
|
|
|
|
+ global thread_info_type
|
|
|
|
+ thread_info_ptr_type = thread_info_type.get_type().pointer()
|
|
|
|
+ if utils.is_target_arch("ia64"):
|
|
|
|
+ global ia64_task_size
|
|
|
|
+ if ia64_task_size is None:
|
|
|
|
+ ia64_task_size = gdb.parse_and_eval("sizeof(struct task_struct)")
|
|
|
|
+ thread_info_addr = task.address + ia64_task_size
|
|
|
|
+ thread_info = thread_info_addr.cast(thread_info_ptr_type)
|
|
|
|
+ else:
|
|
|
|
+ thread_info = task['stack'].cast(thread_info_ptr_type)
|
|
|
|
+ return thread_info.dereference()
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+class LxThreadInfoFunc (gdb.Function):
|
|
|
|
+ """Calculate Linux thread_info from task variable.
|
|
|
|
+
|
|
|
|
+$lx_thread_info(TASK): Given TASK, return the corresponding thread_info
|
|
|
|
+variable."""
|
|
|
|
+
|
|
|
|
+ def __init__(self):
|
|
|
|
+ super(LxThreadInfoFunc, self).__init__("lx_thread_info")
|
|
|
|
+
|
|
|
|
+ def invoke(self, task):
|
|
|
|
+ return get_thread_info(task)
|
|
|
|
+
|
|
|
|
+
|
|
|
|
+LxThreadInfoFunc()
|