seL4之hello-2旅途 #

2016/11/19 13:15:38

If you like my blog, please buy me a cup of coffee.

回顾上周

  • seL4运行环境搭建.
  • 完成hell0-1的运行.

补充上周

1.微内核与宏内核有什么不同?####

微内核——用户态提供OS服务,一般采用server-client架构。代表:L4系列微内核

宏内核——内核态提供OS服务,通过syscall结构向用户态提供服务。

出于对seL4的学习,我们比较关注微内核的评价:

  1. 优势:安全性好、可移植性好、灵活性高、容易debug
  2. 劣势:性能低

2.介绍微内核

第一代微内核:

目标是用于解决Unix的可维护性等问题;

代表是CMU的Mach——以失败告终,主要原因是性能不足.

第二代微内核:

目标是解决第一代微内核的性能问题;

代表是LiedtkeL3L4;

主要贡献是通过改进IPC机制,大幅提高了性能,并支持运行Linux,即L4 Linux(虚拟化).

第三代微内核:

目标是解决第二代微内核的安全性问题;

代表是OKL4、seL4

主要贡献是提出enndpoint的IPC机制、基于capability的权限管理机制,提高了安全性.

L4家族简史

图片来源:L4_family_tree

介绍本周

  • 了解seL4的启动流程和初始化线程
  • 了解seL4的几种内核对象和权能机制

来自伊甸一点的温馨提醒:注意本周内容较多,建议分多次练习,并记录下实验结果

1.提供本次必要的实验手册 ###

文件信息


File: C:\Users\PengFei_Zheng\Desktop\欢迎访问伊甸一点.zip
Size: 4260011 bytes
Modified: 2016年11月19日, 14:42:42
MD5: 374FBCC1782185B358BE3DD7D58FFE88
SHA1: 5261FA4259D9976A227EC7EC86B108E86EF5C1EE
CRC32: 21F07023

来自伊甸一点的温馨提醒:请原谅为文件加了密码,需要密码请在下方留言

2.详细介绍实验步骤 ###

0. 查看手册明确实验内容 ####

来自伊甸一点的温馨提示:手册在刚刚下载的文件



1. 初始化hello-2状态 ####

执行命令 make ia32_hello-2_defconfig

运行结果截图:



2. 进入hello-2目录下 ####

  • 执行命令如下图所示:



注意到有一个名字叫做cscope.out的文件.

来自伊甸一点的温馨提醒:这里先不解释它是怎么来的,我们先往下走,之后会和它打交道的

  • 进入文件main.c: gedit main.c

hello-2 的部分main函数代码:



需要做的就是完成当中对TODO1 ~ TODO15的修改.

对于小白的我来说还是有点难度的,开发者很贴心地为我们配上了solution文档.

来自小白的我的温馨提醒:不过还是建议大家先自己尝试完成对代码的阅读和修改,然后通过solution进行对比以及修改.

solution的路径如下所示:



相信大家通过自己的阅读和尝试已经将上述的TODO1~TODO15都修改完成了.

希望大家能够在上述的练习中明白其中调用的函数,以及函数的作用,对于某一个函数来说.我们要做的是明白函数名,函数返回值,函数参数,函数作用,函数处理逻辑.

如果没有按照上面的来学习函数的话,还是重新回到TODO1~TODO15重新看上几遍.

3. 生成hello-2 ####

生成hello-2的指令: make

注意需要在项目的Makefile目录下进行make操作

刚开始执行时的截图:



之行结束的截图:



如果大家在执行上面的时候出现了错误,首先查看报出的错误,根据错误信息进行修改我们的mian.c,一般当main.c中的TODO都按照solution提示完成之后,程序是不会出现错误的。

如果确定main.c没有错误,但是程序依旧报错的话,可以尝试下面操作.

  • 首先执行指令: make ia32_hello-2_defconfig

  • 执行指令: make

伊甸一点给的对比截图:



完成上述操作之后,程序应该就可以成功跑起来了,但是现在我们只是生成了hello-2,还没有运行hello-2

4. 运行hello-2 ####

运行指令如下所示:

qemu-system-i386 -nographic -m 512 -kernel images/kernel-ia32-pc99 -initrd images/hello-2-image-ia32-pc99

来自伊甸一点的温馨提醒:指令有点长,注意不要copy错了

小白的我给的运行部分截图1:



小白的我给的运行部分截图2:



退出模拟器的指令: Ctrl+a 松开之后再按 x


