• Thomas Richter's avatar
    perf test: Fix test trace+probe_libc_inet_pton.sh for s390x · 7a924536
    Thomas Richter authored
    On Intel test case trace+probe_libc_inet_pton.sh succeeds and the
    output is:
    
    [root@f27 perf]# ./perf trace --no-syscalls
                      -e probe_libc:inet_pton/max-stack=3/ ping -6 -c 1 ::1
    PING ::1(::1) 56 data bytes
    64 bytes from ::1: icmp_seq=1 ttl=64 time=0.037 ms
    
     --- ::1 ping statistics ---
    1 packets transmitted, 1 received, 0% packet loss, time 0ms
    rtt min/avg/max/mdev = 0.037/0.037/0.037/0.000 ms
         0.000 probe_libc:inet_pton:(7fa40ac618a0))
                  __GI___inet_pton (/usr/lib64/libc-2.26.so)
                  getaddrinfo (/usr/lib64/libc-2.26.so)
                  main (/usr/bin/ping)
    
    The kernel stack unwinder is used, it is specified implicitly
    as call-graph=fp (frame pointer).
    
    On s390x only dwarf is available for stack unwinding. It is also
    done in user space. This requires different parameter setup
    and result checking for s390x and Intel.
    
    This patch adds separate perf trace setup and result checking
    for Intel and s390x. On s390x specify this command line to
    get a call-graph and handle the different call graph result
    checking:
    
    [root@s35lp76 perf]# ./perf trace --no-syscalls
    	-e probe_libc:inet_pton/call-graph=dwarf/ ping -6 -c 1 ::1
    PING ::1(::1) 56 data bytes
    64 bytes from ::1: icmp_seq=1 ttl=64 time=0.041 ms
    
     --- ::1 ping statistics ---
    1 packets transmitted, 1 received, 0% packet loss, time 0ms
    rtt min/avg/max/mdev = 0.041/0.041/0.041/0.000 ms
         0.000 probe_libc:inet_pton:(3ffb9942060))
                __GI___inet_pton (/usr/lib64/libc-2.26.so)
                gaih_inet (inlined)
                __GI_getaddrinfo (inlined)
                main (/usr/bin/ping)
                __libc_start_main (/usr/lib64/libc-2.26.so)
                _start (/usr/bin/ping)
    [root@s35lp76 perf]#
    
    Before:
    [root@s8360047 perf]# ./perf test -vv 58
    58: probe libc's inet_pton & backtrace it with ping       :
     --- start ---
    test child forked, pid 26349
    PING ::1(::1) 56 data bytes
    64 bytes from ::1: icmp_seq=1 ttl=64 time=0.079 ms
     --- ::1 ping statistics ---
    1 packets transmitted, 1 received, 0% packet loss, time 0ms
    rtt min/avg/max/mdev = 0.079/0.079/0.079/0.000 ms
    0.000 probe_libc:inet_pton:(3ff925c2060))
    test child finished with -1
     ---- end ----
    probe libc's inet_pton & backtrace it with ping: FAILED!
    [root@s8360047 perf]#
    
    After:
    [root@s35lp76 perf]# ./perf test -vv 57
    57: probe libc's inet_pton & backtrace it with ping       :
     --- start ---
    test child forked, pid 38708
    PING ::1(::1) 56 data bytes
    64 bytes from ::1: icmp_seq=1 ttl=64 time=0.038 ms
     --- ::1 ping statistics ---
    1 packets transmitted, 1 received, 0% packet loss, time 0ms
    rtt min/avg/max/mdev = 0.038/0.038/0.038/0.000 ms
    0.000 probe_libc:inet_pton:(3ff87342060))
    __GI___inet_pton (/usr/lib64/libc-2.26.so)
    gaih_inet (inlined)
    __GI_getaddrinfo (inlined)
    main (/usr/bin/ping)
    __libc_start_main (/usr/lib64/libc-2.26.so)
    _start (/usr/bin/ping)
    test child finished with 0
     ---- end ----
    probe libc's inet_pton & backtrace it with ping: Ok
    [root@s35lp76 perf]#
    
    On Intel the test case runs unchanged and succeeds.
    Signed-off-by: default avatarThomas Richter <tmricht@linux.vnet.ibm.com>
    Reviewed-by: default avatarHendrik Brueckner <brueckner@linux.vnet.ibm.com>
    Tested-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
    Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
    Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
    Link: http://lkml.kernel.org/r/20180117083831.101001-1-tmricht@linux.vnet.ibm.comSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
    7a924536
trace+probe_libc_inet_pton.sh 1.96 KB