Bryan D. Payne wrote:
> I''m looking at developing an application to run in dom0 that will
> need a view into the memory of machines in domU. For now it will be
> a read-only view, but I''d like to experiment with read-write
later.
> I''ve done some poking around in the source code and found the
> xc_map_foreign_range function in libxc. From what I could tell, this
> is (at least one way) how to do this. So, a couple of questions:
Yup, this is the right function to use.
> * This function doesn''t seem to be used very much. The only usage
> that I could find was in the XenTrace tool. So I just wanted to
> confirm that this function was still maintained and not getting ready
> to go away with the 3.0 changes.
Yup, it''s critical for both domain creation and save/restore. See
libxc/xc_linux_build.c or libxc/xc_linux_save.c for other examples of use.
> * Is there any reason that this functionality isn''t implemented in
> the lowlevel/xc library in python? Perhaps just because there
isn''t
> as much demand for it? Or is there a deeper implementation issue?
Things that are that low-level are usually performance sensitive (like
migration) so we implement it in C. Plus, I think it''s non-trivial to
expose raw memory to Python (with doing a copy).
> * Are there other ways to view the memory of domU machines?
> Similarly, are there any ways to view items such as CPU registers of
> the domU machines?
No, xc_map_foreign_range is The Way. You can get the register state of
a domU via xc_domain_get_vcpu_context().
> * Given that the type of usage that I have in mind is going to be
> somewhat high bandwidth (i.e., need to constantly read and re-read
> memory on the domU machine(s)), is this function the best way to go?
> Or would you recommend that I look into another way?
xc_map_foreign_range() actually maps the physical page into dom0''s
address space. You''re limited by the virtual address space available
in
dom0 (so you may have to remap portions of the domUs memory into your
window) but there shouldn''t be any performance overhead once
it''s mapped.
Regards,
Anthony Liguori
> Thanks for the help!
>
> -bryan
>
>------------------------------------------------------------------------
>
>_______________________________________________
>Xen-devel mailing list
>Xen-devel@lists.xensource.com
>http://lists.xensource.com/xen-devel
>
>
_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xensource.com
http://lists.xensource.com/xen-devel