source: trunk/kernel/mm/ppm.h @ 610

Last change on this file since 610 was 610, checked in by alain, 5 years ago

Fix several bugs in VFS to support the following
ksh commandis : cp, mv, rm, mkdir, cd, pwd

File size: 12.8 KB
RevLine 
[1]1/*
[567]2 * ppm.h - Per-cluster Physical Pages Manager definition.
[18]3 *
[1]4 * Authors  Ghassan Almaless (2008,2009,2010,2011,2012)
[567]5 *          Alain Greiner    (2016,2017,2018)
[1]6 *
7 * Copyright (c) UPMC Sorbonne Universites
8 *
9 * This file is part of ALMOS-MKH.
10 *
11 * ALMOS-kernel is free software; you can redistribute it and/or modify it
12 * under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; version 2.0 of the License.
14 *
15 * ALMOS-kernel is distributed in the hope that it will be useful, but
16 * WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
18 * General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with ALMOS-kernel; if not, write to the Free Software Foundation,
22 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
23 */
24
25#ifndef _PPM_H_
26#define _PPM_H_
27
[457]28#include <hal_kernel_types.h>
[1]29#include <list.h>
[567]30#include <busylock.h>
[606]31#include <remote_queuelock.h>
[1]32#include <boot_info.h>
33#include <page.h>
34
35
36/*****************************************************************************************
[409]37 * This structure defines the Physical Pages Manager in a cluster.
38 * In each cluster, the physical memory bank starts at local physical address 0 and
[567]39 * contains an integer number of pages, defined by the <pages_nr> field in the
[50]40 * boot_info structure. It is split in three parts:
[606]41 *
[50]42 * - the "kernel_code" section contains the kernel code, loaded by the boot-loader.
43 *   It starts at PPN = 0 and the size is defined by the <pages_offset> field in the
44 *   boot_info structure.
45 * - the "pages_tbl" section contains the physical page descriptors array. It starts
46 *   at PPN = pages_offset, and it contains one entry per small physical page in cluster.
[567]47 *   It is created and initialized by the hal_ppm_create() function.
[50]48 * - The "kernel_heap" section contains all physical pages that are are not in the
[567]49 *   kernel_code and pages_tbl sections, and that have not been reserved by the
[50]50 *   architecture specific bootloader. The reserved pages are defined in the boot_info
51 *   structure.
[160]52 *
[50]53 * The main service provided by the PMM is the dynamic allocation of physical pages
[567]54 * from the "kernel_heap" section. This low-level allocator implements the buddy
55 * algorithm: an allocated block is an integer number n of small pages, where n
56 * is a power of 2, and ln(n) is called order.
57 * This allocator being shared by the local threads, the free_page lists rooted
58 * in the PPM descriptor are protected by a local busylock, because it is used
59 * by the idle_thread during kernel_init().
60 *
61 * Another service is to register the dirty pages in a specific dirty_list, that is
62 * also rooted in the PPM, in order to be able to save all dirty pages on disk.
[606]63 * This dirty list is protected by a specific remote_queuelock, because it can be
[610]64 * modified by a remote thread, but it contains only local pages.
[1]65 ****************************************************************************************/
[50]66
[1]67typedef struct ppm_s
68{
[606]69        busylock_t          free_lock;          /*! lock protecting free_pages[] lists      */
70        list_entry_t        free_pages_root[CONFIG_PPM_MAX_ORDER];  /*! roots of free lists */
71        uint32_t            free_pages_nr[CONFIG_PPM_MAX_ORDER];    /*! free pages number   */
72        page_t            * pages_tbl;          /*! pointer on page descriptors array       */
73        uint32_t            pages_nr;           /*! total number of small physical page     */
74    remote_queuelock_t  dirty_lock;         /*! lock protecting dirty pages list        */
75    list_entry_t        dirty_root;         /*! root of dirty pages list                */
76    void              * vaddr_base;         /*! pointer on local physical memory base   */
[1]77}
78ppm_t;
79
[567]80/************** functions to allocate / release physical pages  *************************/
81
[1]82/*****************************************************************************************
83 * This is the low-level physical pages allocation function.
84 * It allocates N contiguous physical pages. N is a power of 2.
[18]85 * In normal use, you don't need to call it directly, as the recommended way to get
[1]86 * physical pages is to call the generic allocator defined in kmem.h.
[7]87 *****************************************************************************************
[1]88 * @ order        : ln2( number of 4 Kbytes pages)
89 * @ returns a pointer on the page descriptor if success / NULL otherwise
[50]90 **************************************************************************************à))**/
[1]91page_t * ppm_alloc_pages( uint32_t order );
92
93/*****************************************************************************************
[53]94 * This is the low-level physical pages release function. It takes the lock protecting
95 * the free_list before register the released page in the relevant free_list.
[18]96 * In normal use, you do not need to call it directly, as the recommended way to free
[1]97 * physical pages is to call the generic allocator defined in kmem.h.
[7]98 *****************************************************************************************
[1]99 * @ page         : pointer to the page descriptor to be released
100 ****************************************************************************************/
101void ppm_free_pages( page_t * page );
102
103/*****************************************************************************************
[53]104 * This function does the same as the ppm_free_page() function, without taking the lock.
105 * It is used by the hal_ppm_init() function to initialize the pages_tbl[] array, when
106 * there is no concurrent access issue.
107 *****************************************************************************************
108 * @ page         : pointer to the page descriptor to be released
109 ****************************************************************************************/
110void ppm_free_pages_nolock( page_t * page );
111
112/*****************************************************************************************
[50]113 * This function check if a page descriptor pointer is valid.
[7]114 *****************************************************************************************
[1]115 * @ page         : pointer on a page descriptor
116 * @ returns true if valid / false otherwise.
117 ****************************************************************************************/
118inline bool_t ppm_page_is_valid( page_t * page );
119
[315]120
[567]121/************** functions to translate [ page <->  base <-> ppn ] ***********************/
[315]122
[1]123/*****************************************************************************************
[315]124 * Get extended pointer on page base from extended pointer on page descriptor.
[7]125 *****************************************************************************************
[315]126 * @ page_xp    : extended pointer to page descriptor
127 * @ returns extended pointer on page base.
[1]128 ****************************************************************************************/
[315]129inline xptr_t ppm_page2base( xptr_t page_xp );
[1]130
131/*****************************************************************************************
[315]132 * Get extended pointer on page descriptor from extended pointer on page base.
[7]133 *****************************************************************************************
[315]134 * @ base_xp   : extended pointer to page base.
135 * @ returns extended pointer on page descriptor
[1]136 ****************************************************************************************/
[315]137inline xptr_t ppm_base2page( xptr_t base_xp );
[1]138
139/*****************************************************************************************
[407]140 * Get extended pointer on page base from global PPN.
[315]141 *****************************************************************************************
142 * @ ppn    : global physical page number.
143 * @ returns extended pointer on page base.
144 ****************************************************************************************/
145inline xptr_t ppm_ppn2base( ppn_t ppn );
146
147/*****************************************************************************************
148 * Get global PPN from extended pointer on page base.
149 *****************************************************************************************
150 * @ base_xp   : extended pointer to page base.
151 * @ returns global physical page number.
152 ****************************************************************************************/
153inline ppn_t ppm_base2ppn( xptr_t base_xp );
154
155/*****************************************************************************************
156 * Get global PPN from extended pointer on page descriptor.
157 *****************************************************************************************
158 * @ page_xp   : pointer to page descriptor
159 * @ returns global physical page number.
160 ****************************************************************************************/
161inline ppn_t ppm_page2ppn( xptr_t page_xp );
162
163/*****************************************************************************************
164 * Get extended pointer on page descriptor from global PPN.
165 *****************************************************************************************
166 * @ ppn       : global physical page number
167 * @ returns extended pointer on page descriptor.
168 ****************************************************************************************/
169inline xptr_t ppm_ppn2page( ppn_t ppn );
170
171
[606]172/*********** debug  functions  **********************************************************/
[315]173
174/*****************************************************************************************
[433]175 * This function prints the PPM allocator status in the calling thread cluster.
[1]176 ****************************************************************************************/
[486]177void ppm_print( void );
[1]178
179/*****************************************************************************************
180 * This function checks PPM allocator consistency.
[7]181 *****************************************************************************************
[1]182 * @ ppm      : pointer on PPM allocator.
[53]183 * @ return 0 if PPM is OK / return -1 if PPM not consistent.
[1]184 ****************************************************************************************/
[53]185error_t ppm_assert_order( ppm_t * ppm );
[1]186
[567]187
188/*********** functions to handle dirty pages  *******************************************/
189
190/*****************************************************************************************
[606]191 * This function registers a page identified by the <page_xp> argument as dirty.
192 * It can be called by a thread running in any cluster.
[567]193 * - it takes the queuelock protecting the PPM dirty_list.
[610]194 * - it takes the busylock protecting the page flags.
[567]195 * - it test the PG_DIRTY flag in the page descriptor.
196 *   . if page already dirty => do nothing
197 *   . it page not dirty => set the PG_DIRTY flag and register page in PPM dirty list.
[610]198 * - it releases the busylock protcting the page flags.
[567]199 * - it releases the queuelock protecting the PPM dirty_list.
200 *****************************************************************************************
[606]201 * @ page_xp  : extended pointer on page descriptor.
[567]202 * @ returns true if page was not dirty / returns false if page was dirty
203 ****************************************************************************************/
[606]204bool_t ppm_page_do_dirty( xptr_t page_xp );
[567]205
206/*****************************************************************************************
[606]207 * This function unregisters a page identified by the <page_xp> argument as dirty.
208 * It can be called by a thread running in any cluster.
[567]209 * - it takes the queuelock protecting the PPM dirty_list.
[610]210 * - it takes the busylock protecting the page flags.
[567]211 * - it test the PG_DIRTY flag in the page descriptor.
212 *   . if page not dirty => do nothing
213 *   . it page dirty => reset the PG_DIRTY flag and remove page from PPM dirty list.
[610]214 * - it releases the busylock protcting the page flags.
[567]215 * - it releases the queuelock protecting the PPM dirty_list.
216 *****************************************************************************************
[606]217 * @ page_xp  : extended pointer on page descriptor.
[567]218 * @ returns true if page was dirty / returns false if page was not dirty
219 ****************************************************************************************/
[606]220bool_t ppm_page_undo_dirty( xptr_t page_xp );
[567]221
222/*****************************************************************************************
[606]223 * This function synchronizes (i.e. update the IOC device) all dirty pages in a cluster.
[567]224 * - it takes the queuelock protecting the PPM dirty_list.
225 * - it scans the PPM dirty list, and for each page:
226 *   . it takes the lock protecting the page.
227 *   . it removes the page from the PPM dirty_list.
228 *   . it reset the PG_DIRTY flag.
229 *   . it releases the lock protecting the page.
230 * - it releases the queuelock protecting the PPM dirty_list.
231 $ The PPM dirty_list is empty when the sync operation completes.
232 ****************************************************************************************/
[606]233void ppm_sync_dirty_pages( void );
[567]234
[1]235#endif  /* _PPM_H_ */
Note: See TracBrowser for help on using the repository browser.