los_config.c 8.6 KB
Newer Older
1
/*
2 3
 * Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
 * Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
 *
 * 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.
 */

#include "los_config.h"
#include "stdio.h"
34 35 36 37 38 39 40
#include "string.h"
#include "gic_common.h"
#include "los_atomic.h"
#include "los_exc_pri.h"
#include "los_hwi_pri.h"
#include "los_hw_tick_pri.h"
#include "los_init_pri.h"
41
#include "los_memory_pri.h"
42
#include "los_mp.h"
43
#include "los_mux_pri.h"
44 45
#include "los_printf.h"
#include "los_process_pri.h"
46
#include "los_queue_pri.h"
47
#include "los_sem_pri.h"
48
#include "los_spinlock.h"
49 50
#include "los_swtmr_pri.h"
#include "los_task_pri.h"
51
#include "los_sched_pri.h"
52
#include "los_tick.h"
53
#include "los_vm_boot.h"
54
#include "los_smp.h"
55 56 57
#ifdef LOSCFG_ENABLE_KERNEL_TEST
#include "los_test_pri.h"
#endif
58

59
STATIC SystemRebootFunc g_rebootHook = NULL;///< 系统重启钩子函数
60
/// 设置系统重启钩子函数
61 62 63 64
VOID OsSetRebootHook(SystemRebootFunc func)
{
    g_rebootHook = func;
}
65
///获取系统重启钩子函数
66 67 68 69
SystemRebootFunc OsGetRebootHook(VOID)
{
    return g_rebootHook;
}
70

71 72
LITE_OS_SEC_TEXT_INIT STATIC UINT32 EarliestInit(VOID)
{
73 74 75
    /* Must be placed at the beginning of the boot process *///必须放在启动过程的开头
    OsSetMainTask();//为每个CPU核设置临时主任务
    OsCurrTaskSet(OsGetMainTask());//设置当前任务
76
    OsSchedRunQueInit();
77

78 79
    g_sysClock = OS_SYS_CLOCK;
    g_tickPerSecond =  LOSCFG_BASE_CORE_TICK_PER_SECOND;
80

81 82
    return LOS_OK;
}
83

84 85
LITE_OS_SEC_TEXT_INIT STATIC UINT32 ArchEarlyInit(VOID)
{
86
    UINT32 ret;
87

88 89 90
    /* set system counter freq */
#ifndef LOSCFG_TEE_ENABLE
    HalClockFreqWrite(OS_SYS_CLOCK);
91 92
#endif

93
#ifdef LOSCFG_PLATFORM_HWI
94
    OsHwiInit();
95 96
#endif

97
    OsExcInit();
98

99 100 101 102 103
    ret = OsTickInit(g_sysClock, LOSCFG_BASE_CORE_TICK_PER_SECOND);
    if (ret != LOS_OK) {
        PRINT_ERR("OsTickInit error!\n");
        return ret;
    }
104

105
    return LOS_OK;
106 107
}

108
LITE_OS_SEC_TEXT_INIT STATIC UINT32 PlatformEarlyInit(VOID)
109
{
110 111 112
#if defined(LOSCFG_PLATFORM_UART_WITHOUT_VFS) && defined(LOSCFG_DRIVERS)
    uart_init();
#endif /* LOSCFG_PLATFORM_UART_WITHOUT_VFS */
113

114
    return LOS_OK;
115 116 117 118 119
}

LITE_OS_SEC_TEXT_INIT STATIC UINT32 OsIpcInit(VOID)
{
    UINT32 ret;
120

121
#ifdef LOSCFG_BASE_IPC_SEM
122
    ret = OsSemInit();
123
    if (ret != LOS_OK) {
124
        PRINT_ERR("OsSemInit error\n");
125 126 127 128
        return ret;
    }
#endif

129
#ifdef LOSCFG_BASE_IPC_QUEUE
130
    ret = OsQueueInit();
131
    if (ret != LOS_OK) {
132
        PRINT_ERR("OsQueueInit error\n");
133 134 135 136 137 138
        return ret;
    }
#endif
    return LOS_OK;
}

139
LITE_OS_SEC_TEXT_INIT STATIC UINT32 ArchInit(VOID)
140
{
141 142
#ifdef LOSCFG_KERNEL_MMU
    OsArchMmuInitPerCPU();
143
#endif
144 145
    return LOS_OK;
}
146

147
LITE_OS_SEC_TEXT_INIT STATIC UINT32 PlatformInit(VOID)
148
{
149
    return LOS_OK;
150 151
}

152
LITE_OS_SEC_TEXT_INIT STATIC UINT32 KModInit(VOID)
153
{
154
#ifdef LOSCFG_BASE_CORE_SWTMR_ENABLE
155
    OsSwtmrInit();
156
#endif
157 158 159
    return LOS_OK;
}

