From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from [140.186.70.92] (port=34891 helo=eggs.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1OBW1h-0003nC-OK for qemu-devel@nongnu.org; Mon, 10 May 2010 12:40:22 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.69) (envelope-from ) id 1OBW1c-0006P7-JE for qemu-devel@nongnu.org; Mon, 10 May 2010 12:40:17 -0400 Received: from mx1.redhat.com ([209.132.183.28]:56617) by eggs.gnu.org with esmtp (Exim 4.69) (envelope-from ) id 1OBW1c-0006Oi-Bm for qemu-devel@nongnu.org; Mon, 10 May 2010 12:40:12 -0400 Message-ID: <4BE836E5.9070106@redhat.com> Date: Mon, 10 May 2010 19:40:05 +0300 From: Avi Kivity MIME-Version: 1.0 References: <1271872408-22842-1-git-send-email-cam@cs.ualberta.ca> <1271872408-22842-2-git-send-email-cam@cs.ualberta.ca> <1271872408-22842-3-git-send-email-cam@cs.ualberta.ca> <1271872408-22842-4-git-send-email-cam@cs.ualberta.ca> <1271872408-22842-5-git-send-email-cam@cs.ualberta.ca> <4BE7F517.5010707@redhat.com> <4BE82623.4000905@redhat.com> In-Reply-To: Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Subject: [Qemu-devel] Re: [PATCH v5 4/5] Inter-VM shared memory PCI device List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Cam Macdonell Cc: qemu-devel@nongnu.org, kvm@vger.kernel.org On 05/10/2010 06:41 PM, Cam Macdonell wrote: > >> What would happen to any data written to the BAR before the the handshake >> completed? I think it would disappear. >> > But, the BAR isn't there until the handshake is completed. Only after > receiving the shared memory fd does my device call pci_register_bar() > in the callback function. So there may be a case with BAR2 (the > shared memory BAR) missing during initialization. FWIW, I haven't > encountered this. > Well, that violates PCI. You can't have a PCI device with no BAR, then have a BAR appear. It may work since the BAR is registered a lot faster than the BIOS is able to peek at it, but it's a race nevertheless. -- error compiling committee.c: too many arguments to function