Re: [kvm-devel] [PATCH 00/10] PV-IO v3

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

 



Rusty Russell wrote:
On Wed, 2007-08-22 at 02:26 -0700, Dor Laor wrote:
Actually while playing with virtio for kvm Avi saw that and recommended
to do the following:
struct desc_pages
{
	/* Page of descriptors. */
	union {
		struct virtio_desc desc[NUM_DESCS];
		char pad1[PAGE_SIZE];
	};

	/* Next page: how we tell other side what buffers are available. */
	union {
		struct {
			unsigned int avail_idx;
			unsigned int available[NUM_DESCS];
		};
		char pad2[PAGE_SIZE];
	};

	/* Third page: how other side tells us what's used. */
	union {
		struct {
			unsigned int used_idx;
			struct virtio_used used[NUM_DESCS];
		};
		char pad3[PAGE_SIZE];
	};
};

It saves useless pointer arithmetic.

Hi Dor!

Please consider moving the "used" field into the descriptor (maybe as a
ptr for cache reasons, 'cept I'd really like to trim descriptor size).
That makes the avail and used rings identical, plus the current model
means we can't trust the used length if we don't trust the other side
(this is one of my FIXMEs).

Of course, we could go further and break the fixed structure: there's no
reason for the first and second part to be on separate pages, nor for
the third to be consecutive.  But there is no need until be have an
untrusted demonstration...


Another thing that occurs to me is that alignment should be explicit to 64 bits, so that mixed 32/64 bit guest/hosts can be used.


--
error compiling committee.c: too many arguments to function

_______________________________________________
Virtualization mailing list
Virtualization@xxxxxxxxxxxxxxxxxxxxxxxxxx
https://lists.linux-foundation.org/mailman/listinfo/virtualization

[Index of Archives]     [KVM Development]     [Libvirt Development]     [Libvirt Users]     [CentOS Virtualization]     [Netdev]     [Ethernet Bridging]     [Linux Wireless]     [Kernel Newbies]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite Forum]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]

  Powered by Linux