⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tlb_track.h

📁 xen虚拟机源代码安装包
💻 H
字号:
/****************************************************************************** * tlb_track.h * * Copyright (c) 2006 Isaku Yamahata <yamahata at valinux co jp> *                    VA Linux Systems Japan K.K. * * 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; either version 2 of the License, or * (at your option) any later version. * * 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.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * */#ifndef __TLB_TRACK_H__#define __TLB_TRACK_H__#ifdef CONFIG_XEN_IA64_TLB_TRACK#include <xen/sched.h>#include <xen/perfc.h>#include <asm/domain.h>#include <xen/list.h>#include <asm/p2m_entry.h>#include <asm/vcpumask.h>// TODO: compact this structure.struct tlb_track_entry {    struct list_head   list;    volatile pte_t*     ptep;           // corresponding p2m entry    /* XXX should we use TR_ENTRY? */    pte_t               pte_val;        // mfn and other flags                                        // pte_val.p = 1:                                        //   tlb entry is inserted.                                        // pte_val.p = 0:                                         //   once tlb entry is inserted, so                                        //   this entry is created. But tlb                                        //   purge is isseued, so this                                        //   virtual address need not to be                                        //   purged.    unsigned long       vaddr;          // virtual address    unsigned long       rid;            // rid    cpumask_t           pcpu_dirty_mask;    vcpumask_t          vcpu_dirty_mask;#ifdef CONFIG_TLB_TRACK_CNT#define TLB_TRACK_CNT_FORCE_MANY        256 /* XXX how many? */    unsigned long       cnt;#endif};struct tlb_track {/* see __gnttab_map_grant_ref()   A domain can map granted-page up to MAPTRACK_MAX_ENTRIES pages. */#define TLB_TRACK_LIMIT_ENTRIES                                     \    (MAPTRACK_MAX_ENTRIES * (PAGE_SIZE / sizeof(struct tlb_track)))    spinlock_t                  free_list_lock;    struct list_head            free_list;    unsigned int                limit;    unsigned int                num_entries;    unsigned int                num_free;    struct list_head            page_list;    /* XXX hash table size */    spinlock_t                  hash_lock;    unsigned int                hash_size;    unsigned int                hash_shift;    unsigned int                hash_mask;    struct list_head*           hash;};int tlb_track_create(struct domain* d);void tlb_track_destroy(struct domain* d);void tlb_track_free_entry(struct tlb_track* tlb_track,                          struct tlb_track_entry* entry);void__vcpu_tlb_track_insert_or_dirty(struct vcpu *vcpu, unsigned long vaddr,                                 struct p2m_entry* entry);static inline voidvcpu_tlb_track_insert_or_dirty(struct vcpu *vcpu, unsigned long vaddr,                               struct p2m_entry* entry){    /* optimization.       non-tracking pte is most common. */    perfc_incr(tlb_track_iod);    if (!pte_tlb_tracking(entry->used)) {        perfc_incr(tlb_track_iod_not_tracked);        return;    }    __vcpu_tlb_track_insert_or_dirty(vcpu, vaddr, entry);}/* return value * NULL if this entry is used * entry if this entry isn't used */enum TLB_TRACK_RET {    TLB_TRACK_NOT_TRACKED,    TLB_TRACK_NOT_FOUND,    TLB_TRACK_FOUND,    TLB_TRACK_MANY,    TLB_TRACK_AGAIN,};typedef enum TLB_TRACK_RET TLB_TRACK_RET_T;TLB_TRACK_RET_Ttlb_track_search_and_remove(struct tlb_track* tlb_track,                             volatile pte_t* ptep, pte_t old_pte,                             struct tlb_track_entry** entryp);void__tlb_track_entry_printf(const char* func, int line,                         const struct tlb_track_entry* entry);#define tlb_track_entry_printf(entry)                       \    __tlb_track_entry_printf(__func__, __LINE__, (entry))#else//define as nop#define tlb_track_create(d)                     do { } while (0)#define tlb_track_destroy(d)                    do { } while (0)#define tlb_track_free_entry(tlb_track, entry)  do { } while (0)#define vcpu_tlb_track_insert_or_dirty(vcpu, vaddr, entry)      \                                                do { } while (0)#define tlb_track_search_and_remove(tlb_track, ptep, old_pte, entryp)   \                                                do { } while (0)#define tlb_track_entry_printf(entry)           do { } while (0)#endif /* CONFIG_XEN_IA64_TLB_TRACK */#endif /* __TLB_TRACK_H__ *//* * Local variables: * mode: C * c-set-style: "BSD" * c-basic-offset: 4 * tab-width: 4 * indent-tabs-mode: nil * End: */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -