Skip to content

Commit 055f2e7

Browse files
authored
Merge pull request #1264 from gcmoreira/linux_lsof_namespace_dentry_name
Linux lsof: Add namespace dentry name
2 parents e094218 + cd2af74 commit 055f2e7

File tree

1 file changed

+49
-6
lines changed

1 file changed

+49
-6
lines changed

volatility3/framework/symbols/linux/__init__.py

Lines changed: 49 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -169,13 +169,30 @@ def _get_new_sock_pipe_path(cls, context, task, filp) -> str:
169169
Returns:
170170
str: Sock pipe pathname relative to the task's root directory.
171171
"""
172+
# FIXME: This function must be moved to the 'dentry' object extension
173+
# Also, the scope of this function went beyond the sock pipe path, so we need to rename this.
174+
# Once https://github.com/volatilityfoundation/volatility3/pull/1263 is merged, replace the
175+
# dentry inode getters
176+
177+
if not (filp and filp.is_readable()):
178+
return f"<invalid file pointer> {filp:x}"
179+
172180
dentry = filp.get_dentry()
181+
if not (dentry and dentry.is_readable()):
182+
return f"<invalid dentry pointer> {dentry:x}"
173183

174184
kernel_module = cls.get_module_from_volobj_type(context, dentry)
175185

176186
sym_addr = dentry.d_op.d_dname
187+
if not (sym_addr and sym_addr.is_readable()):
188+
return f"<invalid d_dname pointer> {sym_addr:x}"
189+
177190
symbs = list(kernel_module.get_symbols_by_absolute_location(sym_addr))
178191

192+
inode = dentry.d_inode
193+
if not (inode and inode.is_readable() and inode.is_valid()):
194+
return f"<invalid dentry inode> {inode:x}"
195+
179196
if len(symbs) == 1:
180197
sym = symbs[0].split(constants.BANG)[1]
181198

@@ -191,15 +208,41 @@ def _get_new_sock_pipe_path(cls, context, task, filp) -> str:
191208
elif sym == "simple_dname":
192209
pre_name = cls._get_path_file(task, filp)
193210

211+
elif sym == "ns_dname":
212+
# From Kernels 3.19
213+
214+
# In Kernels >= 6.9, see Linux kernel commit 1fa08aece42512be072351f482096d5796edf7ca
215+
# ns_common->stashed change from 'atomic64_t' to 'dentry*'
216+
try:
217+
ns_common_type = kernel_module.get_type("ns_common")
218+
stashed_template = ns_common_type.child_template("stashed")
219+
stashed_type_full_name = stashed_template.vol.type_name
220+
stashed_type_name = stashed_type_full_name.split(constants.BANG)[1]
221+
if stashed_type_name == "atomic64_t":
222+
# 3.19 <= Kernels < 6.9
223+
fsdata_ptr = dentry.d_fsdata
224+
if not (fsdata_ptr and fsdata_ptr.is_readable()):
225+
raise IndexError
226+
227+
ns_ops = fsdata_ptr.dereference().cast("proc_ns_operations")
228+
else:
229+
# Kernels >= 6.9
230+
private_ptr = inode.i_private
231+
if not (private_ptr and private_ptr.is_readable()):
232+
raise IndexError
233+
234+
ns_common = private_ptr.dereference().cast("ns_common")
235+
ns_ops = ns_common.ops
236+
237+
pre_name = utility.pointer_to_string(ns_ops.name, 255)
238+
except IndexError:
239+
pre_name = "<unsupported ns_dname implementation>"
194240
else:
195-
pre_name = f"<unsupported d_op symbol: {sym}>"
196-
197-
ret = f"{pre_name}:[{dentry.d_inode.i_ino:d}]"
198-
241+
pre_name = f"<unsupported d_op symbol> {sym}"
199242
else:
200-
ret = f"<invalid d_dname pointer> {sym_addr:x}"
243+
pre_name = f"<unknown d_dname pointer> {sym_addr:x}"
201244

202-
return ret
245+
return f"{pre_name}:[{inode.i_ino:d}]"
203246

204247
@classmethod
205248
def path_for_file(cls, context, task, filp) -> str:

0 commit comments

Comments
 (0)