多核初始化过程

2024-05-13 04:38
文章标签 过程 初始化 多核

本文主要是介绍多核初始化过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

平台介绍:

loongson3A-4核cpu(mips架构),vxWorks6.8

多核cpu启动时,刚开始时是cpu0在运行,后面才会初始化其他三个核,这里就说一些其他三个核的初始化过程。

函数调用关系:

usrRoot-->usrSmpInit-->usrEnableCpu-->kernelCpuEnableInternal-->vxCpuStateInit

kernelCpuEnableInternal-->sysCpuEnable-->sysCpuStart-->godson3_cpu_start-->sysCpuInit-->kernelCpuEntry-->idleTask

在这些函数调用完了之后呢,其他三个核就进入了一个可使用状态。

现在呢咱们一步一步分析一下这个初始化的过程:

void usrSmpInit (void){
/*这里挂接cpu调度的中断函数,并使能。主要用于核间通信*/if ((vxIpiConnect (IPI_INTR_ID_SCHED,(IPI_HANDLER_FUNC) windRescheduleNotify,NULL) == ERROR) ||vxIpiEnable (IPI_INTR_ID_SCHED) == ERROR)){return;}
/*使能cpu*/usrEnableCpu();}

LOCAL void usrEnableCpu (void){UINT cpu;UINT numCpus = vxCpuConfiguredGet (); /*获取配置的cpu的个数*/cpuset_t enabledCpus;ULONG timeoutTicks, timeoutStart, currentTickCount;CPUSET_ZERO (enabledCpus);
/*cpu0已经run起来了,先记录cpu0*/    CPUSET_SET (enabledCpus, 0);	/*设置超时时间*/vxCpuEnableTimeout = VX_ENABLE_CPU_TIMEOUT;timeoutTicks = vxCpuEnableTimeout * sysClkRateGet ();
/*对多核cpu进行使能*/for (cpu = 1; cpu < numCpus; cpu++){if (kernelCpuEnableInternal (cpu) == ERROR){}elseCPUSET_SET (enabledCpus, cpu);}timeoutStart = vxAbsTicksGet ();
/*如果没有使能就等待*/  do{currentTickCount = vxAbsTicksGet ();if ((currentTickCount - timeoutStart) > timeoutTicks){for ( cpu = 1 ; cpu < numCpus ; cpu ++){if (!CPUS

这篇关于多核初始化过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/984702

相关文章

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现