static int                     inherit                         = 1;
 static int                     force                           = 0;
 static int                     append_file                     = 0;
+static int                     verbose                         = 0;
 
 static long                    samples;
 static struct timeval          last_read;
 
        track = 0; /* only the first counter needs these */
 
+try_again:
        fd[nr_cpu][counter] = sys_perf_counter_open(attr, pid, cpu, group_fd, 0);
 
        if (fd[nr_cpu][counter] < 0) {
                int err = errno;
 
-               error("syscall returned with %d (%s)\n",
+               if (verbose)
+                       error("sys_perf_counter_open() syscall returned with %d (%s)\n",
                                fd[nr_cpu][counter], strerror(err));
                if (err == EPERM)
-                       printf("Are you root?\n");
+                       die("Permission error - are you root?\n");
+
+               /*
+                * If it's cycles then fall back to hrtimer
+                * based cpu-clock-tick sw counter, which
+                * is always available even if no PMU support:
+                */
+               if (attr->type == PERF_TYPE_HARDWARE
+                       && attr->config == PERF_COUNT_CPU_CYCLES) {
+
+                       if (verbose)
+                               warning(" ... trying to fall back to cpu-clock-ticks\n");
+                       attr->type = PERF_TYPE_SOFTWARE;
+                       attr->config = PERF_COUNT_CPU_CLOCK;
+                       goto try_again;
+               }
                exit(-1);
        }
+
        assert(fd[nr_cpu][counter] >= 0);
        fcntl(fd[nr_cpu][counter], F_SETFL, O_NONBLOCK);
 
                    "profile at this frequency"),
        OPT_INTEGER('m', "mmap-pages", &mmap_pages,
                    "number of mmap data pages"),
+       OPT_BOOLEAN('v', "verbose", &verbose,
+                   "be more verbose (show counter open errors, etc)"),
        OPT_END()
 };
 
 
 static unsigned int            page_size;
 static unsigned int            mmap_pages                      = 16;
 static int                     freq                            =  0;
+static int                     verbose                         =  0;
 
 static char                    *sym_filter;
 static unsigned long           filter_start;
        if (fd[i][counter] < 0) {
                int err = errno;
 
-               error("sys_perf_counter_open() syscall returned with %d (%s)\n",
-                       fd[i][counter], strerror(err));
+               if (verbose)
+                       error("sys_perf_counter_open() syscall returned with %d (%s)\n",
+                               fd[i][counter], strerror(err));
 
                if (err == EPERM)
-                       die(" No permission - are you root?\n");
+                       die("No permission - are you root?\n");
                /*
                 * If it's cycles then fall back to hrtimer
                 * based cpu-clock-tick sw counter, which
                if (attr->type == PERF_TYPE_HARDWARE
                        && attr->config == PERF_COUNT_CPU_CYCLES) {
 
-                       warning(" ... trying to fall back to cpu-clock-ticks\n");
+                       if (verbose)
+                               warning(" ... trying to fall back to cpu-clock-ticks\n");
+
                        attr->type = PERF_TYPE_SOFTWARE;
                        attr->config = PERF_COUNT_CPU_CLOCK;
                        goto try_again;
                    "profile at this frequency"),
        OPT_INTEGER('E', "entries", &print_entries,
                    "display this many functions"),
+       OPT_BOOLEAN('v', "verbose", &verbose,
+                   "be more verbose (show counter open errors, etc)"),
        OPT_END()
 };