160 161 162 163 164 165 166 167 168 169
LITE_OS_SEC_TEXT_INIT VOID OsSystemInfo(VOID)
{
#ifdef LOSCFG_DEBUG_VERSION
    const CHAR *buildType = "debug";
#else
    const CHAR *buildType = "release";
#endif /* LOSCFG_DEBUG_VERSION */

    PRINT_RELEASE("\n******************Welcome******************\n\n"
                  "Processor   : %s"
170
#ifdef LOSCFG_KERNEL_SMP
171 172 173 174 175 176 177 178 179 180 181
                  " * %d\n"
                  "Run Mode    : SMP\n"
#else
                  "\n"
                  "Run Mode    : UP\n"
#endif
                  "GIC Rev     : %s\n"
                  "build time  : %s %s\n"
                  "Kernel      : %s %d.%d.%d.%d/%s\n"
                  "\n*******************************************\n",
                  LOS_CpuInfo(),
182
#ifdef LOSCFG_KERNEL_SMP
183 184 185 186 187
                  LOSCFG_KERNEL_SMP_CORE_NUM,
#endif
                  HalIrqVersion(), __DATE__, __TIME__,\
                  KERNEL_NAME, KERNEL_MAJOR, KERNEL_MINOR, KERNEL_PATCH, KERNEL_ITRE, buildType);
}
188
///由汇编调用,鸿蒙C语言层级的入口点 
189 190 191
LITE_OS_SEC_TEXT_INIT INT32 OsMain(VOID)
{
    UINT32 ret;
192 193
#ifdef LOS_INIT_STATISTICS
    UINT64 startNsec, endNsec, durationUsec;
194 195
#endif

196
    ret = EarliestInit();//鸿蒙初开,天地混沌
197 198 199
    if (ret != LOS_OK) {
        return ret;
    }
200
    OsInitCall(LOS_INIT_LEVEL_EARLIEST);
201

202
    ret = ArchEarlyInit();
203 204 205
    if (ret != LOS_OK) {
        return ret;
    }
206
    OsInitCall(LOS_INIT_LEVEL_ARCH_EARLY);
207

208
    ret = PlatformEarlyInit();
209 210 211
    if (ret != LOS_OK) {
        return ret;
    }
212
    OsInitCall(LOS_INIT_LEVEL_PLATFORM_EARLY);
213

214 215
    /* system and chip info */
    OsSystemInfo();
216

217
    PRINT_RELEASE("\nmain core booting up...\n");
218

219 220
#ifdef LOS_INIT_STATISTICS
    startNsec = LOS_CurrNanosec();
221
#endif
222

223
    ret = OsTaskInit();//任务池初始化
224 225 226 227
    if (ret != LOS_OK) {
        return ret;
    }

228
    OsInitCall(LOS_INIT_LEVEL_KMOD_PREVM);
229

230
    ret = OsSysMemInit();//系统内存初始化
231 232 233
    if (ret != LOS_OK) {
        return ret;
    }
234

235
    OsInitCall(LOS_INIT_LEVEL_VM_COMPLETE);
236

237
    ret = OsIpcInit();//进程间通讯模块初始化
238 239 240 241
    if (ret != LOS_OK) {
        return ret;
    }

242
    ret = OsSystemProcessCreate();//创建系统进程 
243 244 245 246
    if (ret != LOS_OK) {
        return ret;
    }

247
    ret = ArchInit();	//MMU架构初始化
248 249 250
    if (ret != LOS_OK) {
        return ret;
    }
251
    OsInitCall(LOS_INIT_LEVEL_ARCH);
252

253
    ret = PlatformInit();
254 255 256
    if (ret != LOS_OK) {
        return ret;
    }
257
    OsInitCall(LOS_INIT_LEVEL_PLATFORM);
258

259
    ret = KModInit();
260 261 262 263
    if (ret != LOS_OK) {
        return ret;
    }

264 265 266 267
    OsInitCall(LOS_INIT_LEVEL_KMOD_BASIC);

    OsInitCall(LOS_INIT_LEVEL_KMOD_EXTENDED);

268
#ifdef LOSCFG_KERNEL_SMP
269
    OsSmpInit();
270 271
#endif

272 273 274 275 276 277
    OsInitCall(LOS_INIT_LEVEL_KMOD_TASK);

#ifdef LOS_INIT_STATISTICS
    endNsec = LOS_CurrNanosec();
    durationUsec = (endNsec - startNsec) / OS_SYS_NS_PER_US;
    PRINTK("The main core takes %lluus to start.\n", durationUsec);
278
#endif
279 280 281

    return LOS_OK;
}
282

283 284 285 286 287
#ifndef LOSCFG_PLATFORM_ADAPT
STATIC VOID SystemInit(VOID)
{
    PRINTK("dummy: *** %s ***\n", __FUNCTION__);
}
288 289
#else
extern VOID SystemInit(VOID);
290
#endif
291
///创建系统初始任务并申请调度
292 293 294 295 296 297
STATIC UINT32 OsSystemInitTaskCreate(VOID)
{
    UINT32 taskID;
    TSK_INIT_PARAM_S sysTask;

    (VOID)memset_s(&sysTask, sizeof(TSK_INIT_PARAM_S), 0, sizeof(TSK_INIT_PARAM_S));
298
#ifndef LOSCFG_ENABLE_KERNEL_TEST
299
    sysTask.pfnTaskEntry = (TSK_ENTRY_FUNC)SystemInit;
300 301 302
#else
    sysTask.pfnTaskEntry = (TSK_ENTRY_FUNC)TestSystemInit;
#endif
303
    sysTask.uwStackSize = LOSCFG_BASE_CORE_TSK_DEFAULT_STACK_SIZE;
304
    sysTask.pcName = "SystemInit";
305 306
    sysTask.usTaskPrio = LOSCFG_BASE_CORE_TSK_DEFAULT_PRIO;
    sysTask.uwResved = LOS_TASK_STATUS_DETACHED;
307
#ifdef LOSCFG_KERNEL_SMP
308
    sysTask.usCpuAffiMask = CPUID_TO_AFFI_MASK(ArchCurrCpuid());
309
#endif
310
    return LOS_TaskCreate(&taskID, &sysTask);
311 312
}

313
//系统任务初始化
314
STATIC UINT32 OsSystemInit(VOID)
315 316
{
    UINT32 ret;
317 318

    ret = OsSystemInitTaskCreate();
319 320 321 322 323 324 325
    if (ret != LOS_OK) {
        return ret;
    }

    return 0;
}

326
LOS_MODULE_INIT(OsSystemInit, LOS_INIT_LEVEL_KMOD_TASK);//模块初始化