Linux设备驱动中的阻塞和非阻塞I/0,简单来说就是对I/O操作的两种不同的方式,驱动程序可以灵活的支持用户空间对设备的这两种访问方式。...非阻塞应用程序通常使用select系统调用查询是否可以对设备进行无阻塞的访问最终会引发设备驱动中 poll 函数执行。...=1); //串口上没有输入则返回,所以循环读取 printf("%c/n",buf); 阻塞操作常常用等待队列来实现,而非阻塞操作用轮询的方式来实现。...非阻塞I/O的操作在应用层通常会用到select()和poll()系统调用查询是否可对设备进行无阻塞访问。select()和poll()系统调用最终会引发设备驱动中的poll()函数被调用。...return mask; } 三、总结 阻塞与非阻塞操作: 定义并初始化等待对列头; 定义并初始化等待队列; 把等待队列添加到等待队列头 设置进程状态(TASK_INTERRUPTIBLE(可以被信号打断
非阻塞connect详情介绍可以参见文章:https://blog.csdn.net/qq_41453285/article/details/89890429 一、非阻塞connect概述 man手册...解析文档,非阻塞connect如何使用: ①当我们将sock设置为非阻塞之后,使用connect去连接服务端,即使服务端开启了,connect系统调用也不会连接成功,connect而是以失败告终,并返回错误...②但是非阻塞connect返回的错误是有讲究的: 如果非阻塞connect返回的错误是EINPROGRESS,代表不是connect系统调用出错了,而是connect可能会在后面才会建立完整地连接(...,进一步来等待非阻塞connect客户端与服务端建立完整地连接,在等待的过程中,如果非阻塞connect建立成功了,客户端的sock_fd就会变成可写的(这个在本人的IO复用文章中介绍过,见下图) ④当非阻塞...在有些系统(比如Linux)上返回-1,而在有些系统上(比如源自伯克利的UNIX)返回0 这些问题没有一个统一的解决办法 三、编码演示案例 #include #include <stdlib.h
代码参考的是Linux早期的代码,没有现代内核的高级特性,VFS这部分只有介绍。...代码在这里: linux-0.11 系统调用 以前写过一篇系统调用的: http://www.oneyearago.me/2018/05/08/apue-again-system-call-and-std...Linux 一切皆文件 首先通常在windows中是文件的东西,它们在linux中也是文件 其次一些在windows中不是文件的东西, 比如进程, 磁盘, 也被抽象成了文件....-0.11-master/include/unistd.h #define __NR_setup 0 /* used only by init, to get system going */ #define...egid,sgid; long alarm; long utime,stime,cutime,cstime,start_time; unsigned short used_math; /* file system
Linux 系统概述 计算机的体系结构 计算机由计算机硬件和计算机软件两个部分组成,其中计算机软件可分为系统软件和应用软件,系统软件就是操作系统,是其他软件的基础。...Linux 系统的概述 Linux 系统是一套免费、自由、开发源代码的类 Unix 操作系统,是一个基于 POSIX (Portable Operating System Interface) 标准和多用户...Linux 能运行主要的 Unix 工具软件、应用程序和网络协议,支持 32 位和 64 位硬件。 主要发行版本 Redhat:目前最大的 Linux 发行商,功能全面并且稳定,被 IBM 收购。...Ubuntu:目前最好的 Linux 桌面版,拥有很人性化的亮丽的交互界面,强大的软件源支持。...CentOS:是 RHEL (Red Hat Enterprise Linux) 的克隆版本,可以认为是免费版本的 Redhat 系统。
如果任意时刻调用wait/waitpid,子进程存在且正常运行,则可能阻塞。 如果不存在该进程,则立即出错放回。...sleep(5); exit(257); } else { //father int status = 0; pid_t ret = waitpid(-1,&status,0);//阻塞等待...{ //father int status = 0; pid_t ret = 0; do { ret = waitpid(-1,&status,WNOHANG);//非阻塞等待...3.解释堵塞与非堵塞 阻塞场景:打电话等朋友接听 你拨打朋友的电话,直到朋友接通之前你什么都做不了。这就像阻塞调用,你必须等着事情完成。...非阻塞场景:发消息等待回复 你给朋友发了个消息,等他们回你。你不用一直盯着手机看,而是可以去做别的事情,等收到消息后再查看。这就像非阻塞调用,你不需要等着完成才能做其他事情。
大部分高性能网络框架采用的是非阻塞模式。笔者这次就从linux源码的角度来阐述socket阻塞(block)和非阻塞(non_block)的区别。...本文源码均来自采用Linux-2.6.24内核版本。...\非阻塞状态 我们用fcntl修改socket的阻塞\非阻塞状态。...),再通过linux的软中断机制调用net_rx_action,如下图所示: 注:上图来自PLKA(Linux内核架构>>) 紧接着跟踪next_rx_action next_rx_action...希望笔者这篇文章能帮助到阅读linux网络协议栈代码的人。
system V system V 是一套标准,独立于文件系统之外的,专门为了通信设计出来的模块 让两个毫不相关的进程看到同一份资源 1.
阻塞。 好吧,再来一点营养。阻塞是啥意思呢? 就是水管堵住了!扭开水龙头没有水出来。...这个道理跟Linux下读取慢速设备(主要指管道和套接字)数据的情形非常相似,例如当我们在读取一个管道时,如果管道里面没有数据,那么我们什么都读不出来,于是就进入了所谓的“阻塞”状态了,说白了阻塞就是使得当前进程或者线程睡眠了的意思...那么再进一步,什么时候会阻塞呢?下面的表格简单描述了这些清空: ? 其中,读者指的是对管道文件拥有读权限的进程或线程(注意不是正在读),写者指的是对管道文件拥有写权限的进程或线程(注意不是正在写)。...除此之外,其实open()函数也会发生阻塞,比如用只读或者只写open一个管道文件的时候。因为一根只有出口或者只有入口的水管,是无法使用的呀!其实就是生活常识。嘿嘿!
从linux源码看socket的阻塞和非阻塞 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情。 大部分高性能网络框架采用的是非阻塞模式。...笔者这次就从linux源码的角度来阐述socket阻塞(block)和非阻塞(non_block)的区别。 本文源码均来自采用Linux-2.6.24内核版本。...\非阻塞状态 我们用fcntl修改socket的阻塞\非阻塞状态。...阻塞后什么时候恢复运行呢 情况1:有对应的网络数据到来 首先我们看下网络分组到来的内核路径,网卡发起中断后调用netif_rx将事件挂入CPU的等待队列,并唤起软中断(soft_irq),再通过linux...希望笔者这篇文章能帮助到阅读linux网络协议栈代码的人。
在Linux系统中,I/O操作可以分为两种模式:阻塞式I/O和非阻塞式I/O。 这两种模式决定了进程在执行I/O操作时的行为方式,以及CPU资源的利用效率。...2 非阻塞式 I/O (Non-blocking I/O) 非阻塞I/O则是在执行I/O操作时,不管资源是否可用,操作系统都不会让进程进入阻塞状态,而是立即返回控制权。...4 阻塞与非阻塞 I/O 的优缺点 阻塞式 I/O 优点: 程序结构简单,不需要处理I/O状态的变化。 在I/O等待时,能够让出CPU资源,提高系统整体的CPU利用效率。...阻塞式 I/O 缺点: 由于进程可能长时间阻塞,会降低系统的响应性。 不适合高并发场景,因为每个阻塞的进程都会占用一个线程或进程资源。...以鼠标输入设备文件为例,Linux中鼠标对应的设备文件通常位于/dev/input/目录下,命名为mouseX(X为序号)或eventX。
@TOC 这两部分主要是了解即可,为后面学习做铺垫 1 . system V 消息队列(了解) ---- 为了让两个进程间通信 创建一个队列queue 进程A可以通过消息队列的系统调用接口,把自己的数据块链入队列中...这个队列就是一种共享资源 进程A想要读取数据时,只需要在队列中读取不是自己的数据 接口 创建消息队列 , 输入 man msgget 指令 key值含义与msgflg选项 不懂具体可以看 :system...先描述在组织,每一个消息队列都有自己的结构体对象,对应的结构体对象包含当前消息队列的属性 查看消息队列 输入 ipcs -q 指令 删除消息队列 ipcs -q msqid值 即可删除 2.system
在写入完毕的时候再通过像管道写入来通知对方 你已经写完了 可以进行读取 在读取之前,先向管道读取,看看是否收到了写方传达的通知,如果没读到就阻塞着等,读到了才会开始后面的读取命令!...其参数msgp需要我们自定义一个“块”传过去,这个块包括类型(区分是自己的数据还是别人的数据),以及数据块信息 三、IPC在内核中的数据结构设计 其实共享内存、消息队列、信号量都隶属于System...4.6 mmap函数 mmap也是一种共享内存技术 (System V的共享内存技术接口是最难的!) 一文读懂 mmap 原理 - 知乎 (zhihu.com)
找了一个关于Linux下的源代码包的网站http://www.linuxfromscratch.org/blfs/view/svn/longindex.html,里面对于Linux下的常见软件进行了分类...,并且对于每个软件包源代码的编译、安装以及对应的依赖,功能都有了详细的描述,很值得参考,尤其对于那些在Linux下做系统集成和搭建嵌入式开发板等软件开发环境时必不可少。
针对以上问题,提出了ASOC(ALSA System on Chip)来力争解决上述问题。解决方法如下: 1. Codec代码独立,不再耦合与CPU,这样可以增加Codec代码重复利用。 2.
本文章根据 NGINX 官网文档编写的教程 NGINX open source | NGIXN 开源版 第一步: 安装Centos Linux 下的 工具包 sudo -i yum install
目录 认识system V: system V共享内存: 共享内存的基本原理: 共享内存的数据结构: 共享内存的建立与释放: 共享内存的建立: 共享内存的释放: 共享内存的关联: 共享内存的去关联...: 用共享内存实现serve&client通信: system V消息队列: 消息队列基本原理: 消息队列数据结构: 消息队列的创建: 消息队列的释放: 向消息队列发送数据: 从消息队列获取数据: system...,其实是对底层代码的一种复用,linux工程师借助类似文件缓冲区的内存空间实现了管道,其实也算偷了一个小懒,随着linux的发展,linux正式推出了System V来专门进行进程间通信,它和管道的本质都是一样的...system V通信的3种通信方式: 1.system V共享内存 () 2.system V消息队列 () 3.system V信号量 () 上述中的共享内存和消息队列主要用于传输数据,而信号量则是用于保证进程间的同步与互斥...types.h> #include #include #include const char* pathname = "/home/sxk/linux2
我们有个功能是这样的:有个以 root 运行的 python 程序,它需要以 test 用户执行 linux 命令,所以就通过 subprocess 库 + sudo 来执行,也就是下面的关系图: image.png...难道 system 还需要撸一发 shell 么,崩溃!我心目中的 system 不是这么随便的!...System 源码 带着不甘心去搜它的实现: int system(const char * cmdstring) { pid_t pid; int status; if...', '1') 那么这里又引出了一个问题了 system 和 execl 都能执行系统命令,那两者有什么区别呢?...答案在上面的 system 的源码已经给出 80% 了,他们的区别就是: system = fork + execl + waitpid 而 execl 只是系统 exec 族函数的其中一个,说到 exec
Network File System(NFS)是一种用于在网络上共享文件系统的分布式文件系统协议,最初由Sun Microsystems开发。...版本: 关于NFS(Network File System),有几个重要的版本,每个版本都引入了新的功能和改进: NFSv2(Network File System Version 2): NFSv2...NFSv3(Network File System Version 3): NFSv3是NFS协议的下一个主要版本,于1995年发布。...NFSv4(Network File System Version 4): NFSv4是NFS协议的较新版本,最初于2000年发布,经过几次修订,最新版本是NFSv4.2。
二、linux中共享内存的数据结构 在 linux 中,共享内存也是需要被管理的,就像我们的进程控制块、文件描述符等等都是遵循一个原则:先描述、再组织! ...在 Linux 内核中,每个共享内存都由一个名为 struct shmid_kernel 的结构体来管理 (shmid 表示共享内存的 id),而且 Linux 限制了系统最大能创建的共享内存为 128...V 信号量 System V IPC 之信号量 一、信号量的分类 在学习 IPC 信号量之前,让我们先来了解一下 Linux 提供两类信号量: 内核信号量,由内核控制路径使用。...short sem_op; // 进行的操作,可以为负数、零或正数,表示减少、不变或增加信号量的值 short sem_flag; // 操作的标志,可以为IPC_NOWAIT(非阻塞...)或0(阻塞) }; // 用于在Linux系统中进行信号量操作时的参数传递 union semun { int val; // 用于设置信号量的初始值,或者用于获取信号量的当前值
描述 system()库函数使用fork(2)创建一个子进程,该子进程使用execl(3)执行指定的shell命令, execl("/bin/sh", “sh”, “-c”, command,...(char *) 0); 头文件 system - execute a shell command #include int system(const char *command...status) 用来指出子进程是否为正常退出的,如果是,它会返回一个非零值 WEXITSTATUS(status) 用来获取返回值status的低8~15数据 有了这两个宏代码就简介很多, 总结一下,system...0 ; #include #include #include int main() { pid_t status; status = system...返回值判断 命令是否正确执行 Linux system函数返回值 父进程等待子进程终止 wait, WIFEXITED, WEXITSTATUS