| /* |
| * 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). |
| * |
| * You must mask ALL interrupts prior to invoking this code, since |
| * you can't legally touch the stack during the cache flush. |
| */ |
| 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. |
| * |
| * You must mask ALL interrupts prior to invoking this code, since |
| * you can't legally touch the stack during the cache flush. |
| */ |
| 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 */ |