From: Julien Grall <julien.grall@linaro.org>
To: xen-devel@lists.xen.org
Cc: sstabellini@kernel.org, Julien Grall <julien.grall@linaro.org>,
andre.przywara@linaro.org
Subject: [PATCH for-next 03/16] xen/arm: Extend copy_to_guest to support copying from guest VA and use it
Date: Thu, 23 Nov 2017 18:31:57 +0000 [thread overview]
Message-ID: <20171123183210.12045-4-julien.grall@linaro.org> (raw)
In-Reply-To: <20171123183210.12045-1-julien.grall@linaro.org>
The only differences between copy_to_guest (formerly called
raw_copy_to_guest_helper) and raw_copy_from_guest is:
- The direction of the memcpy
- The permission use for translating the address
Extend copy_to_guest to support copying from guest VA by adding using a
bit in the flags to tell the direction of the copy.
Lastly, reimplement raw_copy_from_guest using copy_to_guest.
Signed-off-by: Julien Grall <julien.grall@linaro.org>
---
xen/arch/arm/guestcopy.c | 46 +++++++++++++---------------------------------
1 file changed, 13 insertions(+), 33 deletions(-)
diff --git a/xen/arch/arm/guestcopy.c b/xen/arch/arm/guestcopy.c
index d1cfbe922c..1ffa717ca6 100644
--- a/xen/arch/arm/guestcopy.c
+++ b/xen/arch/arm/guestcopy.c
@@ -6,6 +6,8 @@
#include <asm/guest_access.h>
#define COPY_flush_dcache (1U << 0)
+#define COPY_from_guest (0U << 1)
+#define COPY_to_guest (1U << 1)
static unsigned long copy_guest(void *buf, paddr_t addr, unsigned int len,
unsigned int flags)
@@ -19,13 +21,18 @@ static unsigned long copy_guest(void *buf, paddr_t addr, unsigned int len,
unsigned size = min(len, (unsigned)PAGE_SIZE - offset);
struct page_info *page;
- page = get_page_from_gva(current, addr, GV2M_WRITE);
+ page = get_page_from_gva(current, addr,
+ (flags & COPY_to_guest) ? GV2M_WRITE : GV2M_READ);
if ( page == NULL )
return len;
p = __map_domain_page(page);
p += offset;
- memcpy(p, buf, size);
+ if ( flags & COPY_to_guest )
+ memcpy(p, buf, size);
+ else
+ memcpy(buf, p, size);
+
if ( flags & COPY_flush_dcache )
clean_dcache_va_range(p, size);
@@ -46,13 +53,14 @@ static unsigned long copy_guest(void *buf, paddr_t addr, unsigned int len,
unsigned long raw_copy_to_guest(void *to, const void *from, unsigned len)
{
- return copy_guest((void *)from, (unsigned long)to, len, 0);
+ return copy_guest((void *)from, (unsigned long)to, len, COPY_to_guest);
}
unsigned long raw_copy_to_guest_flush_dcache(void *to, const void *from,
unsigned len)
{
- return copy_guest((void *)from, (unsigned long)to, len, COPY_flush_dcache);
+ return copy_guest((void *)from, (unsigned long)to, len,
+ COPY_to_guest | COPY_flush_dcache);
}
unsigned long raw_clear_guest(void *to, unsigned len)
@@ -90,35 +98,7 @@ unsigned long raw_clear_guest(void *to, unsigned len)
unsigned long raw_copy_from_guest(void *to, const void __user *from, unsigned len)
{
- unsigned offset = (vaddr_t)from & ~PAGE_MASK;
-
- while ( len )
- {
- void *p;
- unsigned size = min(len, (unsigned)(PAGE_SIZE - offset));
- struct page_info *page;
-
- page = get_page_from_gva(current, (vaddr_t) from, GV2M_READ);
- if ( page == NULL )
- return len;
-
- p = __map_domain_page(page);
- p += ((vaddr_t)from & (~PAGE_MASK));
-
- memcpy(to, p, size);
-
- unmap_domain_page(p);
- put_page(page);
- len -= size;
- from += size;
- to += size;
- /*
- * After the first iteration, guest virtual address is correctly
- * aligned to PAGE_SIZE.
- */
- offset = 0;
- }
- return 0;
+ return copy_guest(to, (unsigned long)from, len, COPY_from_guest);
}
/*
--
2.11.0
_______________________________________________
Xen-devel mailing list
Xen-devel@lists.xenproject.org
https://lists.xenproject.org/mailman/listinfo/xen-devel
next prev parent reply other threads:[~2017-11-23 18:31 UTC|newest]
Thread overview: 49+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-11-23 18:31 [PATCH for-next 00/16] xen/arm: Stage-2 handling cleanup Julien Grall
2017-11-23 18:31 ` [PATCH for-next 01/16] xen/arm: raw_copy_to_guest_helper: Rename flush_dcache to flags Julien Grall
2017-12-06 0:51 ` Stefano Stabellini
2017-11-23 18:31 ` [PATCH for-next 02/16] xen/arm: raw_copy_to_guest_helper: Rework the prototype and rename it Julien Grall
2017-12-06 1:04 ` Stefano Stabellini
2017-11-23 18:31 ` Julien Grall [this message]
2017-12-06 1:05 ` [PATCH for-next 03/16] xen/arm: Extend copy_to_guest to support copying from guest VA and use it Stefano Stabellini
2017-11-23 18:31 ` [PATCH for-next 04/16] xen/arm: Extend copy_to_guest to support zeroing " Julien Grall
2017-12-06 1:08 ` Stefano Stabellini
2017-11-23 18:31 ` [PATCH for-next 05/16] xen/arm: guest_copy: Extend the prototype to pass the vCPU Julien Grall
2017-12-06 1:11 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 06/16] xen/arm: Extend copy_to_guest to support copying from/to guest physical address Julien Grall
2017-12-06 1:22 ` Stefano Stabellini
2017-12-06 1:24 ` Stefano Stabellini
2017-12-06 12:22 ` Julien Grall
2017-12-07 23:01 ` Stefano Stabellini
2017-12-08 15:24 ` Julien Grall
2017-12-08 21:13 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 07/16] xen/arm: Introduce copy_to_guest_phys_flush_dcache Julien Grall
2017-11-23 18:49 ` Andrew Cooper
2017-11-23 19:02 ` Julien Grall
2017-12-06 1:26 ` Stefano Stabellini
2017-12-06 12:27 ` Julien Grall
2017-12-08 15:34 ` Julien Grall
2017-12-08 22:26 ` Stefano Stabellini
2017-12-08 22:30 ` Julien Grall
2017-12-08 22:43 ` Stefano Stabellini
2017-12-12 0:16 ` Julien Grall
2017-12-12 0:28 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 08/16] xen/arm: kernel: Rework kernel_zimage_load to use the generic copy helper Julien Grall
2017-12-06 1:38 ` Stefano Stabellini
2017-12-06 1:42 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 09/16] xen/arm: domain_build: Rework initrd_load " Julien Grall
2017-12-06 1:56 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 10/16] xen/arm: domain_build: Use copy_to_guest_phys_flush_dcache in dtb_load Julien Grall
2017-12-06 1:59 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 11/16] xen/arm: p2m: Rename p2m_flush_tlb and p2m_flush_tlb_sync Julien Grall
2017-12-07 22:10 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 12/16] xen/arm: p2m: Introduce p2m_tlb_flush_sync, export it and use it Julien Grall
2017-12-07 22:14 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 13/16] xen/arm: p2m: Fold p2m_tlb_flush into p2m_force_tlb_flush_sync Julien Grall
2017-12-07 22:26 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 14/16] xen/arm: traps: Remove the field gva from mmio_info_t Julien Grall
2017-12-07 22:29 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 15/16] xen/arm: traps: Move the definition of mmio_info_t in try_handle_mmio Julien Grall
2017-12-07 22:43 ` Stefano Stabellini
2017-11-23 18:32 ` [PATCH for-next 16/16] xen/arm: traps: Merge do_trap_instr_abort_guest and do_trap_data_abort_guest Julien Grall
2017-12-07 22:43 ` Stefano Stabellini
2017-12-07 22:57 ` Julien Grall
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20171123183210.12045-4-julien.grall@linaro.org \
--to=julien.grall@linaro.org \
--cc=andre.przywara@linaro.org \
--cc=sstabellini@kernel.org \
--cc=xen-devel@lists.xen.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).