frame.h

Go to the documentation of this file.
00001 /*
00002  * Copyright (C) 2005 Jakub Jermar
00003  * Copyright (C) 2005 Sergey Bondari
00004  * All rights reserved.
00005  *
00006  * Redistribution and use in source and binary forms, with or without
00007  * modification, are permitted provided that the following conditions
00008  * are met:
00009  *
00010  * - Redistributions of source code must retain the above copyright
00011  *   notice, this list of conditions and the following disclaimer.
00012  * - Redistributions in binary form must reproduce the above copyright
00013  *   notice, this list of conditions and the following disclaimer in the
00014  *   documentation and/or other materials provided with the distribution.
00015  * - The name of the author may not be used to endorse or promote products
00016  *   derived from this software without specific prior written permission.
00017  *
00018  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
00019  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
00020  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
00021  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
00022  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
00023  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00024  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00025  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00026  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
00027  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00028  */
00029 
00036 #ifndef __FRAME_H__
00037 #define __FRAME_H__
00038 
00039 #include <arch/types.h>
00040 #include <typedefs.h>
00041 #include <adt/list.h>
00042 #include <synch/spinlock.h>
00043 #include <mm/buddy.h>
00044 #include <arch/mm/page.h>
00045 #include <arch/mm/frame.h>
00046 
00047 #define ONE_FRAME       0
00048 #define TWO_FRAMES      1
00049 
00050 #ifdef ARCH_STACK_FRAMES
00051 #define STACK_FRAMES ARCH_STACK_FRAMES
00052 #else
00053 #define STACK_FRAMES ONE_FRAME
00054 #endif
00055 
00056 #define ZONES_MAX       16      
00058 #define ZONE_JOIN       0x1     
00060 #define FRAME_KA                0x1     /* skip frames conflicting with user address space */
00061 #define FRAME_PANIC             0x2     /* panic on failure */
00062 #define FRAME_ATOMIC            0x4     /* do not panic and do not sleep on failure */
00063 #define FRAME_NO_RECLAIM        0x8     /* do not start reclaiming when no free memory */
00064 
00065 #define FRAME_OK                0       /* frame_alloc return status */
00066 #define FRAME_NO_MEMORY         1       /* frame_alloc return status */
00067 #define FRAME_ERROR             2       /* frame_alloc return status */
00068 
00069 static inline __address PFN2ADDR(pfn_t frame)
00070 {
00071         return (__address)(frame << FRAME_WIDTH);
00072 }
00073 
00074 static inline pfn_t ADDR2PFN(__address addr)
00075 {
00076         return (pfn_t)(addr >> FRAME_WIDTH);
00077 }
00078 
00079 static inline count_t SIZE2FRAMES(size_t size)
00080 {
00081         if (!size)
00082                 return 0;
00083         return (count_t)((size-1) >> FRAME_WIDTH)+1;
00084 }
00085 
00086 #define IS_BUDDY_ORDER_OK(index, order)         ((~(((__native) -1) << (order)) & (index)) == 0)
00087 #define IS_BUDDY_LEFT_BLOCK(zone, frame)        (((frame_index((zone), (frame)) >> (frame)->buddy_order) & 0x1) == 0)
00088 #define IS_BUDDY_RIGHT_BLOCK(zone, frame)       (((frame_index((zone), (frame)) >> (frame)->buddy_order) & 0x1) == 1)
00089 #define IS_BUDDY_LEFT_BLOCK_ABS(zone, frame)    (((frame_index_abs((zone), (frame)) >> (frame)->buddy_order) & 0x1) == 0)
00090 #define IS_BUDDY_RIGHT_BLOCK_ABS(zone, frame)   (((frame_index_abs((zone), (frame)) >> (frame)->buddy_order) & 0x1) == 1)
00091 
00092 #define frame_alloc(order, flags)                               frame_alloc_generic(order, flags, NULL, NULL)
00093 #define frame_alloc_rc(order, flags, status)                    frame_alloc_generic(order, flags, status, NULL)
00094 #define frame_alloc_rc_zone(order, flags, status, zone)         frame_alloc_generic(order, flags, status, zone)
00095 
00096 extern void frame_init(void);
00097 extern pfn_t frame_alloc_generic(__u8 order, int flags, int * status, int *pzone);
00098 extern void frame_free(pfn_t pfn);
00099 extern void frame_reference_add(pfn_t pfn);
00100 
00101 extern int zone_create(pfn_t start, count_t count, pfn_t confframe, int flags);
00102 void * frame_get_parent(pfn_t frame, int hint);
00103 void frame_set_parent(pfn_t frame, void *data, int hint);
00104 void frame_mark_unavailable(pfn_t start, count_t count);
00105 __address zone_conf_size(count_t count);
00106 void zone_merge(int z1, int z2);
00107 void zone_merge_all(void);
00108 
00109 /*
00110  * Console functions
00111  */
00112 extern void zone_print_list(void);
00113 void zone_print_one(int znum);
00114 
00115 #endif
00116 

Generated on Sun Jun 18 17:17:05 2006 for HelenOS Kernel (ppc32) by  doxygen 1.4.6