Skip to content

Commit

Permalink
Documentation/litmus-tests/atomic: Add a test for atomic_set()
Browse files Browse the repository at this point in the history
We already use a litmus test in atomic_t.txt to describe the behavior of
an atomic_set() with the an atomic RMW, so add it into atomic-tests
directory to make it easily accessible for anyone who cares about the
semantics of our atomic APIs.

Besides currently the litmus test "atomic-set" in atomic_t.txt has a few
things to be improved:

1)	The CPU/Processor numbers "P1,P2" are not only inconsistent with
	the rest of the document, which uses "CPU0" and "CPU1", but also
	unacceptable by the herd tool, which requires processors start
	at "P0".

2)	The initialization block uses a "atomic_set()", which is OK, but
	it's better to use ATOMIC_INIT() to make clear this is an
	initialization.

3)	The return value of atomic_add_unless() is discarded
	inexplicitly, which is OK for C language, but it will be helpful
	to the herd tool if we use a void cast to make the discard
	explicit.

4)	The name and the paragraph describing the test need to be more
	accurate and aligned with our wording in LKMM.

Therefore fix these in both atomic_t.txt and the new added litmus test.

Acked-by: Andrea Parri <[email protected]>
Acked-by: Alan Stern <[email protected]>
Signed-off-by: Boqun Feng <[email protected]>
Reviewed-by: Joel Fernandes (Google) <[email protected]>
Signed-off-by: Paul E. McKenney <[email protected]>
  • Loading branch information
fbq authored and paulmckrcu committed Jun 29, 2020
1 parent efff615 commit 4dcd4d3
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 7 deletions.
14 changes: 7 additions & 7 deletions Documentation/atomic_t.txt
Original file line number Diff line number Diff line change
Expand Up @@ -85,21 +85,21 @@ smp_store_release() respectively. Therefore, if you find yourself only using
the Non-RMW operations of atomic_t, you do not in fact need atomic_t at all
and are doing it wrong.

A subtle detail of atomic_set{}() is that it should be observable to the RMW
ops. That is:
A note for the implementation of atomic_set{}() is that it must not break the
atomicity of the RMW ops. That is:

C atomic-set
C Atomic-RMW-ops-are-atomic-WRT-atomic_set

{
atomic_set(v, 1);
atomic_t v = ATOMIC_INIT(1);
}

P1(atomic_t *v)
P0(atomic_t *v)
{
atomic_add_unless(v, 1, 0);
(void)atomic_add_unless(v, 1, 0);
}

P2(atomic_t *v)
P1(atomic_t *v)
{
atomic_set(v, 0);
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
C Atomic-RMW-ops-are-atomic-WRT-atomic_set

(*
* Result: Never
*
* Test that atomic_set() cannot break the atomicity of atomic RMWs.
*)

{
atomic_t v = ATOMIC_INIT(1);
}

P0(atomic_t *v)
{
(void)atomic_add_unless(v, 1, 0);
}

P1(atomic_t *v)
{
atomic_set(v, 0);
}

exists
(v=2)
7 changes: 7 additions & 0 deletions Documentation/litmus-tests/atomic/README
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,10 @@ This directory contains litmus tests that are typical to describe the semantics
of our atomic APIs. For more information about how to "run" a litmus test or
how to generate a kernel test module based on a litmus test, please see
tools/memory-model/README.

============
LITMUS TESTS
============

Atomic-RMW-ops-are-atomic-WRT-atomic_set.litmus
Test that atomic_set() cannot break the atomicity of atomic RMWs.

0 comments on commit 4dcd4d3

Please sign in to comment.