/* * Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved. * Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, this list * of conditions and the following disclaimer in the documentation and/or other materials * provided with the distribution. * * 3. Neither the name of the copyright holder nor the names of its contributors may be used * to endorse or promote products derived from this software without specific prior written * permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /** * @defgroup los_vm_filemap vm filemap definition * @ingroup kernel */ #ifndef __LOS_VM_FILEMAP_H__ #define __LOS_VM_FILEMAP_H__ #ifdef LOSCFG_FS_VFS #include "fs/file.h" #endif #include "los_vm_map.h" #include "los_vm_page.h" #include "los_vm_common.h" #include "los_vm_phys.h" #ifdef __cplusplus #if __cplusplus extern "C" { #endif /* __cplusplus */ #endif /* __cplusplus */ typedef struct FilePage { LOS_DL_LIST node; LOS_DL_LIST lru; LOS_DL_LIST i_mmap; /* list of mappings */ UINT32 n_maps; /* num of mapping */ struct VmPhysSeg *physSeg; /* physical memory that file page belongs to */ struct VmPage *vmPage; struct page_mapping *mapping; VM_OFFSET_T pgoff; UINT32 flags; UINT16 dirtyOff; UINT16 dirtyEnd; } LosFilePage; typedef struct MapInfo { LOS_DL_LIST node; VADDR_T vaddr; LosFilePage *page; LosArchMmu *archMmu; } LosMapInfo; enum OsPageFlags { FILE_PAGE_FREE, FILE_PAGE_LOCKED, FILE_PAGE_REFERENCED, FILE_PAGE_DIRTY, FILE_PAGE_LRU, FILE_PAGE_ACTIVE, FILE_PAGE_SHARED, }; #define PGOFF_MAX 2000 #define MAX_SHRINK_PAGECACHE_TRY 2 #define VM_FILEMAP_MAX_SCAN (SYS_MEM_SIZE_DEFAULT >> PAGE_SHIFT) #define VM_FILEMAP_MIN_SCAN 32 STATIC INLINE VOID OsSetPageLocked(LosVmPage *page) { LOS_BitmapSet(&page->flags, FILE_PAGE_LOCKED); } STATIC INLINE VOID OsCleanPageLocked(LosVmPage *page) { LOS_BitmapClr(&page->flags, FILE_PAGE_LOCKED); } STATIC INLINE VOID OsSetPageDirty(LosVmPage *page) { LOS_BitmapSet(&page->flags, FILE_PAGE_DIRTY); } STATIC INLINE VOID OsCleanPageDirty(LosVmPage *page) { LOS_BitmapClr(&page->flags, FILE_PAGE_DIRTY); } STATIC INLINE VOID OsSetPageActive(LosVmPage *page) { LOS_BitmapSet(&page->flags, FILE_PAGE_ACTIVE); } STATIC INLINE VOID OsCleanPageActive(LosVmPage *page) { LOS_BitmapClr(&page->flags, FILE_PAGE_ACTIVE); } STATIC INLINE VOID OsSetPageLRU(LosVmPage *page) { LOS_BitmapSet(&page->flags, FILE_PAGE_LRU); } STATIC INLINE VOID OsSetPageFree(LosVmPage *page) { LOS_BitmapSet(&page->flags, FILE_PAGE_FREE); } STATIC INLINE VOID OsCleanPageFree(LosVmPage *page) { LOS_BitmapClr(&page->flags, FILE_PAGE_FREE); } STATIC INLINE VOID OsSetPageReferenced(LosVmPage *page) { LOS_BitmapSet(&page->flags, FILE_PAGE_REFERENCED); } STATIC INLINE VOID OsCleanPageReferenced(LosVmPage *page) { LOS_BitmapClr(&page->flags, FILE_PAGE_REFERENCED); } STATIC INLINE BOOL OsIsPageActive(LosVmPage *page) { return BIT_GET(page->flags, FILE_PAGE_ACTIVE); } STATIC INLINE BOOL OsIsPageLocked(LosVmPage *page) { return BIT_GET(page->flags, FILE_PAGE_LOCKED); } STATIC INLINE BOOL OsIsPageReferenced(LosVmPage *page) { return BIT_GET(page->flags, FILE_PAGE_REFERENCED); } STATIC INLINE BOOL OsIsPageDirty(LosVmPage *page) { return BIT_GET(page->flags, FILE_PAGE_DIRTY); } STATIC INLINE BOOL OsIsPageMapped(LosFilePage *page) { return (page->n_maps != 0); } /* The follow three functions is used to SHM module */ STATIC INLINE VOID OsSetPageShared(LosVmPage *page) { LOS_BitmapSet(&page->flags, FILE_PAGE_SHARED); } STATIC INLINE VOID OsCleanPageShared(LosVmPage *page) { LOS_BitmapClr(&page->flags, FILE_PAGE_SHARED); } STATIC INLINE BOOL OsIsPageShared(LosVmPage *page) { return BIT_GET(page->flags, FILE_PAGE_SHARED); } typedef struct ProcessCB LosProcessCB; #ifdef LOSCFG_FS_VFS INT32 OsVfsFileMmap(struct file *filep, LosVmMapRegion *region); STATUS_T OsNamedMMap(struct file *filep, LosVmMapRegion *region); VOID OsVmmFileRegionFree(struct file *filep, LosProcessCB *processCB); #endif LosFilePage *OsPageCacheAlloc(struct page_mapping *mapping, VM_OFFSET_T pgoff); LosFilePage *OsFindGetEntry(struct page_mapping *mapping, VM_OFFSET_T pgoff); LosMapInfo *OsGetMapInfo(LosFilePage *page, LosArchMmu *archMmu, VADDR_T vaddr); VOID OsAddMapInfo(LosFilePage *page, LosArchMmu *archMmu, VADDR_T vaddr); VOID OsDelMapInfo(LosVmMapRegion *region, LosVmPgFault *pgFault, BOOL cleanDirty); VOID OsFileCacheFlush(struct page_mapping *mapping); VOID OsFileCacheRemove(struct page_mapping *mapping); VOID OsUnmapPageLocked(LosFilePage *page, LosMapInfo *info); VOID OsUnmapAllLocked(LosFilePage *page); VOID OsLruCacheAdd(LosFilePage *fpage, enum OsLruList lruType); VOID OsLruCacheDel(LosFilePage *fpage); LosFilePage *OsDumpDirtyPage(LosFilePage *oldPage); VOID OsDoFlushDirtyPage(LosFilePage *fpage); VOID OsDeletePageCacheLru(LosFilePage *page); VOID OsPageRefDecNoLock(LosFilePage *page); VOID OsPageRefIncLocked(LosFilePage *page); int OsTryShrinkMemory(size_t nPage); VOID OsMarkPageDirty(LosFilePage *fpage, LosVmMapRegion *region, int off, int len); #ifdef LOSCFG_DEBUG_VERSION VOID ResetPageCacheHitInfo(int *try, int *hit); struct file_map* GetFileMappingList(void); #endif #ifdef __cplusplus #if __cplusplus } #endif /* __cplusplus */ #endif /* __cplusplus */ #endif /* __LOS_VM_FILEMAP_H__ */