Avi Kivity wrote:
On 07/28/2009 12:32 AM, Stephen Donnelly wrote:
What I don't understand is how to turn the host address returned from
mmap into a ram_addr_t to pass to pci_register_bar.
Memory must be allocated using the qemu RAM functions.
That seems to be the problem. The memory cannot be allocated by
qemu_ram_alloc, because it is coming from the mmap call. The memory is
already allocated outside the qemu process. mmap can indicate where in
the qemu process address space the local mapping should be, but
mapping it 'on top' of memory allocated with qemu_ram_alloc doesn't
seem to work (I get a BUG in gfn_to_pfn).
You need a variant of qemu_ram_alloc() that accepts an fd and offset and
mmaps that. A less intrusive, but uglier, alternative is to call
qemu_ram_alloc() and them mmap(MAP_FIXED) on top of that.
Hi Avi,
I noticed that the region of memory being allocated for shared memory
using qemu_ram_alloc gets added to the total RAM of the system
(according to /proc/meminfo). I'm wondering if this is normal/OK since
memory for the shared memory device (and similarly VGA RAM) is not
intended to be used as regular RAM.
Should memory of devices be reported as part of MemTotal or is something
wrong in my use of qemu_ram_alloc()?
Thanks,
Cam
--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html