Skip to content

Commit bd3fd45

Browse files
committed
Merge branch 'locking-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull locking fixes from Ingo Molnar: "Two lockless_dereference() related fixes" * 'locking-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: locking/barriers: Suppress sparse warnings in lockless_dereference() Revert "drm/fb-helper: Reduce READ_ONCE(master) to lockless_dereference"
2 parents f28535c + 112dc0c commit bd3fd45

File tree

2 files changed

+4
-4
lines changed

2 files changed

+4
-4
lines changed

drivers/gpu/drm/drm_fb_helper.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -464,7 +464,7 @@ static bool drm_fb_helper_is_bound(struct drm_fb_helper *fb_helper)
464464

465465
/* Sometimes user space wants everything disabled, so don't steal the
466466
* display if there's a master. */
467-
if (lockless_dereference(dev->master))
467+
if (READ_ONCE(dev->master))
468468
return false;
469469

470470
drm_for_each_crtc(crtc, dev) {

include/linux/compiler.h

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -527,13 +527,13 @@ static __always_inline void __write_once_size(volatile void *p, void *res, int s
527527
* object's lifetime is managed by something other than RCU. That
528528
* "something other" might be reference counting or simple immortality.
529529
*
530-
* The seemingly unused void * variable is to validate @p is indeed a pointer
531-
* type. All pointer types silently cast to void *.
530+
* The seemingly unused size_t variable is to validate @p is indeed a pointer
531+
* type by making sure it can be dereferenced.
532532
*/
533533
#define lockless_dereference(p) \
534534
({ \
535535
typeof(p) _________p1 = READ_ONCE(p); \
536-
__maybe_unused const void * const _________p2 = _________p1; \
536+
size_t __maybe_unused __size_of_ptr = sizeof(*(p)); \
537537
smp_read_barrier_depends(); /* Dependency order vs. p above. */ \
538538
(_________p1); \
539539
})

0 commit comments

Comments
 (0)