cregit-Linux how code gets into the kernel

Release 4.14 arch/x86/xen/grant-table.c

Directory: arch/x86/xen
/******************************************************************************
 * grant_table.c
 * x86 specific part
 *
 * Granting foreign access to our memory reservation.
 *
 * Copyright (c) 2005-2006, Christopher Clark
 * Copyright (c) 2004-2005, K A Fraser
 * Copyright (c) 2008 Isaku Yamahata <yamahata at valinux co jp>
 *                    VA Linux Systems Japan. Split out x86 specific part.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License version 2
 * as published by the Free Software Foundation; or, when distributed
 * separately from the Linux kernel or incorporated into other
 * software packages, subject to the following license:
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this source file (the "Software"), to deal in the Software without
 * restriction, including without limitation the rights to use, copy, modify,
 * merge, publish, distribute, sublicense, and/or sell copies of the Software,
 * and to permit persons to whom the Software is furnished to do so, subject to
 * the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 * IN THE SOFTWARE.
 */

#include <linux/sched.h>
#include <linux/mm.h>
#include <linux/slab.h>
#include <linux/vmalloc.h>

#include <xen/interface/xen.h>
#include <xen/page.h>
#include <xen/grant_table.h>
#include <xen/xen.h>

#include <asm/pgtable.h>


static struct gnttab_vm_area {
	
struct vm_struct *area;
	
pte_t **ptes;

} gnttab_shared_vm_area;


int arch_gnttab_map_shared(unsigned long *frames, unsigned long nr_gframes, unsigned long max_nr_gframes, void **__shared) { void *shared = *__shared; unsigned long addr; unsigned long i; if (shared == NULL) *__shared = shared = gnttab_shared_vm_area.area->addr; addr = (unsigned long)shared; for (i = 0; i < nr_gframes; i++) { set_pte_at(&init_mm, addr, gnttab_shared_vm_area.ptes[i], mfn_pte(frames[i], PAGE_KERNEL)); addr += PAGE_SIZE; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
David Vrabel6962.73%150.00%
Isaku Yamahata4137.27%150.00%
Total110100.00%2100.00%


void arch_gnttab_unmap(void *shared, unsigned long nr_gframes) { unsigned long addr; unsigned long i; addr = (unsigned long)shared; for (i = 0; i < nr_gframes; i++) { set_pte_at(&init_mm, addr, gnttab_shared_vm_area.ptes[i], __pte(0)); addr += PAGE_SIZE; } }

Contributors

PersonTokensPropCommitsCommitProp
David Vrabel4667.65%266.67%
Isaku Yamahata2232.35%133.33%
Total68100.00%3100.00%


static int arch_gnttab_valloc(struct gnttab_vm_area *area, unsigned nr_frames) { area->ptes = kmalloc_array(nr_frames, sizeof(*area->ptes), GFP_KERNEL); if (area->ptes == NULL) return -ENOMEM; area->area = alloc_vm_area(PAGE_SIZE * nr_frames, area->ptes); if (area->area == NULL) { kfree(area->ptes); return -ENOMEM; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
David Vrabel5565.48%360.00%
Isaku Yamahata2327.38%120.00%
SF Markus Elfring67.14%120.00%
Total84100.00%5100.00%


int arch_gnttab_init(unsigned long nr_shared) { if (!xen_pv_domain()) return 0; return arch_gnttab_valloc(&gnttab_shared_vm_area, nr_shared); }

Contributors

PersonTokensPropCommitsCommitProp
David Vrabel1451.85%250.00%
Annie Li1244.44%125.00%
Isaku Yamahata13.70%125.00%
Total27100.00%4100.00%

#ifdef CONFIG_XEN_PVH #include <xen/events.h> #include <xen/xen-ops.h>
static int __init xen_pvh_gnttab_setup(void) { if (!xen_pvh_domain()) return -ENODEV; xen_auto_xlat_grant_frames.count = gnttab_max_grant_frames(); return xen_xlate_map_ballooned_pages(&xen_auto_xlat_grant_frames.pfn, &xen_auto_xlat_grant_frames.vaddr, xen_auto_xlat_grant_frames.count); }

Contributors

PersonTokensPropCommitsCommitProp
Konrad Rzeszutek Wilk2454.55%125.00%
Shannon Zhao1738.64%125.00%
David Vrabel24.55%125.00%
Dave Jones12.27%125.00%
Total44100.00%4100.00%

/* Call it _before_ __gnttab_init as we need to initialize the * xen_auto_xlat_grant_frames first. */ core_initcall(xen_pvh_gnttab_setup); #endif

Overall Contributors

PersonTokensPropCommitsCommitProp
David Vrabel20852.66%541.67%
Isaku Yamahata11027.85%18.33%
Konrad Rzeszutek Wilk4010.13%216.67%
Shannon Zhao184.56%18.33%
Annie Li123.04%18.33%
SF Markus Elfring61.52%18.33%
Dave Jones10.25%18.33%
Total395100.00%12100.00%
Directory: arch/x86/xen
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.