![](https://img-blog.csdnimg.cn/20201014180756913.png?x-oss-process=image/resize,m_fixed,h_64,w_64)
kernel
struct task_struct
这个作者很懒,什么都没留下…
展开
-
Linux 内存管理 重要结构体
虚拟内存地址与实际内存地址之间的关系,是如此转换的,逻辑地址-->线性地址-->物理地址。也是从分段单元到分页单元的转换。在linux中,用户程序所使用的地址与硬件使用的物理地址是不等同的。虚拟内存引入一个间接层,它使得许多操作成为可能。在引入虚拟内存这个概念和方法后,在系统中运行的程序可以分配比物理内存更多的内存。而linux的地址有分下面几个类型:用户虚拟地址:用户空间所能看到的常规地转载 2016-09-08 15:48:37 · 642 阅读 · 0 评论 -
linux 内存管理 - paging_init 函数
源码为 2.6.37内核,x86_64架构,内存模型为Sparse Memorypaging_init函数在setup_arch函数中被调用,用于初始化所有节点的pg_data_t结构,以及节点对应的管理区zone结构,和page结构。调用的大致过程为:start_kernel() --> setup_arch() --> paging转载 2016-09-08 15:49:35 · 830 阅读 · 0 评论 -
linux 内存管理 - 分配页面
源码为 2.6.37内核,x86_64架构Linux内核中分配页面使用了以下六个函数:alloc_pages(gfp_mask, order):用这个函数请求2order 个连续的页框。他返回第一个所分配页框描述符的地址,或者如果失败,则返回NULL。alloc_page(gfp_mask):用于获得一个单独页框的宏,它其实只是alloc_p转载 2016-09-08 15:50:31 · 415 阅读 · 0 评论 -
关于linux 内存分配
Linux内存管理摘要:本章首先以应用程序开发者的角度审视Linux的进程内存管理,在此基础上逐步深入到内核中讨论系统物理内存管理和内核内存的使用方法。力求从外到内、水到渠成地引导网友分析Linux的内存管理与使用。在本章最后,我们给出一个内存映射的实例,帮助网友们理解内核内存管理与用户内存管理之间的关系,希望大家最终能驾驭Linux内存管理。前言内存管理一向是所有操作系统书籍不惜笔墨...转载 2016-09-08 15:52:45 · 3007 阅读 · 0 评论 -
Linux 内存管理
计算机系统中有几类存储设备:cache、内存、外存。cache的存取速度最高,可以和CPU匹配,因此其代价最高,容量也最小。内存,又称主存或物理内存,是可以随机访问的存储器,其存取速度比高速cache低,对内存的访问需要几倍的CPU周期,因此其代价也比cache低,容量也可以做得比较大(从M到G) 。外存,如硬盘、软盘、光盘等,其容量大、成本低,但存取速度更低,对硬盘的存取速度至少比对内存的存取速转载 2016-09-08 15:54:37 · 484 阅读 · 0 评论 -
<Linux内核源码>内存管理模型
原文地址:【http://www.cnblogs.com/guguli/p/4489272.html#top】首先要理解一下每一个进程是如何维护自己独立的寻址空间的,我的电脑里呢是8G内存空间。了解过的朋友应该都知道这是虚拟内存技术解决的这个问题,然而再linux中具体是怎样的模型解决的操作系统的这个设计需求的呢,让我们从linux源码的片段开始看吧!(以下内核源码均来自fedora2转载 2016-09-08 15:55:59 · 912 阅读 · 0 评论 -
Linux内核源代码分析——Linux内核的入口
Jack:hi,淫龙,在Linux内核的源代码里,有几段汇编代码,那几段代码是负责Linux内核引导的。我:是的。早期的Linux内核引导代码只有bootsect.s、setup.s、head.s这3个文件,这三个文件都是Linus在1991年左右亲手写的。后来的代码虽然进行了加固,但是原型还是这几个。Jack:我想弄清楚。这几个汇编代码做了些什么事情。我:我不能在对话中一句代码一句代转载 2016-09-08 15:58:39 · 1999 阅读 · 0 评论 -
linux-4.3.0代码注释git地址
https://code.csdn.net/xiebaoyou/linux-4-3-0-comment.git可以用git clone命令下载代码注释。目前刚开始,欢迎有兴趣的同学一起参与注释。参与方式有两种:1、加入到项目中,可以给我发邮件或者微信商量加入事宜。2、clone代码后,建立自己的分支,然后向项目发出合并请求。在linux下用vim查看乱码的同学,可以编辑~/转载 2016-09-08 16:02:35 · 345 阅读 · 0 评论 -
Linux文件系统的实现
Linux文件管理从用户的层面介绍了Linux管理文件的方式。Linux有一个树状结构来组织文件。树的顶端为根目录(/),节点为目录,而末端的叶子为包含数据的文件。当我们给出一个文件的完整路径时,我们从根目录出发,经过沿途各个目录,最终到达文件。我们可以对文件进行许多操作,比如打开和读写。在Linux文件管理相关命令中,我们看到许多对文件进行操作的命令。它们大都基于对文件的打开和读写操作。比如转载 2016-09-08 16:06:47 · 321 阅读 · 0 评论 -
Linux内存管理中内存的组织及主要数据结构分析(pg_data_t&&page&&zone)
在讲解内核中用于组织内存的数据结构之前,考虑到术语不总是容易理解,所以先来看看几个概念。我们首先考虑NUMA系统,这样,在UMA系统上介绍这些概念就非常容易了。下图给出内存划分的图示:首先,内核划分为结点。每个结点关联到系统中的一个处理器,在内核中表示为pa_data_t的实例(稍后定义该数据结构)。各个结点又划分为内存域,是内存的进一步细分。例如,对可用于(ISA设备的)DMA操转载 2016-09-08 16:12:57 · 2541 阅读 · 0 评论 -
一个全面介绍uBoot的文章
1 U-Boot简介U-Boot,全称Universal Boot Loader,是遵循GPL条款的开放源码项目。从FADSROM、8xxROM、PPCBOOT逐步发展演化而来。其源码目录、编译形式与Linux内核很相似,事实上,不少U-Boot源码就是相应的Linux内核源程序的简化,尤其是一些设备的驱动程序,这从U-Boot源码的注释中能体现这一点。但是U-Boot不仅仅支持嵌入式Linux...转载 2016-09-06 00:23:48 · 2250 阅读 · 0 评论 -
uboot之makefile底层文件
1.HOSTARCH 和HOSTOSHOSTARCH := $(<span style="background-color: rgb(255, 215, 0);">shell</span> uname -m | \ sed -e s/i.86/i386/ \ -e s/sun4u/sparc64/ \ -e s/arm.*/arm/ \ ...原创 2016-09-06 00:21:54 · 734 阅读 · 0 评论 -
常用的U-boot命令详解
U-boot发展到现在,他的命令行模式已经非常接近Linux下的shell了,在我编译的U-boot-2009.11中的命令行模式模式下支持“Tab”键的命令补全和命令的历史记录功能。而且如果你输入的命令的前几个字符和别的命令不重复,那么你就只需要打这几个字符即可,比如我想看这个U-boot的版本号,命令就是“ version”,但是在所有的命令中没有其他任何一个的命令是由“v”开头的,所以只需...原创 2016-09-06 00:14:56 · 1305 阅读 · 0 评论 -
UBOOT移植详细 很全面
u-boot-1.3.4 移植到S3C2440 (带有某些解析) 移植u-boot-1.3.4到S3C2440 一.预备知识: 1.首先,U-Boot1.3.4还没有支持s3c2440,移植仍是用2410的文件稍作修改而成的。 2....原创 2016-09-06 00:12:34 · 1691 阅读 · 0 评论 -
深入浅出Linux内核内存管理基础
1 背景1.1 用户空间与内核空间内存的划分 从Linux操作系统层次上,内存可划分为用户空间内存和内核空间内存。 32位的CPU,最大寻址范围为2^32 - 1也就是4G的线性地址空间。Linux简化了分段机制,使得虚拟地址与线性地址总是一致的。Linux一般把这个4G的地址空间划分为两个部分:其中 0~3G为用户程序地址空间,虚地址0x00000000到0x转载 2016-09-08 15:41:39 · 480 阅读 · 0 评论 -
Linux内核学习笔记十——虚拟文件系统概念
虚拟文件系统虚拟文件系统:内核子系统VFS,VFS是内核中文件系统的抽象层,为用户空间提供文件系统相关接口;通过虚拟文件系统,程序可以利用标准Linux文件系统调用在不同的文件系统中进行交互和操作。VFS作为抽象层: 文件系统被安装在一个特定的安装点上,该安装点在全局层次结构中被称作命名空间,所有的已安装文件系统都作为根文件系统树的枝叶出现在系统中。转载 2016-09-07 19:20:31 · 164 阅读 · 0 评论 -
Linux内核学习笔记九——内核内存管理方式
一 页 内核把物理页作为内存管理的基本单位;内存管理单元(MMU)把虚拟地址转换为物理地址,通常以页为单位进行处理。MMU以页大小为单位来管理系统中的也表。 32位系统:页大小4KB 64位系统:页大小8KB内核用相应的数据结构表示系统中的每个物理页: struct page {}内核通过这样的数据结构管理系统中所有的页,因转载 2016-09-07 19:20:02 · 211 阅读 · 0 评论 -
linux 内核网络,数据接收流程图
4.3 数据接收流程图各层主要函数以及位置功能说明: 1)sock_read:初始化msghdr{}的结构类型变量msg,并且将需要接收的数据存放的地址传给msg.msg_iov->iov_base. net/socket.c 2)sock_recvmsg: 调用函数指针sock->ops->recvmsg()完转载 2016-09-05 16:38:20 · 468 阅读 · 0 评论 -
bootloader与linux内核的约定
bootloader巧妙地利用函数指针及传参规范将R0:0x0,R1: 机器号,R2:参数地址传递给内核.由于R0,R1比较简单,不需要再作说明.需要花点时间了解的是R2寄存器. R2寄存器传递的是一个指针,这个指针指向一个TAG区域.UBOOT和Linux内核之间正是通过这个扩展了的TAG区域来进行复杂参数的传递,如 command line,文件系统信息等等,用户也可以扩展这个TAG来进...原创 2016-09-06 00:13:47 · 440 阅读 · 0 评论 -
对于struct file_operations中ioctl消失的学习笔记
当年看《LDD3》的时候已经注意到了书中对ioctl的评价不是很好:“ioctl调用的非结构化本质导致众多内核开发者倾向于放弃它。” ,而在这次阅读3.0代码的时候,这个成员在struct file_operations中早已消失了。这个激起了我学习的兴趣,以下是对这个ioctl的学习小结:1、消失的确切时间 ioctl的消失到底是从哪个版本开始的?网上给出的时间是2.6.3转载 2016-09-06 00:27:12 · 815 阅读 · 0 评论 -
Linux内核高端内存
Linux内核地址映射模型x86 CPU采用了段页式地址映射模型。进程代码中的地址为逻辑地址,经过段页式地址映射后,才真正访问物理内存。段页式机制如下图。 Linux内核地址空间划分通常32位Linux内核地址空间划分0~3G为用户空间,3~4G为内核空间。注意这里是32位内核地址空间划分,64位内核地址空间划分是不同的。 Linux内核高端内存转载 2016-09-06 21:07:29 · 152 阅读 · 0 评论 -
Linux 源代码阅读知识点及要求
说明:1、本次源代码阅读,以Linux 最新的稳定版本(2.6)为主;2、源代码下载地址:在官方站点 www.kernel.org 上最新稳定版本是 2.6.13.2;在清华的 ftp 上随时都可以下载到:ftp.tsinghua.edu.cn/mirror/kernel.org/linux/kernel/v2.6/3、源代码阅读辅助工具:在Windows 环境下推荐Sourc转载 2016-09-06 21:14:51 · 224 阅读 · 0 评论 -
Linux内核目录结构
l arch目录arch是architecture的缩写。内核所支持的每种CPU体系,在该目录下都有对应的子目录。每个CPU的子目录,又进一步分解为boot,mm,kernel等子目录,分别包含控制系统引导,内存管理,系统调用等。| --x86 /* 英特尔cpu及与之相兼容体系结构的子目录*/| |--boot /*引导程序*/| | |--compressed转载 2016-09-06 21:26:52 · 169 阅读 · 0 评论 -
Linux2.6内核启动流程
Linux内核构成1 arch/arm/boot/compressed/Makefile arch/arm/boot/compressed/vmlinux.lds2. arch/arm/kernel/vmlinux.lds Linux内核启动流程arch/arm/boot/compressed/start.S Start: .转载 2016-09-06 21:30:10 · 349 阅读 · 0 评论 -
Linux内核学习笔记一
内核与操作系统: 内核是操作系统的核心部分,包含了系统运行的核心过程,决定系统的性能,操作系统启动内核被装入到RAM中;操作系统与底层硬件设备交互和为运行应用程序提供执行环境。Linux内核与微内核比较: 微内核:内核只需要一个很小的函数集,通常包括几个同步原语,一个简单的调度程序和进程间通信机制。运行在微内核之上的几个系统进程实现系统级功能:内存分配,设备转载 2016-09-07 19:15:46 · 189 阅读 · 0 评论 -
Linux内核学习笔记二——进程
一 进程与线程 进程就是处于执行期的程序,包含了独立地址空间,多个执行线程等资源。 线程是进程中活动的对象,每个线程都拥有独立的程序计数器、进程栈和一组进程寄存器。 内核调度的对象是线程而不是进程。对Linux而言,线程是特殊的进程。二 进程描述符及任务结构 内核使用双向循环链表的任务队列来存放进程,使用结构体task_struc转载 2016-09-07 19:16:28 · 230 阅读 · 0 评论 -
Linux内核学习笔记三——进程调度
进程调度: 在可运行态进程之间分配有限处理器时间资源的内核子系统。一 调度策略1 进程类型 I/O消耗型进程:大部分时间用来提交I/O请求或是等待I/O请求,经常处于可运行状态,但运行时间短,等待请求过程时处于阻塞状态。如交互式程序。 处理器消耗型进程:时间大都用在执行代码上,除非被抢占否则一直不停的运行。 综合型:既是I/O转载 2016-09-07 19:17:07 · 348 阅读 · 0 评论 -
Linux内核学习笔记四——系统调用
一 用户空间和内核空间Linux内核将这4G字节虚拟地址空间的空间分为两部分: l 将最高的1G字节(从虚拟地址0xC0000000到0xFFFFFFFF),供内核使用,称为“内核空间”。 l 将较低的3G字节(从虚拟地址 0x00000000到0xBFFFFFFF),供各个进程使用,称为“用户空间)。 因为每个进程可以通过系统调用进入内核,因此Linux内核由系统内的所转载 2016-09-07 19:17:31 · 218 阅读 · 0 评论 -
Linux内核学习笔记五——中断推后处理机制
一 中断 硬件通过中断与操作系统进行通信,通过对硬件驱动程序处注册中断处理程序,快速响应硬件的中断。硬件中断优先级很高,打断当前正在执行的程序。有两种情况: 硬件中断在中断处理程序中处理 硬件中断延后再进行处理 这个具体硬件相关,在中断处理程序中处理,打断了当前正在执行的程序;所有中断都将被屏蔽;如果占用时间太长不合适,造成系统交互性,反应能力都会受到影响转载 2016-09-07 19:18:05 · 199 阅读 · 0 评论 -
Linux内核学习笔记六——并发和同步概念
一 临界区和竞争条件 临界区:访问和操作共享数据的代码段。 竞争条件:多个执行线程处于同一个临界区中。 处于竞争条件:造成访问的数据或者资源不一致状态:对资源i的访问:ProcessA和B访问后得到正确的结果应该是9: 进程是并发执行,有可能得到的结果是:8转载 2016-09-07 19:18:31 · 188 阅读 · 0 评论 -
Linux内核学习笔记七——内核同步机制和实现方式
一 原子操作 指令以原子的方式执行——执行过程不被打断。1 原子整数操作 原子操作函数接收的操作数类型——atomic_t//定义atomic_t v;//初始化atomic_t u = ATOMIC_INIT(0);//操作atomic_set(&v,4); // v = 4atomic_add(2,&v); //转载 2016-09-07 19:19:06 · 189 阅读 · 0 评论 -
Linux内核学习笔记八——定时器和时间管理
一 内核中的时间观念 内核在硬件的帮助下计算和管理时间。硬件为内核提供一个系统定时器用以计算流逝的时间。系 统定时器以某种频率自行触发,产生时钟中断,进入内核时钟中断处理程序中进行处理。 墙上时间和系统运行时间根据时钟间隔来计算。利用时间中断周期执行的工作: 更新系统运行时间; 更新实际时间; 在smp系统上,转载 2016-09-07 19:19:31 · 232 阅读 · 0 评论 -
用户空间和内核空间通讯之【Netlink 下】
关于Netlink多播机制的用法 在上一篇博文中我们所遇到的情况都是用户空间作为消息进程的发起者,Netlink还支持内核作为消息的发送方的情况。这一般用于内核主动向用户空间报告一些内核状态,例如我们在用户空间看到的USB的热插拔事件的通告就是这样的应用。 先说一下我们的目标,内核线程每个一秒钟往一个多播组里发送一条消息,然后用户空间所以加入了该组的进程都会收到这...转载 2016-09-05 16:13:54 · 223 阅读 · 0 评论