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