Source code for volatility3.plugins.linux.pstree

# This file is Copyright 2019 Volatility Foundation and licensed under the Volatility Software License 1.0
# which is available at https://www.volatilityfoundation.org/license/vsl-v1.0
#

from volatility3.framework.objects import utility
from volatility3.plugins.linux import pslist


[docs]class PsTree(pslist.PsList): """Plugin for listing processes in a tree based on their parent process ID.""" def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) self._processes = {} self._levels = {} self._children = {}
[docs] def find_level(self, pid): """Finds how deep the pid is in the processes list.""" seen = set([]) seen.add(pid) level = 0 proc = self._processes.get(pid, None) while proc is not None and proc.parent != 0 and proc.parent.pid not in seen: ppid = int(proc.parent.pid) child_list = self._children.get(ppid, set([])) child_list.add(proc.pid) self._children[ppid] = child_list proc = self._processes.get(ppid, None) level += 1 self._levels[pid] = level
def _generator(self): """Generates the.""" vmlinux = self.context.modules[self.config['kernel']] for proc in self.list_tasks(self.context, vmlinux.name): self._processes[proc.pid] = proc # Build the child/level maps for pid in self._processes: self.find_level(pid) def yield_processes(pid): proc = self._processes[pid] row = (proc.pid, proc.parent.pid, utility.array_to_string(proc.comm)) yield (self._levels[pid] - 1, row) for child_pid in self._children.get(pid, []): yield from yield_processes(child_pid) for pid in self._levels: if self._levels[pid] == 1: yield from yield_processes(pid)