当前时间:2016/11/19 16:15:32

(今天第一次使用markdown,写得好累啊)

如果你喜欢我的博客,please buy me a cup of coffee.

右侧选择打赏.


3.强大的vim+cscope ###

未完待续额...

2016年11月20日09:13:01

1.介绍Cscope ####

From 百度词条

Cscope 是一款开源免费的 C/C++浏览工具,自带一个基于文本的用户界面,通过cscope可以很方便地找到某个函数或变量的定义位置、被调用的位置等信息。Cscope对 C /C++支持较好,也可以自己定制来支持Java和Perl、Python等脚本语言。Vim和gvim都提供了cscope接口,通过适当的配置,可以在Unix/Linux下实现变量、函数、文件等之间跳转,就像Windows下的Source Insight一样灵活易用。由于cscope是开源免费的,而且配合vim可以脱离鼠标,实现全键盘操作,方便快捷地浏览源代码,深受程序员、Geek等人士的喜爱。

From Wikipedia

cscope is a programming tool which works in console mode, text-based interface, that allows computer programmers or software developers to search source code of the programming language C, with some support for C++ and Java. It is often used on very large projects to find source code, functions, declarations, definitions and regular expressions given a text string. cscope is free and released under a BSD license. The original developer of cscope is Joe Steffen.

有兴趣的可以专门了解一下cscope,这里简单介绍如何使用cscope搭配vim来更好地阅读seL4的代码.

这里是cscope的查询界面



这里是cscope的help界面



2.举一个简单例子

通过指令: vim a.cpp 进入vim界面



vim界面示意图如下:



在vim中使用cscope进行查询操作



按F5运行程序:



退出vim,或者另起终端,查看是否生成可执行文件



使用指令 ./a 运行该文件



3.安装cscope以及修改vim配置文件 ####

先介绍到这里,我们来安装一下cscope,以及修改一下vim的配置文件,让大家也可以在vim中玩得更开心玩得更高兴.

由于已经安装过cscope,我这里就不在演示安装截图了,因为之前没有保存下来.

安装指令如下: sudo apt-get install cscope

小白的我温馨提示: 使用指令 ls -a可以查看隐藏的文件

小白的我温馨提示:如果您存在文件.vimrc,有必要先对您的.vimrc文件进行备份

配置文件流程请移步强大的vim配置文件,让编程更随意

好哒,这样就完成对vim配置文件的修改.

通过指令 ls -a 来查看是否成功获取.vimrc文件

上述博客提供两种得到.vimrc的方法

获取配置文件方法1

通过指令touch .vimrc创建空的文件,使用指令 gedit .vimrc进入文件,复制上述博客的代码,保存到创建的.vimrc中即可

获取配置文件方法2

利用上述博客提供的方法

执行指令 wget http://files.cnblogs.com/ma6174/vimrc.zip

再执行指令 unzip -f vimrc.zip -d ~/

4.学习cscope ###

这里不再对vim配置文件进行折腾,想了解更多请移步.

vim主页

强大的vim配置文件,让编程更随意

晒晒我的vimrc配置【不定期更新】

这里不再对cscope的使用做详细讲解,想了解更多请移步.

cscope主页

Vim + Cscope打造Linux下的Source Insight

2016年11月20日10:42:50

转载注意

转载请注明原作者:伊甸一点

转载请以链接形式注明文章地址

