From: John Ogness <[email protected]> Sent: Tuesday, January 26, 2021 
1:16 PM
> 
> In preparation for removing printk's @logbuf_lock, dumpers that have
> assumed to be protected against parallel calls must provide their own
> synchronization. Add a locally static spinlock to synchronize the
> kmsg_dump call.
> 
> Signed-off-by: John Ogness <[email protected]>
> ---
>  drivers/hv/vmbus_drv.c | 12 ++++++++----
>  1 file changed, 8 insertions(+), 4 deletions(-)
> 
> diff --git a/drivers/hv/vmbus_drv.c b/drivers/hv/vmbus_drv.c
> index fbeddef90941..08db95e1a139 100644
> --- a/drivers/hv/vmbus_drv.c
> +++ b/drivers/hv/vmbus_drv.c
> @@ -1362,23 +1362,27 @@ static void hv_kmsg_dump(struct kmsg_dumper *dumper,
>                        enum kmsg_dump_reason reason,
>                        struct kmsg_dumper_iter *iter)
>  {
> +     static DEFINE_SPINLOCK(lock);
>       size_t bytes_written;
>       phys_addr_t panic_pa;
> +     unsigned long flags;
> 
>       /* We are only interested in panics. */
>       if ((reason != KMSG_DUMP_PANIC) || (!sysctl_record_panic_msg))
>               return;
> 
> +     if (!spin_trylock_irqsave(&lock, flags))
> +             return;
> +
>       panic_pa = virt_to_phys(hv_panic_page);
> 
> -     /*
> -      * Write dump contents to the page. No need to synchronize; panic should
> -      * be single-threaded.
> -      */
> +     /* Write dump contents to the page. */
>       kmsg_dump_get_buffer(iter, false, hv_panic_page, HV_HYP_PAGE_SIZE,
>                            &bytes_written);
>       if (bytes_written)
>               hyperv_report_panic_msg(panic_pa, bytes_written);
> +
> +     spin_unlock_irqrestore(&lock, flags);
>  }
> 
>  static struct kmsg_dumper hv_kmsg_dumper = {
> --
> 2.20.1

I don't think this patch is needed.   Per some of the unmodified code
above, and the comment, we proceed to the call to kmsg_dump_get_buffer()
only in the panic path.  Code in the panic path prior to invoking kmsg_dump()
ensures that we are single-threaded on a single CPU.   So I think everything
is good here without the new spin lock.  The subsequent call to
hyperv_report_panic_msg() also assumes that we are single-threaded.

Michael

Reply via email to