From owner-svn-soc-all@freebsd.org Thu Jul 9 17:07:12 2015 Return-Path: Delivered-To: svn-soc-all@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 59AFF997647 for ; Thu, 9 Jul 2015 17:07:12 +0000 (UTC) (envelope-from mihai@FreeBSD.org) Received: from socsvn.freebsd.org (socsvn.freebsd.org [IPv6:2001:1900:2254:206a::50:2]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 24C353BBC for ; Thu, 9 Jul 2015 17:07:12 +0000 (UTC) (envelope-from mihai@FreeBSD.org) Received: from socsvn.freebsd.org ([127.0.1.124]) by socsvn.freebsd.org (8.14.9/8.14.9) with ESMTP id t69H7C6K096166 for ; Thu, 9 Jul 2015 17:07:12 GMT (envelope-from mihai@FreeBSD.org) Received: (from www@localhost) by socsvn.freebsd.org (8.14.9/8.14.9/Submit) id t69H7B8T096152 for svn-soc-all@FreeBSD.org; Thu, 9 Jul 2015 17:07:11 GMT (envelope-from mihai@FreeBSD.org) Date: Thu, 9 Jul 2015 17:07:11 GMT Message-Id: <201507091707.t69H7B8T096152@socsvn.freebsd.org> X-Authentication-Warning: socsvn.freebsd.org: www set sender to mihai@FreeBSD.org using -f From: mihai@FreeBSD.org To: svn-soc-all@FreeBSD.org Subject: socsvn commit: r288159 - in soc2015/mihai/bhyve-on-arm-head: sys/arm/vmm usr.sbin/bhyveloadarm MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-soc-all@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: SVN commit messages for the entire Summer of Code repository List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 09 Jul 2015 17:07:12 -0000 Author: mihai Date: Thu Jul 9 17:07:10 2015 New Revision: 288159 URL: http://svnweb.FreeBSD.org/socsvn/?view=rev&rev=288159 Log: soc2015: mihai: bhyve: sys: arm: vmm: mmu.c: fix bug when len is not multiple of PAGE_SIZE Modified: soc2015/mihai/bhyve-on-arm-head/sys/arm/vmm/mmu.c soc2015/mihai/bhyve-on-arm-head/usr.sbin/bhyveloadarm/bhyveloadarm.c Modified: soc2015/mihai/bhyve-on-arm-head/sys/arm/vmm/mmu.c ============================================================================== --- soc2015/mihai/bhyve-on-arm-head/sys/arm/vmm/mmu.c Thu Jul 9 16:43:10 2015 (r288158) +++ soc2015/mihai/bhyve-on-arm-head/sys/arm/vmm/mmu.c Thu Jul 9 17:07:10 2015 (r288159) @@ -192,11 +192,15 @@ if (arg) l1pd = &vm_hyp->l1pd[0]; - while (len > 0) { + while (1) { n = create_lpae_mapping(l1pd, virt_start, phys_start, len, prot); + + if (len <= n) + break; len -= n; virt_start += n; phys_start += n; + printf("%s n: %d %d\n", __func__, n, len); } return (0); } Modified: soc2015/mihai/bhyve-on-arm-head/usr.sbin/bhyveloadarm/bhyveloadarm.c ============================================================================== --- soc2015/mihai/bhyve-on-arm-head/usr.sbin/bhyveloadarm/bhyveloadarm.c Thu Jul 9 16:43:10 2015 (r288158) +++ soc2015/mihai/bhyve-on-arm-head/usr.sbin/bhyveloadarm/bhyveloadarm.c Thu Jul 9 17:07:10 2015 (r288159) @@ -28,6 +28,7 @@ #define MB (1024 * 1024UL) #define GB (1024 * 1024 * 1024UL) #define BSP 0 +#define KERNEL_IMAGE_NAME_LEN 32 static char *vmname, *progname; static struct vmctx *ctx; @@ -92,20 +93,20 @@ int opt, error; int kernel_image_fd; uint64_t kernel_load_address, memory_base_address; + char kernel_image_name[KERNEL_IMAGE_NAME_LEN]; struct stat st; void *addr; progname = basename(argv[0]); - mem_size = 256 * MB; + mem_size = 128 * MB; + kernel_load_address = 0xc0000000; + memory_base_address = 0xc0000000; while ((opt = getopt(argc, argv, "k:l:b:m:")) != -1) { switch (opt) { case 'k': - kernel_image_fd = open(optarg, O_RDONLY); - if (kernel_image_fd == -1) { - errx(EX_USAGE, "Could not open '%s'", optarg); - } + strncpy(kernel_image_name, optarg, KERNEL_IMAGE_NAME_LEN); break; case 'l': kernel_load_address = strtoul(optarg, NULL, 0); @@ -129,6 +130,12 @@ vmname = argv[0]; + kernel_image_fd = open(kernel_image_name, O_RDONLY); + if (kernel_image_fd == -1) { + perror("open kernel_image_name"); + exit(1); + } + error = vm_create(vmname); if (error) { perror("vm_create"); @@ -147,6 +154,7 @@ exit(1); } + error = fstat(kernel_image_fd, &st); if (error) { perror("fstat");