};
 
 struct bpf_prog_stats {
-       u64 cnt;
-       u64 nsecs;
-       u64 misses;
+       u64_stats_t cnt;
+       u64_stats_t nsecs;
+       u64_stats_t misses;
        struct u64_stats_sync syncp;
 } __aligned(2 * sizeof(u64));
 
                ret = dfunc(ctx, prog->insnsi, prog->bpf_func);
                stats = this_cpu_ptr(prog->stats);
                flags = u64_stats_update_begin_irqsave(&stats->syncp);
-               stats->cnt++;
-               stats->nsecs += sched_clock() - start;
+               u64_stats_inc(&stats->cnt);
+               u64_stats_add(&stats->nsecs, sched_clock() - start);
                u64_stats_update_end_irqrestore(&stats->syncp, flags);
        } else {
                ret = dfunc(ctx, prog->insnsi, prog->bpf_func);
 
        return 0;
 }
 
+struct bpf_prog_kstats {
+       u64 nsecs;
+       u64 cnt;
+       u64 misses;
+};
+
 static void bpf_prog_get_stats(const struct bpf_prog *prog,
-                              struct bpf_prog_stats *stats)
+                              struct bpf_prog_kstats *stats)
 {
        u64 nsecs = 0, cnt = 0, misses = 0;
        int cpu;
                st = per_cpu_ptr(prog->stats, cpu);
                do {
                        start = u64_stats_fetch_begin_irq(&st->syncp);
-                       tnsecs = st->nsecs;
-                       tcnt = st->cnt;
-                       tmisses = st->misses;
+                       tnsecs = u64_stats_read(&st->nsecs);
+                       tcnt = u64_stats_read(&st->cnt);
+                       tmisses = u64_stats_read(&st->misses);
                } while (u64_stats_fetch_retry_irq(&st->syncp, start));
                nsecs += tnsecs;
                cnt += tcnt;
 {
        const struct bpf_prog *prog = filp->private_data;
        char prog_tag[sizeof(prog->tag) * 2 + 1] = { };
-       struct bpf_prog_stats stats;
+       struct bpf_prog_kstats stats;
 
        bpf_prog_get_stats(prog, &stats);
        bin2hex(prog_tag, prog->tag, sizeof(prog->tag));
        struct bpf_prog_info __user *uinfo = u64_to_user_ptr(attr->info.info);
        struct bpf_prog_info info;
        u32 info_len = attr->info.info_len;
-       struct bpf_prog_stats stats;
+       struct bpf_prog_kstats stats;
        char __user *uinsns;
        u32 ulen;
        int err;
 
 
        stats = this_cpu_ptr(prog->stats);
        u64_stats_update_begin(&stats->syncp);
-       stats->misses++;
+       u64_stats_inc(&stats->misses);
        u64_stats_update_end(&stats->syncp);
 }
 
 
                stats = this_cpu_ptr(prog->stats);
                flags = u64_stats_update_begin_irqsave(&stats->syncp);
-               stats->cnt++;
-               stats->nsecs += sched_clock() - start;
+               u64_stats_inc(&stats->cnt);
+               u64_stats_add(&stats->nsecs, sched_clock() - start);
                u64_stats_update_end_irqrestore(&stats->syncp, flags);
        }
 }