#define NUM_COUNTERS_NB                4
 #define NUM_COUNTERS_L2                4
 #define NUM_COUNTERS_L3                6
+#define NUM_COUNTERS_MAX       64
 
 #define RDPMC_BASE_NB          6
 #define RDPMC_BASE_LLC         10
        int refcnt;
        int cpu;
        struct perf_event **events;
+       unsigned long active_mask[BITS_TO_LONGS(NUM_COUNTERS_MAX)];
+       int nr_active;
+       struct hrtimer hrtimer;
+       u64 hrtimer_duration;
 };
 
 struct amd_uncore_pmu {
        return container_of(event->pmu, struct amd_uncore_pmu, pmu);
 }
 
+static enum hrtimer_restart amd_uncore_hrtimer(struct hrtimer *hrtimer)
+{
+       struct amd_uncore_ctx *ctx;
+       struct perf_event *event;
+       int bit;
+
+       ctx = container_of(hrtimer, struct amd_uncore_ctx, hrtimer);
+
+       if (!ctx->nr_active || ctx->cpu != smp_processor_id())
+               return HRTIMER_NORESTART;
+
+       for_each_set_bit(bit, ctx->active_mask, NUM_COUNTERS_MAX) {
+               event = ctx->events[bit];
+               event->pmu->read(event);
+       }
+
+       hrtimer_forward_now(hrtimer, ns_to_ktime(ctx->hrtimer_duration));
+       return HRTIMER_RESTART;
+}
+
+static void amd_uncore_start_hrtimer(struct amd_uncore_ctx *ctx)
+{
+       hrtimer_start(&ctx->hrtimer, ns_to_ktime(ctx->hrtimer_duration),
+                     HRTIMER_MODE_REL_PINNED_HARD);
+}
+
+static void amd_uncore_cancel_hrtimer(struct amd_uncore_ctx *ctx)
+{
+       hrtimer_cancel(&ctx->hrtimer);
+}
+
+static void amd_uncore_init_hrtimer(struct amd_uncore_ctx *ctx)
+{
+       hrtimer_setup(&ctx->hrtimer, amd_uncore_hrtimer, CLOCK_MONOTONIC, HRTIMER_MODE_REL_HARD);
+}
+
 static void amd_uncore_read(struct perf_event *event)
 {
        struct hw_perf_event *hwc = &event->hw;
 
 static void amd_uncore_start(struct perf_event *event, int flags)
 {
+       struct amd_uncore_pmu *pmu = event_to_amd_uncore_pmu(event);
+       struct amd_uncore_ctx *ctx = *per_cpu_ptr(pmu->ctx, event->cpu);
        struct hw_perf_event *hwc = &event->hw;
 
+       if (!ctx->nr_active++)
+               amd_uncore_start_hrtimer(ctx);
+
        if (flags & PERF_EF_RELOAD)
                wrmsrl(hwc->event_base, (u64)local64_read(&hwc->prev_count));
 
        hwc->state = 0;
+       __set_bit(hwc->idx, ctx->active_mask);
        wrmsrl(hwc->config_base, (hwc->config | ARCH_PERFMON_EVENTSEL_ENABLE));
        perf_event_update_userpage(event);
 }
 
 static void amd_uncore_stop(struct perf_event *event, int flags)
 {
+       struct amd_uncore_pmu *pmu = event_to_amd_uncore_pmu(event);
+       struct amd_uncore_ctx *ctx = *per_cpu_ptr(pmu->ctx, event->cpu);
        struct hw_perf_event *hwc = &event->hw;
 
        wrmsrl(hwc->config_base, hwc->config);
                event->pmu->read(event);
                hwc->state |= PERF_HES_UPTODATE;
        }
+
+       if (!--ctx->nr_active)
+               amd_uncore_cancel_hrtimer(ctx);
+
+       __clear_bit(hwc->idx, ctx->active_mask);
 }
 
 static int amd_uncore_add(struct perf_event *event, int flags)
                                goto fail;
                        }
 
+                       amd_uncore_init_hrtimer(curr);
+                       curr->hrtimer_duration = 60LL * NSEC_PER_SEC;
+
                        cpumask_set_cpu(cpu, &pmu->active_mask);
                }
 
 
 static void amd_uncore_umc_start(struct perf_event *event, int flags)
 {
+       struct amd_uncore_pmu *pmu = event_to_amd_uncore_pmu(event);
+       struct amd_uncore_ctx *ctx = *per_cpu_ptr(pmu->ctx, event->cpu);
        struct hw_perf_event *hwc = &event->hw;
 
+       if (!ctx->nr_active++)
+               amd_uncore_start_hrtimer(ctx);
+
        if (flags & PERF_EF_RELOAD)
                wrmsrl(hwc->event_base, (u64)local64_read(&hwc->prev_count));
 
        hwc->state = 0;
+       __set_bit(hwc->idx, ctx->active_mask);
        wrmsrl(hwc->config_base, (hwc->config | AMD64_PERFMON_V2_ENABLE_UMC));
        perf_event_update_userpage(event);
 }