Linux源码阅读笔记13-进程通信组件上

Linux进程通信方式

  • 管道:创建的时候分配一个页大小内存,空间有限,不适合大量数据传输。
  • 消息队列:有两次copy造成额外的CPU消耗,不适合大量信息传输,效率比较低。
  • 共享内存:多个进程共享一块内存,没有同步机制,需要自己实现同步机制。
  • 套接字:在单机的情况下面走网络传输效率低。
  • 信号量:是一种锁机制,方式多个进程访问同一个资源,是一种同步手段。
  • 信号:不适合数据传输。

Android会什么会实现IPC Binder机制

  • 耦合性:C/S架构,不是网络通信,而是Binder机制。C和S是独立的。
  • 安全角度:Android是开放操作系统,保护每一个进程之间信息的安全。
  • 开发角度:在IPC中是C和C++,安卓使用Java,对组件进行Java的封装。

如何自己开发一个内核模块

bash 复制代码
make # 编译出模块
insmod xxx.ko # 将模块插入内核
lsmod # 查看模块
mknod /dev/mychannel c 96 0 # 创建设备文件 字符模块 主设备号 次设备号
# 启动进程

模块开发

什么是主次设备号

每一个设备都有一个设备号,字符模块有一个字符模块的ID就是设备号;一个主设备号可以有多多个次设备号

private_data

设备文件的私有空间,可以被poll感知到。

insmod时候调用Init

  1. 注册设备
  2. 初始化设备
  3. 添加到内核
  4. 初始化private_data

channel_open

  1. 检查设备是否对应
  2. 将分配好的空间指向private_data

channel_read

  1. 有数据时读取对应长度的数据
  2. 没有数据等待数据写入唤醒

channel_write

  1. 通过最大长度判断数据是否可以写入private_data
  2. 写入数据唤醒io多路复用的read(channel_read)

channel_poll

  1. 初始化
  2. 控制标志位

下一节具体实现这个通信组件。

相关推荐
vortex59 分钟前
AppArmor 受限 Shell 环境绕过技术分析:利用动态链接器路径差异实现 Profile 逃逸
linux·运维·服务器·网络安全
春日见28 分钟前
python3语法学习
linux·运维·服务器·人工智能·驱动开发
天寒心亦热1 小时前
Ubuntu20.04系统WIFI网络监测及自动重启
linux·运维·服务器
骇客野人2 小时前
Java比较两个list,A中有但B中没有的元素
linux·服务器·windows
EndingCoder2 小时前
数组和元组:处理集合数据
linux·运维·前端·ubuntu·typescript
数据雕塑家2 小时前
Linux运维实战:巧用文件操作实现SSH免密登录配置
linux·运维·ssh
天码-行空2 小时前
【大数据环境安装指南】HBase单机环境搭建教程
大数据·linux·运维·数据库·hbase
qq_316837752 小时前
java 对接支付宝支付 提现操作
java·linux·python
南棱笑笑生2 小时前
20260105给荣品PRO-RK3566开发板适配Rockchip原厂的Buildroot【linux-5.10】系统时解决eth0不能开机就打开的问题
linux·运维·服务器·rockchip
弓弧名家_玄真君2 小时前
虚拟机里的ubuntu 系统 设置宿主机关机ip不变化
linux·运维·ubuntu