Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

powerpc/powernv/memtrace: Allow mmaping trace buffers

Let the memory removed from the linear mapping to be used for the trace
buffers be mmaped. This is a useful way of providing cache-inhibited
memory for the alignment_handler selftest.

Signed-off-by: Jordan Niethe <jniethe5@gmail.com>
[mpe: make memtrace_mmap() static as noticed by lkp@intel.com]
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/20210225032108.1458352-1-jniethe5@gmail.com

authored by

Jordan Niethe and committed by
Michael Ellerman
08a022ad acd4dfeb

+17 -1
+17 -1
arch/powerpc/platforms/powernv/memtrace.c
··· 46 46 return simple_read_from_buffer(ubuf, count, ppos, ent->mem, ent->size); 47 47 } 48 48 49 + static int memtrace_mmap(struct file *filp, struct vm_area_struct *vma) 50 + { 51 + struct memtrace_entry *ent = filp->private_data; 52 + 53 + if (ent->size < vma->vm_end - vma->vm_start) 54 + return -EINVAL; 55 + 56 + if (vma->vm_pgoff << PAGE_SHIFT >= ent->size) 57 + return -EINVAL; 58 + 59 + vma->vm_page_prot = pgprot_noncached(vma->vm_page_prot); 60 + return remap_pfn_range(vma, vma->vm_start, PHYS_PFN(ent->start) + vma->vm_pgoff, 61 + vma->vm_end - vma->vm_start, vma->vm_page_prot); 62 + } 63 + 49 64 static const struct file_operations memtrace_fops = { 50 65 .llseek = default_llseek, 51 66 .read = memtrace_read, 52 67 .open = simple_open, 68 + .mmap = memtrace_mmap, 53 69 }; 54 70 55 71 #define FLUSH_CHUNK_SIZE SZ_1G ··· 203 187 dir = debugfs_create_dir(ent->name, memtrace_debugfs_dir); 204 188 205 189 ent->dir = dir; 206 - debugfs_create_file("trace", 0400, dir, ent, &memtrace_fops); 190 + debugfs_create_file_unsafe("trace", 0600, dir, ent, &memtrace_fops); 207 191 debugfs_create_x64("start", 0400, dir, &ent->start); 208 192 debugfs_create_x64("size", 0400, dir, &ent->size); 209 193 }