]> Pileus Git - ~andy/linux/blobdiff - lib/average.c
Merge remote-tracking branch 'regulator/fix/core' into regulator-linus
[~andy/linux] / lib / average.c
index 99a67e662b3c6b747e2ccb81f576e8e5ba040b6b..114d1beae0c785a358bf709dd6f9a1e7ee46ce1d 100644 (file)
@@ -53,8 +53,10 @@ EXPORT_SYMBOL(ewma_init);
  */
 struct ewma *ewma_add(struct ewma *avg, unsigned long val)
 {
-       avg->internal = avg->internal  ?
-               (((avg->internal << avg->weight) - avg->internal) +
+       unsigned long internal = ACCESS_ONCE(avg->internal);
+
+       ACCESS_ONCE(avg->internal) = internal ?
+               (((internal << avg->weight) - internal) +
                        (val << avg->factor)) >> avg->weight :
                (val << avg->factor);
        return avg;