From: Julien Grall Date: Fri, 30 Jun 2017 15:54:22 +0000 (+0100) Subject: xen/arm: livepatch: Redefine virt_to_mfn to support typesafe X-Git-Tag: archive/raspbian/4.11.1-1+rpi1~1^2~66^2~1857 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=ea29758880779e6f10ba707d9a4b5e8cd5a49b97;p=xen.git xen/arm: livepatch: Redefine virt_to_mfn to support typesafe The file xen/arch/arm/livepatch.c is using typesafe MFN in most of the place. The only caller to virt_to_mfn is using with _mfn(...). To avoid extra _mfn(...), re-define virt_to_mfn within xen/arch/arm/livepatch.c to handle typesafe MFN. Signed-off-by: Julien Grall Reviewed-by: Stefano Stabellini Acked-by: Konrad Rzeszutek Wilk --- diff --git a/xen/arch/arm/livepatch.c b/xen/arch/arm/livepatch.c index de95e54744..3e53524365 100644 --- a/xen/arch/arm/livepatch.c +++ b/xen/arch/arm/livepatch.c @@ -12,6 +12,10 @@ #include #include +/* Override macros from asm/page.h to make them work with mfn_t */ +#undef virt_to_mfn +#define virt_to_mfn(va) _mfn(__virt_to_mfn(va)) + void *vmap_of_xen_text; int arch_livepatch_quiesce(void) @@ -22,7 +26,7 @@ int arch_livepatch_quiesce(void) if ( vmap_of_xen_text ) return -EINVAL; - text_mfn = _mfn(virt_to_mfn(_start)); + text_mfn = virt_to_mfn(_start); text_order = get_order_from_bytes(_end - _start); /*