RE: flow control in vmbus ring buffers

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



From: Roman Kagan <rkagan@xxxxxxxxxxxxx> Sent: Tuesday, December 24, 2019 8:29 AM
> 
> On Tue, Dec 24, 2019 at 10:56:08AM +0000, Roman Kagan wrote:
> > I'm trying to get my head around how the flow control in vmbus ring
> > buffers works.
> >
> > In particular, I'm failing to see how the following can be prevented:
> >
> >
> >      producer                     |       consumer
> > ==================================================================
> > read read_index                   |
> > (enough room for packet)          |
> > write pending_send_sz = 0         |
> > write packet                      |
> > update write_index                |
> >                                   | read write_index
> > read read_index                   | read packet
> > (not enough room for packet)      | update read_index (= write_index)
> >                                   | read pending_send_sz = 0
> > write pending_send_sz = X         | skip notification
> > go to sleep                       | go to sleep
> >                                 stall
> >
> > Could anybody please shed some light on how it's supposed to work?
> 
> Sorry to reply to myself, but looks like the answer is to re-read
> read_index on the producer side after setting pending_send_sz.
> 

Are you seeing a problem in the Linux guest code in drivers/hv/ring_buffer.c?
The only time the Linux guest as the producer sets pending_send_sz is in the
hv_socket code.  Or are you looking at the KVM code that does emulation of
Hyper-V, where KVM is acting as the producer?

Just curious as to what prompted your question.  I did the most recent fixes a
couple years ago to the Linux guest code for handling the ring buffer interaction
with Hyper-V, and if there is still a problem, I'm super interested. :-)

Michael




[Index of Archives]     [Linux Samsung SoC]     [Linux Rockchip SoC]     [Linux Actions SoC]     [Linux for Synopsys ARC Processors]     [Linux NFS]     [Linux NILFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]


  Powered by Linux