Fix two bugs causing lost comm mappings:
 - initial PID is not 0 but getpid()
 - when we are unable to handle an mmap event, dont assume the event
   itself is broken - try to parse the stream. This way we wont lose
   comm events.
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Mike Galbraith <efault@gmx.de>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com>
Cc: Marcelo Tosatti <mtosatti@redhat.com>
Cc: Arnaldo Carvalho de Melo <acme@redhat.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
LKML-Reference: <new-submission>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
        }
 
        if (!system_wide) {
-               open_counters(-1, target_pid != -1 ? target_pid : 0);
+               open_counters(-1, target_pid != -1 ? target_pid : getpid());
        } else for (i = 0; i < nr_cpus; i++)
                open_counters(i, target_pid);
 
 
 
        if (thread == NULL || map == NULL) {
                dprintf("problem processing PERF_EVENT_MMAP, skipping event.\n");
-               return -1;
+               return 0;
        }
 
        thread__insert_map(thread, map);