linux-next/arch/tile/mm/migrate.h
Chris Metcalf 867e359b97 arch/tile: core support for Tilera 32-bit chips.
This change is the core kernel support for TILEPro and TILE64 chips.
No driver support (except the console driver) is included yet.

This includes the relevant Linux headers in asm/; the low-level
low-level "Tile architecture" headers in arch/, which are
shared with the hypervisor, etc., and are build-system agnostic;
and the relevant hypervisor headers in hv/.

Signed-off-by: Chris Metcalf <cmetcalf@tilera.com>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Acked-by: FUJITA Tomonori <fujita.tomonori@lab.ntt.co.jp>
Reviewed-by: Paul Mundt <lethal@linux-sh.org>
2010-06-04 17:11:18 -04:00

51 lines
1.6 KiB
C

/*
* Copyright 2010 Tilera Corporation. All Rights Reserved.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation, version 2.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE, GOOD TITLE or
* NON INFRINGEMENT. See the GNU General Public License for
* more details.
*
* Structure definitions for migration, exposed here for use by
* arch/tile/kernel/asm-offsets.c.
*/
#ifndef MM_MIGRATE_H
#define MM_MIGRATE_H
#include <linux/cpumask.h>
#include <hv/hypervisor.h>
/*
* This function is used as a helper when setting up the initial
* page table (swapper_pg_dir).
*/
extern int flush_and_install_context(HV_PhysAddr page_table, HV_PTE access,
HV_ASID asid,
const unsigned long *cpumask);
/*
* This function supports migration as a "helper" as follows:
*
* - Set the stack PTE itself to "migrating".
* - Do a global TLB flush for (va,length) and the specified ASIDs.
* - Do a cache-evict on all necessary cpus.
* - Write the new stack PTE.
*
* Note that any non-NULL pointers must not point to the page that
* is handled by the stack_pte itself.
*/
extern int homecache_migrate_stack_and_flush(pte_t stack_pte, unsigned long va,
size_t length, pte_t *stack_ptep,
const struct cpumask *cache_cpumask,
const struct cpumask *tlb_cpumask,
HV_Remote_ASID *asids,
int asidcount);
#endif /* MM_MIGRATE_H */