• Kim Phillips's avatar
    perf annotate: AArch64 support · 0fcb1da4
    Kim Phillips authored
    This is a regex converted version from the original:
    
    	https://lkml.org/lkml/2016/5/19/461
    
    Add basic support to recognise AArch64 assembly. This allows perf to
    identify AArch64 instructions that branch to other parts within the
    same function, thereby properly annotating them.
    
    Rebased onto new cross-arch annotation bits:
    
    	https://lkml.org/lkml/2016/11/25/546
    
    Sample output:
    
    security_file_permission  vmlinux
      5.80 │    ← ret                                                  ▒
           │70:   ldr    w0, [x21,#68]                                 ▒
      4.44 │    ↓ tbnz   d0                                            ▒
           │      mov    w0, #0x24                       // #36        ▒
      1.37 │      ands   w0, w22, w0                                   ▒
           │    ↑ b.eq   60                                            ▒
      1.37 │    ↓ tbnz   e4                                            ▒
           │      mov    w19, #0x20000                   // #131072    ▒
      1.02 │    ↓ tbz    ec                                            ▒
           │90:┌─→ldr    x3, [x21,#24]                                 ▒
      1.37 │   │  add    x21, x21, #0x10                               ▒
           │   │  mov    w2, w19                                       ▒
      1.02 │   │  mov    x0, x21                                       ▒
           │   │  mov    x1, x3                                        ▒
      1.71 │   │  ldr    x20, [x3,#48]                                 ▒
           │   │→ bl     __fsnotify_parent                             ▒
      0.68 │   │↑ cbnz   60                                            ▒
           │   │  mov    x2, x21                                       ▒
      1.37 │   │  mov    w1, w19                                       ▒
           │   │  mov    x0, x20                                       ▒
      0.68 │   │  mov    w5, #0x0                        // #0         ▒
           │   │  mov    x4, #0x0                        // #0         ▒
      1.71 │   │  mov    w3, #0x1                        // #1         ▒
           │   │→ bl     fsnotify                                      ▒
      1.37 │   │↑ b      60                                            ▒
           │d0:│  mov    w0, #0x0                        // #0         ▒
           │   │  ldp    x19, x20, [sp,#16]                            ▒
           │   │  ldp    x21, x22, [sp,#32]                            ▒
           │   │  ldp    x29, x30, [sp],#48                            ▒
           │   │← ret                                                  ▒
           │e4:│  mov    w19, #0x10000                   // #65536     ▒
           │   └──b      90                                            ◆
           │ec:   brk    #0x800                                        ▒
    Press 'h' for help on key bindings
    Signed-off-by: default avatarKim Phillips <kim.phillips@arm.com>
    Signed-off-by: default avatarChris Ryder <chris.ryder@arm.com>
    Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
    Cc: Mark Rutland <mark.rutland@arm.com>
    Cc: Pawel Moll <pawel.moll@arm.com>
    Cc: Peter Zijlstra <peterz@infradead.org>
    Cc: Will Deacon <will.deacon@arm.com>
    Link: http://lkml.kernel.org/r/20161130092344.012e18e3e623bea395162f95@arm.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
    0fcb1da4
instructions.c 1.3 KB