tlb.h

Go to the documentation of this file.
00001 /*
00002  * Copyright (C) 2001-2004 Jakub Jermar
00003  * All rights reserved.
00004  *
00005  * Redistribution and use in source and binary forms, with or without
00006  * modification, are permitted provided that the following conditions
00007  * are met:
00008  *
00009  * - Redistributions of source code must retain the above copyright
00010  *   notice, this list of conditions and the following disclaimer.
00011  * - Redistributions in binary form must reproduce the above copyright
00012  *   notice, this list of conditions and the following disclaimer in the
00013  *   documentation and/or other materials provided with the distribution.
00014  * - The name of the author may not be used to endorse or promote products
00015  *   derived from this software without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
00018  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
00019  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
00020  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
00021  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
00022  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00023  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00024  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00025  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
00026  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00027  */
00028 
00035 #ifndef __TLB_H__
00036 #define __TLB_H__
00037 
00038 #include <arch/mm/asid.h>
00039 #include <arch/types.h>
00040 #include <typedefs.h>
00041 
00046 #define TLB_MESSAGE_QUEUE_LEN   10
00047 
00049 enum tlb_invalidate_type {
00050         TLB_INVL_INVALID = 0,           
00051         TLB_INVL_ALL,                   
00052         TLB_INVL_ASID,                  
00053         TLB_INVL_PAGES                  
00054 };
00055 typedef enum tlb_invalidate_type tlb_invalidate_type_t;
00056 
00058 struct tlb_shootdown_msg {
00059         tlb_invalidate_type_t type;     
00060         asid_t asid;                    
00061         __address page;                 
00062         count_t count;                  
00063 };
00064 typedef struct tlb_shootdown_msg tlb_shootdown_msg_t;
00065 
00066 extern void tlb_init(void);
00067 
00068 #ifdef CONFIG_SMP
00069 extern void tlb_shootdown_start(tlb_invalidate_type_t type, asid_t asid, __address page, count_t count);
00070 extern void tlb_shootdown_finalize(void);
00071 extern void tlb_shootdown_ipi_recv(void);
00072 #else
00073 #  define tlb_shootdown_start(w, x, y, z)
00074 #  define tlb_shootdown_finalize()
00075 #  define tlb_shootdown_ipi_recv()
00076 #endif /* CONFIG_SMP */
00077 
00078 
00079 /* Export TLB interface that each architecture must implement. */
00080 extern void tlb_arch_init(void);
00081 extern void tlb_print(void);
00082 extern void tlb_shootdown_ipi_send(void);
00083 
00084 extern void tlb_invalidate_all(void);
00085 extern void tlb_invalidate_asid(asid_t asid);
00086 extern void tlb_invalidate_pages(asid_t asid, __address page, count_t cnt);
00087 #endif
00088 

Generated on Sun Jun 18 16:26:57 2006 for HelenOS Kernel (amd64) by  doxygen 1.4.6