seL4之hello-2旅途(完成更新)的更多相关文章

  1. seL4环境配置

      转载声明:希望大家能够从这里收获知识之外,也能够体会到博主撰写博客的辛苦.个人博客势单力薄,对于强转甚至转载博客访问量高于原文的例子不在少数. 希望能够得到大家关注的同时,也能够稍微体谅一下博主的 ...

  2. fedora23没有/var/log/messages &如何禁用后台自动更新软件?

    警告!! Linux是一个非常敏感的操作系统,若删除文件错误,很容易造成系统崩溃. fedora23没有/var/log/messages 不是没有messages这个文件,而是 从 fc core ...

  3. 差旅日志i·长安&北京(更新于8.21_夜)

    大学之时,看到zealer王自如的差旅日志系列欲罢不能,扁平化的管理理念以及轻松的工作氛围,耳目一新的出差体验,抵消了部分不曾走入职场的紧张感甚至是恐惧感.如今初入职场也进入了职业生涯,特记录此次的差 ...

  4. 【原】Android热更新开源项目Tinker源码解析系列之三:so热更新

    本系列将从以下三个方面对Tinker进行源码解析: Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Android热更新开源项目Tinker源码解析系列之二:资源文件热更新 A ...

  5. 使用TSQL查询和更新 JSON 数据

    JSON是一个非常流行的,用于数据交换的文本数据(textual data)格式,主要用于Web和移动应用程序中.JSON 使用“键/值对”(Key:Value pair)存储数据,能够表示嵌套键值对 ...

  6. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  7. 【原】Android热更新开源项目Tinker源码解析系列之二:资源文件热更新

    上一篇文章介绍了Dex文件的热更新流程,本文将会分析Tinker中对资源文件的热更新流程. 同Dex,资源文件的热更新同样包括三个部分:资源补丁生成,资源补丁合成及资源补丁加载. 本系列将从以下三个方 ...

  8. Entity Framework 6 Recipes 2nd Edition 译 -> 目录 -持续更新

    因为看了<Entity Framework 6 Recipes 2nd Edition>这本书前面8章的翻译,感谢china_fucan. 从第九章开始,我是边看边译的,没有通读,加之英语 ...

  9. iOS热更新-8种实现方式

    一.JSPatch 热更新时,从服务器拉去js脚本.理论上可以修改和新建所有的模块,但是不建议这样做. 建议 用来做紧急的小需求和 修复严重的线上bug. 二.lua脚本 比如: wax.热更新时,从 ...

随机推荐

  1. 一种简单的md5加盐加密的方法(防止彩虹表撞库)

    md5加密(或者说摘要算法)大家都很熟悉了 就不解释了 现在很多数据库设计都喜欢用单向加密的方式保存密码,验证时对提交的密码再次加密之后做密文对比 /// <summary> 使用MD5加 ...

  2. Azure 上通过 SendGrid 发送邮件

    SendGrid 是什么? SendGrid 是架构在云端的电子邮件服务,它能提供基于事务的可靠的电子邮件传递. 并且具有可扩充性和实时分析的能力.常见的用例有: 自动回复用户的邮件 定期发送信息给用 ...

  3. Entity Framework 6 Recipes 2nd Edition(11-6)译 -> 从一个”模型定义”函数里返回一个复杂类型

    11-6.从一个”模型定义”函数里返回一个复杂类型 问题 想要从一个”模型定义”函数返回一个复杂类型 解决方案 假设我们有一个病人(patient)和他们访客(visit)的模型,如 Figure 1 ...

  4. iOS开发中静态库之".framework静态库"的制作及使用篇

    iOS开发中静态库之".framework静态库"的制作及使用篇 .framework静态库支持OC和swift .a静态库如何制作可参照上一篇: iOS开发中静态库之" ...

  5. Redis数据结构详解之List(二)

    序言 思来想去感觉redis中的list没什么好写的,如果单写几个命令的操作过于乏味,所以本篇最后我会根据redis中list数据类型的特殊属性,同时对比成熟的消息队列产品rabbitmq,使用red ...

  6. 《JavaScript 源码分析》之 jquery.unobtrusive-ajax.js

    /*! ** Unobtrusive Ajax support library for jQuery ** Copyright (C) Microsoft Corporation. All right ...

  7. 开源Word读写组件DocX 的深入研究和问题总结

    一. 前言 前两天看到了asxinyu大神的[原创]开源Word读写组件DocX介绍与入门,正好我也有类似的自动生成word文档得需求,于是便仔细的研究了这个DocX. 我也把它融入到我的项目当中并进 ...

  8. C++服务器开发之笔记三

    为什么需要原子性操作? 我们考虑一个例子:(1)x++这个常见的运算符在内存中是怎样操作的?从内存中读x的值到寄存器中,对寄存器加1,再把新值写回x所处的内存地址 若是有两个线程同时对同一个变量++, ...

  9. MySQL binlog中的事件类型

    MySQL binlog记录的所有操作实际上都有对应的事件类型的,譬如STATEMENT格式中的DML操作对应的是QUERY_EVENT类型,ROW格式下的DML操作对应的是ROWS_EVENT类型. ...

  10. ORACLE 11gR2 DG(Physical Standby)日常维护02

    环境:RHEL 6.5 + Oracle 11.2.0.4 三.监控DG的状态 3.1监控DG备库的状态 3.2监控主库传输日志链路的状态 四.备库切换为snapshot standby 4.1备库切 ...