⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 读核日记(三).htm

📁 这是我做linux系统初始化过程分析时在网上收集到的资料
💻 HTM
📖 第 1 页 / 共 2 页
字号:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<!-- saved from url=(0049)http://www.heblinux.org/view.php?skin=art&ID=1595 -->
<HTML><HEAD><TITLE>linuxbyte</TITLE>
<META http-equiv=Content-Language content=zh-cn>
<META http-equiv=Content-Type content="text/html; charset=gb2312">
<STYLE type=text/css>A:link {
	COLOR: #000000; TEXT-DECORATION: none
}
A:visited {
	COLOR: #000000; TEXT-DECORATION: none
}
A:hover {
	TEXT-DECORATION: underline
}
BODY {
	FONT-SIZE: 12px; SCROLLBAR-ARROW-COLOR: #395d81; BACKGROUND-COLOR: #ffffff
}
TABLE {
	BORDER-RIGHT: #889093 1px solid; BORDER-TOP: #889093 1px solid; FONT-SIZE: 9pt; BORDER-LEFT: #889093 1px solid; COLOR: #000000; BORDER-BOTTOM: #889093 1px solid
}
TEXTAREA {
	BORDER-RIGHT: #666666 1px solid; BORDER-TOP: #666666 1px solid; FONT-WEIGHT: normal; FONT-SIZE: 12px; BORDER-LEFT: #666666 1px solid; COLOR: #000000; BORDER-BOTTOM: #666666 1px solid; FONT-FAMILY: Verdana, Tahoma, Arial; BACKGROUND-COLOR: #f8f8f8
}
INPUT {
	BORDER-RIGHT: #666666 1px solid; BORDER-TOP: #666666 1px solid; FONT-WEIGHT: normal; FONT-SIZE: 12px; BORDER-LEFT: #666666 1px solid; COLOR: #000000; BORDER-BOTTOM: #666666 1px solid; FONT-FAMILY: Verdana, Tahoma, Arial; BACKGROUND-COLOR: #f8f8f8
}
SELECT {
	FONT-WEIGHT: normal; FONT-SIZE: 12px; COLOR: #000000; FONT-FAMILY: Tahoma, Verdana; BACKGROUND-COLOR: #f8f8f8
}
.nav {
	FONT-WEIGHT: bold; FONT-SIZE: 12px; FONT-FAMILY: Tahoma, Verdana
}
.header {
	FONT-WEIGHT: bold; FONT-SIZE: 11px; COLOR: #ffffff; FONT-FAMILY: Tahoma, Verdana; BACKGROUND-COLOR: #698cc3
}
.category {
	FONT-SIZE: 11px; COLOR: #000000; FONT-FAMILY: Tahoma, Verdana; BACKGROUND-COLOR: #efefef
}
.multi {
	FONT-SIZE: 11px; COLOR: #003366; FONT-FAMILY: Tahoma, Verdana
}
.smalltxt {
	FONT-SIZE: 11px; FONT-FAMILY: Tahoma, Verdana
}
.mediumtxt {
	FONT-SIZE: 12px; COLOR: #000000; FONT-FAMILY: Tahoma, Verdana
}
.bold {
	FONT-WEIGHT: bold
}
</STYLE>
</STYLE>
<META content="MSHTML 6.00.2800.1106" name=GENERATOR></HEAD>
<BODY leftMargin=0 background=读核日记(三).files/bg.gif topMargin=0 rightMargin=0>
<TABLE 
style="BORDER-RIGHT: #656b6d 1px solid; TABLE-LAYOUT: fixed; BORDER-TOP: #656b6d 1px solid; BORDER-LEFT: #656b6d 1px solid; BORDER-BOTTOM: #656b6d 1px solid; WORD-WRAP: break-word" 
cellSpacing=0 cellPadding=0 width="98%" align=center bgColor=#ffffff border=0>
  <TBODY>
  <TR height=0>
    <TD width="25%"></TD>
    <TD width="65%"></TD>
    <TD width="10%"></TD></TR>
  <TR height=26>
    <TD vAlign=center align=right width="100%" 
    background=读核日记(三).files/topbg.jpg colSpan=3>
      <FORM action=search.php method=post><SELECT name=radiobutton> <OPTION 
        value=news selected>-- 新闻搜索 --</OPTION> <OPTION value=articles>-- 文章搜索 
        --</OPTION> <OPTION value=software>-- 软件搜索 --</OPTION></SELECT><INPUT 
      size=15 name=Search> <INPUT type=image src="读核日记(三).files/go.gif" 
      border=0>&nbsp;&nbsp; </FORM></TD></TR>
  <TR>
    <TD align=left width="20%"><IMG src="读核日记(三).files/logo.jpg" border=0></TD>
    <TD align=middle width="60%"><IMG src="读核日记(三).files/logo2.jpg" 
    border=1></TD>
    <TD align=middle width="20%">::<A 
      href="http://www.heblinux.org/news.php">网站新闻</A>::<BR>::<A 
      href="http://www.heblinux.org/articles.php">技术文献</A>::<BR>::<A 
      href="http://www.heblinux.org/softs.php">软件中心</A>::<BR>::<A 
      href="http://www.heblinux.org/bbs/index.php" target=_blank>讨论区</A>:: 
