Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

cherry-pick: Protect read-only bits of syscfg #91

Conversation

quic-mathbern
Copy link

No description provided.

stefanhaRH and others added 4 commits July 15, 2024 14:35
The Big QEMU Lock (BQL) has many names and they are confusing. The
actual QemuMutex variable is called qemu_global_mutex but it's commonly
referred to as the BQL in discussions and some code comments. The
locking APIs, however, are called qemu_mutex_lock_iothread() and
qemu_mutex_unlock_iothread().

The "iothread" name is historic and comes from when the main thread was
split into into KVM vcpu threads and the "iothread" (now called the main
loop thread). I have contributed to the confusion myself by introducing
a separate --object iothread, a separate concept unrelated to the BQL.

The "iothread" name is no longer appropriate for the BQL. Rename the
locking APIs to:
- void bql_lock(void)
- void bql_unlock(void)
- bool bql_locked(void)

There are more APIs with "iothread" in their names. Subsequent patches
will rename them. There are also comments and documentation that will be
updated in later patches.

Signed-off-by: Stefan Hajnoczi <[email protected]>
Reviewed-by: Paul Durrant <[email protected]>
Acked-by: Fabiano Rosas <[email protected]>
Acked-by: David Woodhouse <[email protected]>
Reviewed-by: Cédric Le Goater <[email protected]>
Acked-by: Peter Xu <[email protected]>
Acked-by: Eric Farman <[email protected]>
Reviewed-by: Harsh Prateek Bora <[email protected]>
Acked-by: Hyman Huang <[email protected]>
Reviewed-by: Akihiko Odaki <[email protected]>
Message-id: [email protected]
Signed-off-by: Stefan Hajnoczi <[email protected]>
The name "iothread" is overloaded. Use the term Big QEMU Lock (BQL)
instead, it is already widely used and unambiguous.

Signed-off-by: Stefan Hajnoczi <[email protected]>
Reviewed-by: Paul Durrant <[email protected]>
Acked-by: David Woodhouse <[email protected]>
Reviewed-by: Cédric Le Goater <[email protected]>
Acked-by: Ilya Leoshkevich <[email protected]>
Reviewed-by: Harsh Prateek Bora <[email protected]>
Reviewed-by: Akihiko Odaki <[email protected]>
Message-id: [email protected]
Signed-off-by: Stefan Hajnoczi <[email protected]>
This lock is scope-bound - so we will avoid errors when adding new early
return statements.

BQL_LOCK_GUARD is an architecture-independent QEMU idiom to replace the
hexagon-specific {UN,}LOCK_IOTHREAD().  The hexagon-specific macro was
a pseudo-nested lock but we don't seem to need that flexibility if we
move the lock acquisition up to a consistent place high enough in the
call stack.

Signed-off-by: Brian Cain <[email protected]>
Users may do a read-modify-write to update syscfg.  Between
the read of the original value of syscfg and the write of the new value
another thread may do a k0lock/unlock or tlblock/unlock changing read-only
bits k0 or tk.

This patch protects those bits from being lost during the read-modify-write
sequence.

Signed-off-by: Sid Manning <[email protected]>
@quic-mathbern quic-mathbern merged commit 7d9f56d into hexagon_sysemu_20_dec_2023 Jul 15, 2024
1 check passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants