File: pfaults.stp

package info (click to toggle)
systemtap 2.6-0.2
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 21,220 kB
  • ctags: 10,944
  • sloc: cpp: 53,239; ansic: 50,615; exp: 33,694; sh: 9,906; xml: 7,665; perl: 2,089; python: 1,534; tcl: 1,236; makefile: 797; java: 148; lisp: 104; awk: 94; asm: 91; sed: 16
file content (35 lines) | stat: -rwxr-xr-x 859 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#! /usr/bin/env stap

global fault_entry_time, fault_address, fault_access
global time_offset

probe begin { time_offset = gettimeofday_us() }

probe vm.pagefault {
  t = gettimeofday_us()
  p = pid()
  fault_entry_time[p] = t
  fault_address[p] = address
  fault_access[p] = write_access ? "w" : "r"
}

probe vm.pagefault.return {
  t=gettimeofday_us()
  p = pid()
  if (!(p in fault_entry_time)) next
  e = t - fault_entry_time[p]
  if (vm_fault_contains(fault_type,VM_FAULT_MINOR)) {
    ftype="minor"
  } else if (vm_fault_contains(fault_type,VM_FAULT_MAJOR)) {
    ftype="major"
  } else {
    next #only want to deal with minor and major page faults
  }

  printf("%d:%d:%p:%s:%s:%d\n",
	t - time_offset, p, fault_address[p], fault_access[p], ftype, e)
  #free up memory
  delete fault_entry_time[p]
  delete fault_address[p]
  delete fault_access[p]
}