diff options
author | Sverker Eriksson <[email protected]> | 2018-11-22 16:02:27 +0100 |
---|---|---|
committer | Sverker Eriksson <[email protected]> | 2018-11-22 16:02:27 +0100 |
commit | 253d146786dc2068de724bb36f61d6d24c4d460b (patch) | |
tree | 81df6b72154b7998c64c6317ab4c64e447cfdf22 /erts/preloaded/src/counters.erl | |
parent | a411b7dedd42cc4cbe160eec3e5aae8027e7833b (diff) | |
parent | fb8018f9ebebbcb5ef074e33514a4c03aaefbe2d (diff) | |
download | otp-253d146786dc2068de724bb36f61d6d24c4d460b.tar.gz otp-253d146786dc2068de724bb36f61d6d24c4d460b.tar.bz2 otp-253d146786dc2068de724bb36f61d6d24c4d460b.zip |
Merge branch 'maint'
Diffstat (limited to 'erts/preloaded/src/counters.erl')
-rw-r--r-- | erts/preloaded/src/counters.erl | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/erts/preloaded/src/counters.erl b/erts/preloaded/src/counters.erl index 67354f648d..a0e3035e0f 100644 --- a/erts/preloaded/src/counters.erl +++ b/erts/preloaded/src/counters.erl @@ -26,6 +26,7 @@ get/2, add/3, sub/3, + put/3, info/1]). -export_type([counters_ref/0]). @@ -76,6 +77,19 @@ add(_, _, _) -> sub(Ref, Ix, Decr) -> add(Ref, Ix, -Decr). + +-spec put(Ref, Ix, Value) -> ok when + Ref :: counters_ref(), + Ix :: integer(), + Value :: integer(). +put({atomics, Ref}, Ix, Value) -> + atomics:put(Ref, Ix, Value); +put({write_concurrency, Ref}, Ix, Value) -> + erts_internal:counters_put(Ref, Ix, Value); +put(_, _, _) -> + erlang:error(badarg). + + -spec info(Ref) -> Info when Ref :: counters_ref(), Info :: #{'size':=Size, 'memory':=Memory}, |