10d163575Sopenharmony_ci/* 20d163575Sopenharmony_ci * Copyright (c) 2021-2021 Huawei Device Co., Ltd. All rights reserved. 30d163575Sopenharmony_ci * 40d163575Sopenharmony_ci * Redistribution and use in source and binary forms, with or without modification, 50d163575Sopenharmony_ci * are permitted provided that the following conditions are met: 60d163575Sopenharmony_ci * 70d163575Sopenharmony_ci * 1. Redistributions of source code must retain the above copyright notice, this list of 80d163575Sopenharmony_ci * conditions and the following disclaimer. 90d163575Sopenharmony_ci * 100d163575Sopenharmony_ci * 2. Redistributions in binary form must reproduce the above copyright notice, this list 110d163575Sopenharmony_ci * of conditions and the following disclaimer in the documentation and/or other materials 120d163575Sopenharmony_ci * provided with the distribution. 130d163575Sopenharmony_ci * 140d163575Sopenharmony_ci * 3. Neither the name of the copyright holder nor the names of its contributors may be used 150d163575Sopenharmony_ci * to endorse or promote products derived from this software without specific prior written 160d163575Sopenharmony_ci * permission. 170d163575Sopenharmony_ci * 180d163575Sopenharmony_ci * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 190d163575Sopenharmony_ci * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 200d163575Sopenharmony_ci * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 210d163575Sopenharmony_ci * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR 220d163575Sopenharmony_ci * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 230d163575Sopenharmony_ci * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 240d163575Sopenharmony_ci * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 250d163575Sopenharmony_ci * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 260d163575Sopenharmony_ci * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 270d163575Sopenharmony_ci * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 280d163575Sopenharmony_ci * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 290d163575Sopenharmony_ci */ 300d163575Sopenharmony_ci 310d163575Sopenharmony_ci#include "fs/mount.h" 320d163575Sopenharmony_ci#include "path_cache.h" 330d163575Sopenharmony_ci#include "vnode.h" 340d163575Sopenharmony_ci#ifdef LOSCFG_DRIVERS_RANDOM 350d163575Sopenharmony_ci#include "hisoc/random.h" 360d163575Sopenharmony_ci#else 370d163575Sopenharmony_ci#include "stdlib.h" 380d163575Sopenharmony_ci#endif 390d163575Sopenharmony_ci 400d163575Sopenharmony_ci#ifdef LOSCFG_MNT_CONTAINER 410d163575Sopenharmony_ci#include "los_mnt_container_pri.h" 420d163575Sopenharmony_cistatic LIST_HEAD *g_mountCache = NULL; 430d163575Sopenharmony_ci#else 440d163575Sopenharmony_cistatic LIST_HEAD *g_mountList = NULL; 450d163575Sopenharmony_ci#endif 460d163575Sopenharmony_ci 470d163575Sopenharmony_cistruct Mount *MountAlloc(struct Vnode *vnodeBeCovered, struct MountOps *fsop) 480d163575Sopenharmony_ci{ 490d163575Sopenharmony_ci struct Mount *mnt = (struct Mount *)zalloc(sizeof(struct Mount)); 500d163575Sopenharmony_ci if (mnt == NULL) { 510d163575Sopenharmony_ci PRINT_ERR("MountAlloc failed no memory!\n"); 520d163575Sopenharmony_ci return NULL; 530d163575Sopenharmony_ci } 540d163575Sopenharmony_ci 550d163575Sopenharmony_ci LOS_ListInit(&mnt->activeVnodeList); 560d163575Sopenharmony_ci LOS_ListInit(&mnt->vnodeList); 570d163575Sopenharmony_ci 580d163575Sopenharmony_ci mnt->vnodeBeCovered = vnodeBeCovered; 590d163575Sopenharmony_ci vnodeBeCovered->newMount = mnt; 600d163575Sopenharmony_ci#ifdef LOSCFG_DRIVERS_RANDOM 610d163575Sopenharmony_ci HiRandomHwInit(); 620d163575Sopenharmony_ci (VOID)HiRandomHwGetInteger(&mnt->hashseed); 630d163575Sopenharmony_ci HiRandomHwDeinit(); 640d163575Sopenharmony_ci#else 650d163575Sopenharmony_ci mnt->hashseed = (uint32_t)random(); 660d163575Sopenharmony_ci#endif 670d163575Sopenharmony_ci return mnt; 680d163575Sopenharmony_ci} 690d163575Sopenharmony_ci 700d163575Sopenharmony_ci#ifdef LOSCFG_MNT_CONTAINER 710d163575Sopenharmony_ciLIST_HEAD *GetMountList(void) 720d163575Sopenharmony_ci{ 730d163575Sopenharmony_ci return GetContainerMntList(); 740d163575Sopenharmony_ci} 750d163575Sopenharmony_ci 760d163575Sopenharmony_ciLIST_HEAD *GetMountCache(void) 770d163575Sopenharmony_ci{ 780d163575Sopenharmony_ci if (g_mountCache == NULL) { 790d163575Sopenharmony_ci g_mountCache = zalloc(sizeof(LIST_HEAD)); 800d163575Sopenharmony_ci if (g_mountCache == NULL) { 810d163575Sopenharmony_ci PRINT_ERR("init cache mount list failed, no memory."); 820d163575Sopenharmony_ci return NULL; 830d163575Sopenharmony_ci } 840d163575Sopenharmony_ci LOS_ListInit(g_mountCache); 850d163575Sopenharmony_ci } 860d163575Sopenharmony_ci return g_mountCache; 870d163575Sopenharmony_ci} 880d163575Sopenharmony_ci#else 890d163575Sopenharmony_ciLIST_HEAD* GetMountList(void) 900d163575Sopenharmony_ci{ 910d163575Sopenharmony_ci if (g_mountList == NULL) { 920d163575Sopenharmony_ci g_mountList = zalloc(sizeof(LIST_HEAD)); 930d163575Sopenharmony_ci if (g_mountList == NULL) { 940d163575Sopenharmony_ci PRINT_ERR("init mount list failed, no memory."); 950d163575Sopenharmony_ci return NULL; 960d163575Sopenharmony_ci } 970d163575Sopenharmony_ci LOS_ListInit(g_mountList); 980d163575Sopenharmony_ci } 990d163575Sopenharmony_ci return g_mountList; 1000d163575Sopenharmony_ci} 1010d163575Sopenharmony_ci#endif 102