</TD></TR>
  <TR>
    <TD background=读核日记(三).files/tabledi.jpg colSpan=3 height=6></TD></TR>
  <TR>
    <TD background=读核日记(三).files/titlebg.jpg colSpan=3 height=22>
      <CENTER>&nbsp;<B><A href="http://www.heblinux.org/index.php">首页</A></B> || 
      <B><A href="http://www.heblinux.org/bbs/index.php" target=new>讨论区</A></B> 
      || <B><A href="http://www.heblinux.org/news.php">新闻中心</A></B> || <B><A 
      href="http://www.heblinux.org/articles.php">技术文献</A></B> || <B><A 
      href="http://www.heblinux.org/softs.php">软件中心</A></B> || <B><A 
      href="http://www.heblinux.org/about.php">关于本站</A></B> || <B><A 
      href="mailto:oneteam@mail.linuxbyte.net">联系本站</A></B>||</CENTER></TD></TR></TBODY></TABLE>
<TABLE 
style="TABLE-LAYOUT: fixed; BORDER-COLLAPSE: collapse; WORD-WRAP: break-word" 
cellSpacing=0 cellPadding=0 width="98%" align=center bgColor=#ffffff border=1>
  <TBODY>
  <TR><!--第二列-->
    <TD vAlign=top align=left width="75%"><BR>&nbsp;<A 
      href="http://www.heblinux.org/index.php">首页</A>&lt;&lt;&nbsp;<A 
      href="http://www.heblinux.org/articles.php">技术文献</A>&lt;&lt;&nbsp;<B>读核日记(三)</B><BR><BR>
      <UL>&nbsp;&nbsp;&nbsp;&nbsp; <BR><BR><BR>作者:sunmoon (未经许可不得转载) 
        <BR><BR>这几天身体不太好,进展不快.有时候突然发现在拼命的读代码的间隙里,停一会想一想,收获会更大.特别是对于这种非常庞大的系统来说.把握整体的意义尤其重要.随着对linux整体的拆解,我对于整个系统,已经不想开始是那么模糊.好像已经度过了那个极点.不过我也应做好准备,因为一但我对整个细节解读时,肯定也会有同样的经历. 
        <BR>整个linux内核之所以这样艰涩,难懂就在于它的整体性.想我们这样很少写万行以上程序的人来说,它就好像一个庞大的肉球.让你不知道如何下嘴.不过一但咬破.就非常香美了.毕竟,读这么优秀的代码也是一种享受. 
        我个人认为linux 的内核难在这几点: <BR>1,系统庞大,太多的变量,结构, 以及typedef定义的东西不容易找到. 
        <BR>2,作为操作系统,它的函数调用时动态的,读不懂大量的makefile 你根本就不知道这50 
        M的东西是怎么组织起来的,况且,你绝对不可以像跟踪程序一样用debug走一下. <BR>3, 庞大的数据结构,可能是比较简单的运算变得不容易读. 
        因此在读核的初级阶段.我们应该善于想象,善于将不容易理解的部分用伪码的理解方式走过,当我们对大局把握好了,将整个结构拆解清楚了,在读不迟.况且,虽内核本身来说,它所涉及到的运算,结构. 
        本质上和课本上的没有差别.(可惜我不是计算机系毕业的).只不过是内容多了一些罢了. 
        比如说进程调度这一部分,说白了,就是在调用fork()的时候,就产生一task_strut 
        类型的指针,它包含进程调度所用到的一切信息.然后将这个指针插到队列中去就行了,然后cpu 一次总队类中取出指针,分配给他们时间片. 
        而这个指针如何插入呢?说白了就是看它的weight,weight 
        的计算方法,有根据进程类型的不同由不同的算法(实时进程,内核进程,普通进程).好了,这样我们想一下&lt;数据结构中&gt;关于队列的操作,插入,删除,插到队头,置于队尾.再想一下,这些操作如何同操作系统的应用结合在一块.例如;好队进程正在运行,突然,由于一硬件中断.产生一进程,它必须马上处理.系统应把它插入到队头. 
        好了.你可以读一下/usr./src/linux/kenrel/sched.c,不要过那么多全局变量,现在数据结构上走过去,如下面的代码: 
        <BR>static inline void move_last_runqueue(struct task_struct * p) { 
        struct task_struct *next = p-&gt;next_run; struct task_struct *prev = 
        p-&gt;prev_run; <BR>/* remove from list */ next-&gt;prev_run = prev; 
        prev-&gt;next_run = next; /* add back to list */ p-&gt;next_run = 
        &amp;init_task; prev = init_task.prev_run; init_task.prev_run = p; 
        p-&gt;prev_run = prev; prev-&gt;next_run = p; } <BR>static inline void 
        move_first_runqueue(struct task_struct * p) { struct task_struct *next = 
        p-&gt;next_run; struct task_struct *prev = p-&gt;prev_run; <BR>/* remove 
        from list */ next-&gt;prev_run = prev; prev-&gt;next_run = next; /* add 
        back to list */ p-&gt;prev_run = &amp;init_task; next = 
        init_task.next_run; init_task.next_run = p; p-&gt;next_run = next; 
        next-&gt;prev_run = p; } 如果你还不懂,你可能要先,在c语言和数据结构上下一点功夫.其他的模块,我想也是大同小异, 
        不过,也修补会这么简单.如内存管理中用到了好多平衡二叉树的排序,遍历等等.但总的结构时不变的.只要可以通栏全局,在不开定义的情况下,可以读懂全局变量的意思(其实,猜个八九不成问题),看懂是不成问题的.起码我是信心十足. 
        我应该在熟悉一下,计算机专业的软件基础课!! 
        <BR><BR><BR>近来忙得不得了,这时才体会出工作和在学校真的不同.有时候自己想做的事,很难如愿.不过我这一段时间没有太偷懒.对于linux 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -