linux0.11源代码电梯算法解析

在看linux0.11代码里面的电梯算法的时候,产生了一些疑惑,经过分析解决了,发现网上也有不少讨论,我自己的分析记录下来。

00017 int file_read(struct m_inode * inode, struct file * filp, char * buf, int count)
00018 {
00019     int left,chars,nr;
00020     struct buffer_head * bh;
00021 
00022     if ((left=count)<=0)
00023         return 0;
00024     while (left) {
00025         if ((nr = bmap(inode,(filp->f_pos)/BLOCK_SIZE))) {
00026             if (!(bh=bread(inode->i_dev,nr)))
00027                 break;
00028         } else
00029             bh = NULL;
00030         nr = filp->f_pos % BLOCK_SIZE;
00031         chars = MIN( BLOCK_SIZE-nr , left );
00032         filp->f_pos += chars;
00033         left -= chars;
00034         if (bh) {
00035             char * p = nr + bh->b_data;
00036             while (chars-->0)
00037                 put_fs_byte(*(p++),buf++);
00038             brelse(bh);
00039         } else {
00040             while (chars-->0)
00041                 put_fs_byte(0,buf++);
00042         }
00043     }
00044     inode->i_atime = CURRENT_TIME;
00045     return (count-left)?(count-left):-ERROR;
00046 }


00270 struct buffer_head * bread(int dev,int block)
00271 {
00272     struct buffer_head * bh;
00273 
00274     if (!(bh=getblk(dev,block)))
00275         panic("bread: getblk returned NULL\n");
00276     if (bh->b_uptodate)
00277         return bh;
00278     ll_rw_block(READ,bh);
00279     wait_on_buffer(bh);
00280     if (bh->b_uptodate)
00281         return bh;
00282     brelse(bh);
00283     return NULL;
00284 }

00145 void ll_rw_block(int rw, struct buffer_head * bh)
00146 {
00147     unsigned int major;
00148 
00149     if ((major=MAJOR(bh->b_dev)) >= NR_BLK_DEV ||
00150     !(blk_dev[major].request_fn)) {
00151         printk("Trying to read nonexistent block-device\n\r");
00152         return;
00153     }
00154     make_request(major,rw,bh);
00155 }

00088 static void make_request(int major,int rw, struct buffer_head * bh)
00089 {
00090     struct request * req;
00091     int rw_ahead;
00092 
00093 /* WRITEA/READA is special case - it is not really needed, so if the */
00094 /* buffer is locked, we just forget about it, else it's a normal read */
00095     if ((rw_ahead = (rw == READA || rw == WRITEA))) {
00096     
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 《Linux 0.11内核完全解析》是一本介绍Linux 0.11内核的书籍,内容详尽地解析Linux 0.11内核的设计和实现原理。 首先,书籍介绍了Linux 0.11内核的历史背景和发展过程。Linux 0.11内核是Linux早期版本中的一种,由于其简洁、高效的设计而受到广泛关注。 接着,书籍着重解析Linux 0.11内核的架构和核心组件。包括内存管理、进程管理、文件系统等模块,为读者提供了详尽的API和数据结构说明,使读者可以深入理解内核的运作原理。 此外,书籍还详细介绍了Linux 0.11内核的系统调用和设备驱动。系统调用是用户程序与内核之间的接口,书籍列举了Linux 0.11内核支持的各种系统调用,并给出了具体的调用过程和参数传递方式。设备驱动则涉及与硬件设备的交互,书籍对Linux 0.11内核中常见的设备驱动进行了解析和实例讲解。 最后,书籍还介绍了Linux 0.11内核的调试和性能优化技巧。通过学习这些技巧,读者可以更好地理解内核的运行机制,并能够在实际项目中进行问题排查和性能优化。 《Linux 0.11内核完全解析》全面而深入地解析Linux 0.11内核的各个方面,适合对操作系统和内核开发有兴趣的读者阅读。阅读本书后,读者将对Linux 0.11内核有更深入的理解,并能够应用这些知识进行内核开发和调试工作。 ### 回答2: 《Linux 0.11内核完全解析》是一本详细介绍Linux 0.11内核的书籍。Linux 0.11Linux操作系统的早期版本,具有重要的历史和技术价值。这本书对Linux 0.11内核的设计思想、代码结构、系统调用、进程管理、内存管理、文件系统、设备驱动等方面进行了全面深入的讲解和解析。 首先,这本书对Linux 0.11内核的设计思想进行了详细的介绍。它解析Linux 0.11内核的设计理念,包括分层结构、模块化设计、中断处理、进程管理等方面。通过解析设计思想,读者可以了解到Linux 0.11内核的基本原理和设计哲学。 其次,这本书还深入解析Linux 0.11内核的代码结构。它逐行解读了内核的关键代码,包括启动代码、中断处理程序、进程管理代码等。通过阅读和理解内核代码,读者可以了解到Linux 0.11内核的运行机制和内部实现。 此外,这本书还对Linux 0.11内核的系统调用、进程管理、内存管理、文件系统、设备驱动等方面进行了详细的解析。它介绍了系统调用的处理过程、进程管理的算法、内存管理的策略、文件系统的结构和操作、设备驱动的注册和使用等。通过全面解析这些关键功能,读者可以深入了解到Linux 0.11内核的核心功能和实现细节。 总之,《Linux 0.11内核完全解析》是一本全面深入解析Linux 0.11内核的书籍。通过阅读这本书,读者可以了解到Linux 0.11内核的设计思想、代码结构、系统调用、进程管理、内存管理、文件系统、设备驱动等方面的内容。这对于理解早期Linux的发展历程、了解操作系统的原理和学习内核开发都具有重要的参考价值。 ### 回答3: 《Linux 0.11内核完全解析》是一本关于分析Linux 0.11内核的书籍。该书主要分析了Linux 0.11内核的结构、原理和实现细节。 首先,书籍详细介绍了Linux 0.11内核的组成结构。它由一个基本的多任务、分时操作系统构成,包括进程管理、内存管理、文件系统、设备驱动等基本模块。书中对这些模块的实现细节进行了解析,帮助读者理解Linux内核的整体结构。 其次,书中深入分析了Linux 0.11内核的原理。它详细讲解了Linux内核的各个部分是如何协作的,包括进程调度、内存管理、文件系统访问等。通过深入理解Linux内核的原理,读者可以更好地理解操作系统的工作原理,并能够在需要时进行相应的调整和优化。 最后,书中还介绍了Linux 0.11内核的实现细节。它深入解析了内核源代码,讲解了内核代码中的关键部分和数据结构。通过对内核代码的深入分析,读者不仅可以了解Linux内核的具体实现方式,还可以学习到一些编程技巧和设计原则。 综上所述,《Linux 0.11内核完全解析》这本书详细介绍了Linux 0.11内核的结构、原理和实现细节,是一本帮助读者深入了解和学习Linux内核的重要参考书籍。通过阅读该书,读者可以提升对操作系统的理解和编程能力,进一步掌握和应用Linux内核的相关知识。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值