热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

系统启动理解兴趣篇

电脑是如何启动的?为什么电脑断电后系统时间任然在走,短时间内启动电脑后系统时间不会发生偏差?远程开机是如何实现的?为什么电脑

        电脑是如何启动的?为什么电脑断电后系统时间任然在走,短时间内启动电脑后系统时间不会发生偏差?远程开机是如何实现的?为什么电脑操作系统比手机占用更多的内存?为什么电脑没有采用运算速度更快的哈佛结构,一如既往的采用冯诺依曼机构?……最近接触到一些嵌入式linix系统中的裸机程序,对它的执行过程引发了许多思考。

       对于BIOS大家都不陌生,最常用的功能是在装系统时配置启动项,是从U盘启动还是硬盘启动还是其他。其实BIOS功能远不止这些,它包含着系统的基本信息设定,上电自检,系统启动项等内容,一个有意思的设定是它可以改变电脑开机的方式,如按键盘任意键开机,鼠标点击开机,定时自启等,如果主板与网卡支持,还可以设计远程开机。

       难以想象,未来的家用电器如果配置了远程网络功能,可以实现开关机的话,下班乘公交车的时候用手机打开家里的电饭锅,回到家就可以直接享受刚出锅的晚餐了。

了解了BIOS就能够对电脑从按下电源键开始到桌面化系统启动这段时间都发生了什么,下面从嵌入式系统的boot loader 工作过程简单理解一个处理器是如何启动的(它与BIOS的工作原理惊人的相似)。

简介


了解这些首先要理解一些相关概念。一个系统的组成包括软件系统和硬件系统。




                          


         为什么嵌入式采用的Linix操作系统要比PC机采用的Windows操作系统在内存上小出那么多?其实,无论是哪一个系统都是由内核与接口程序,驱动程序(驱动硬件操作),它是操作系统的基础。像现在的手机操作系统都是通过改编开放的Linix系统内核加上必要的接口程序驱动程序得到的。嵌入式所要求的操作系统功能并不是非常全面,它往往是针对某一个具体的功能而设计的,则系统并不需要加入所有的驱动程序,以够用为原则。而Windows操作系统为适应不同的CPU,主板等不同硬件的需要,而且要实现多功能操作,势必引入的接口,驱动程序要多出很多了。

       Boot loader与BIOS的功能相似,是一段占用4k的启动代码,它最初存在于Norflash中(就像电脑硬盘)。

       Norflash与Nandflash都是一种存储介质,Norflash比Nandflash存储容量小,访问速度快。

       哈佛结构与冯诺依曼结构对比,冯诺依曼结构只有在上一条指令执行完成后才能执行下一条,依次顺序执行,哈佛结构在执行第一条指令的译码工作时,第二条指令就可以同步执行取指令操作了。电脑采用但由于电脑的晶振比手机大的多,所以并没有感觉电脑比手机慢。

                                         

                       

工作

      在2410中存在一块SRAM(相当于CPU中存在一块4k内存,存放执行数据),boot loader从Nandflash中读出boot loader到SDRAM中,然后送回到2410处理器中处理数据(因为内存中的SRAM只有4k相当小,如果是小程序直接烧写到这里可直接执行)。

    

        Bootloader中含有一组启动的代码init.s(用汇编编写为.s文件,但往往启动代码是由汇编与c语言混合编写的)它的具体流程如下:

 

1.      关闭看门狗。程序一旦开始执行,看门狗定时器就开始计时,如果一个程序一段时间后不给定时器一个信号的话,看门狗数据溢出,自动复位。

2.      中断是硬件执行的基本操作。程序执行过程中收到外来打扰就会响应中断执行外部程序。

3.      时钟为所有的工作提供一个统一的信号,就像运动员在喊口令一样,保持协调一致,只有这样才不会造成各个程序之间的混乱

4.      RAM存储器在断电后都会清空

5.      波特率是串口的传输速率,电脑主机接显示屏的线就是一个串口线。校验位负责检验是否系统启动是否出错,寄存器负责记录当前工作状态的地址,暂存待处理数据等功能。

6.      设置堆栈指针,指针主要应对c程序。比方说程序在开始启动时执行汇编指令,突然接到中断后转到其他地址去执行指令,此时的地址要保存到堆栈中保护起来,等到中断执行完毕,又返回来执行现有程序,必须要从堆栈中获取当前地址。

总结

        对比软件编程与驱动硬件的编程,其语法结构都是一样的,无外乎顺序,选择,循环结构。但基于硬件的编程必须要考虑到硬件寄存器端口地址,每个处理器中的寄存器地址都代表着不同的地址,造成程序编写过程中必须要查表才能对实现具体的操作。而软件中的每一个控件都是由自己命名的,大大简化了操作过程。
       对机器执行程序的理解:最初的计算机语言都是机器语言,用到的都是0和1,难以记忆。后逐渐发展的汇编,高级语言被大众所接受,经过专门的编译器编译生成二进制文件。在执行过程中调入内存中,每一个内存单元都有一个特定的地址。CPU通过寻址的方式发现这些被编译的0和1被电脑所识别,执行。
       就好比驱动程序,如果不是专门的驱动程序师编译出来的驱动往往都是不稳定的。只有清晰的理解了内部架构才能编写出出色的硬件程序,这应该就是硬件编程困难的原因吧。
(如有错误,还望大神前来扶正)


推荐阅读
  • 如何高效学习鸿蒙操作系统:开发者指南
    本文探讨了开发者如何更有效地学习鸿蒙操作系统,提供了来自行业专家的建议,包括系统化学习方法、职业规划建议以及具体的开发技巧。 ... [详细]
  • 为何Compose与Swarm之后仍有Kubernetes的诞生?
    探讨在已有Compose和Swarm的情况下,Kubernetes是如何以其独特的设计理念和技术优势脱颖而出,成为容器编排领域的领航者。 ... [详细]
  • 雨林木风 GHOST XP SP3 经典珍藏版 YN2014.04
    雨林木风 GHOST XP SP3 经典珍藏版 YN2014.04 ... [详细]
  • 本文详细介绍了PHP中的几种超全局变量,包括$GLOBAL、$_SERVER、$_POST、$_GET等,并探讨了AJAX的工作原理及其优缺点。通过具体示例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 本文探讨了使用Python实现监控信息收集的方法,涵盖从基础的日志记录到复杂的系统运维解决方案,旨在帮助开发者和运维人员提升工作效率。 ... [详细]
  • 服务器虚拟化存储设计,完美规划储存与资源,部署高性能虚拟化桌面
    规划部署虚拟桌面环境前,必须先估算目前所使用实体桌面环境的工作负载与IOPS性能,并慎选储存设备。唯有谨慎估算贴近实际的IOPS性能,才能 ... [详细]
  • 吴石访谈:腾讯安全科恩实验室如何引领物联网安全研究
    腾讯安全科恩实验室曾两次成功破解特斯拉自动驾驶系统,并远程控制汽车,展示了其在汽车安全领域的强大实力。近日,该实验室负责人吴石接受了InfoQ的专访,详细介绍了团队未来的重点方向——物联网安全。 ... [详细]
  • Docker安全策略与管理
    本文探讨了Docker的安全挑战、核心安全特性及其管理策略,旨在帮助读者深入理解Docker安全机制,并提供实用的安全管理建议。 ... [详细]
  • 2023年,Android开发前景如何?25岁还能转行吗?
    近期,关于Android开发行业的讨论在多个平台上热度不减,许多人担忧其未来发展。本文将探讨当前Android开发市场的现状、薪资水平及职业选择建议。 ... [详细]
  • 流处理中的计数挑战与解决方案
    本文探讨了在流处理中进行计数的各种技术和挑战,并基于作者在2016年圣何塞举行的Hadoop World大会上的演讲进行了深入分析。文章不仅介绍了传统批处理和Lambda架构的局限性,还详细探讨了流处理架构的优势及其在现代大数据应用中的重要作用。 ... [详细]
  • 最适合初学者的编程语言
    本文探讨了适合编程新手的最佳语言选择,包括Python、JavaScript等易于上手且功能强大的语言,以及如何通过有效的学习方法提高编程技能。 ... [详细]
  • 在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
  • 调试利器SSH隧道
    在开发微信公众号或小程序的时候,由于微信平台规则的限制,部分接口需要通过线上域名才能正常访问。但我们一般都会在本地开发,因为这能快速的看到 ... [详细]
  • 本文介绍了在Linux环境下如何有效返回命令行状态、上一级目录及快速查找头文件和函数定义的方法。包括处理长时间运行命令、编辑器退出技巧、目录导航以及文件搜索策略。 ... [详细]
  • 深入解析WebP图片格式及其应用
    随着互联网技术的发展,无论是PC端还是移动端,图片数据流量占据了很大比重。尤其在高分辨率屏幕普及的背景下,如何在保证图片质量的同时减少文件大小,成为了亟待解决的问题。本文将详细介绍Google推出的WebP图片格式,探讨其在实际项目中的应用及优化策略。 ... [详细]
author-avatar
28划生12_928
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有