Linux Kernel API
记录一些Linux Device Drivers中常用的API。
Linux官方提供的内核文档:
1、 最新版: https://www.kernel.org/doc/html/latest/
2、 4.10: https://www.kernel.org/doc/html/v4.10/
3、 Understanding the Linux Virtual Memory Manager 或者查看PDF版本
一、内存分配
1. void *devm_kmalloc(struct device *dev, size_t size, gfp_t gfp)
2、 void *devm_kzalloc(struct device *dev, size_t size, gfp_t gfp)
3、 void devm_kfree(struct device *dev, void *p)
4、 struct resource *platform_get_resource(struct platform_device *dev, unsigned int type, unsigned int num)
5、 int platform_get_irq(struct platform_device *dev, unsigned int num)
6、 struct resource *platform_get_resource_byname(struct platform_device *dev, unsigned int type, const char *name)
7、 int platform_get_irq_byname(struct platform_device *dev, const char *name)
示例(4、5、6、7几个API的调用):
设备树:
reg = <0x15240000 0x2c000>,
<0x15204000 0x20000>;
reg-names = "slimbus_physical", "slimbus_bam_physical";
interrupts = < >, < >;
interrupt-names = "slimbus_irq", "slimbus_bam_irq"; 驱动: struct resource *bam_mem;
struct resource *slim_mem;
struct resource *irq, *bam_irq; slim_mem = platform_get_resource_byname(pdev, IORESOURCE_MEM,
"slimbus_physical");
等价于: platform_get_resource(pdev, IORESOURCE_MEM, ) bam_mem = platform_get_resource_byname(pdev, IORESOURCE_MEM,
"slimbus_bam_physical");
等价于: platform_get_resource(pdev, IORESOURCE_MEM, ) irq = platform_get_resource_byname(pdev, IORESOURCE_IRQ,
"slimbus_irq");
等价于: platform_get_resource(pdev, IORESOURCE_IRQ, ) bam_irq = platform_get_resource_byname(pdev, IORESOURCE_IRQ,
"slimbus_bam_irq");
等价于: platform_get_resource(pdev, IORESOURCE_IRQ, )
8、 char *kstrdup(const char *s, gfp_t gfp);
功能: 分配一块内存空间(kmalloc + gfp),然后将s指向的字符串拷贝到这块内存中并返回该内存的首地址
9、void *kmemdup(const void *src, size_t len, gfp_t gfp);
功能:分配一块长度为len的内存(kmalloc+gfp),然后将src到(src + len)内存的内容copy到新分配的内存中,然后返回该内存的首地址
10、void *memdup_user(const void __user *src, size_t len);
功能: 分配一块长度为len的内存(kmalloc + gfp),然后将用户空间的地址src到(src+len)范围的内存使用copy_from_user的方式拷贝到
新分配的内存当中,最后返回新分配的内存的首地址
二、GPIO相关
1、static inline int of_get_named_gpio(struct device_node *np, const char *propname, int index)
获得GPIO号, 失败的话,会返回负数, 可以用gpio_is_valid来检查解析到的gpio是否合法:
设备树:
qcom,cdc-us-euro-gpios = <&tlmm > 驱动:
pdata->us_euro_gpio = of_get_named_gpio(pdev->dev.of_node,
"qcom,cdc-us-euro-gpios", );
2、 int of_get_gpio(struct device_node *np, int index)
从设备树的gpios属性中解析出第index个gpio资源:
设备树:
gpios = <&gpf1 GPIO_ACTIVE_HIGH>, <&gpf1 GPIO_ACTIVE_HIGH>;
驱动:
int sda_pin, scl_pin; sda_pin = of_get_gpio(np, );
scl_pin = of_get_gpio(np, );
of_get_gpio
三、端口映射
1、void __iomem *devm_ioremap_resource(struct device *dev, struct resource *res)
示例:
2、 void devm_iounmap(struct device *dev, void __iomem *addr)
3、 void __iomem *devm_ioremap(struct device *dev, resource_size_t offset, resource_size_t size)
4、 void __iomem *of_iomap(struct device_node *np, int index)
5、void __iomem *of_io_request_and_map(struct device_node *np, int index, const char *name)
四、设备树相关
1. bool of_property_read_bool(const struct device_node *np, const char *propname)
如果存在该属性,那么返回true,否则返回false
2. int of_property_read_u8(const struct device_node *np, const char *propname, u8 *out_value)
读取一个unsigned char, 成功返回0, 失败的话返回负数
这里需要注意的是: 设备树中对应的属性是 property_name = /bits/ 8 <0x50>
3. int of_property_read_u16(const struct device_node *np, const char *propname, u16 *out_value)
读取一个unsigned short, 成功返回0, 失败的话返回负数
这里需要注意的是: 设备树中对应的属性是 property = /bits/ 16 <0x5000 0x6000 0x7000>
4. int of_property_read_u32(const struct device_node *np, const char *propname, u32 *out_value)
读取一个unsigned int, 成功返回0, 失败的话返回负数
5、const struct of_device_id *of_match_node(const struct of_device_id *matches, const struct device_node *node)
返回matches中跟node相匹配的那一项, 如:
设备树如下:
sound {
status = "okay";
compatible = "qcom,sdm660-asoc-snd";
... ...
} 驱动如下:
static const struct of_device_id sdm660_asoc_machine_of_match[] = {
{ .compatible = "qcom,sdm660-asoc-snd",
.data = "internal_codec"},
{ .compatible = "qcom,sdm660-asoc-snd-tasha",
.data = "tasha_codec"},
{ .compatible = "qcom,sdm660-asoc-snd-tavil",
.data = "tavil_codec"},
{},
}; static int msm_asoc_machine_probe(struct platform_device *pdev)
{
const struct of_device_id *match; match = of_match_node(sdm660_asoc_machine_of_match,
pdev->dev.of_node);
... ...
} static struct platform_driver sdm660_asoc_machine_driver = {
.driver = {
......
.of_match_table = sdm660_asoc_machine_of_match,
},
......
};
module_platform_driver(sdm660_asoc_machine_driver);
6、 struct device_node *of_parse_phandle(const struct device_node *np, const char *phandle_name, int index)
根据一个handle property解析得到对应的device node, 如:
设备树: sound {
status = "okay";
compatible = "qcom,sdm660-asoc-snd";
... ...
qcom,us-euro-gpios = <0x1b4>;
... ...
}; msm_cdc_pinctrl@ {
compatible = "qcom,msm-cdc-pinctrl";
... ...
linux,phandle = <0x1b4>;
phandle = <0x1b4>;
}; 驱动:
struct device_node *node;
node = of_parse_phandle(pdev->dev.of_node,
"qcom,us-euro-gpios", );
五、中断
内核中其他一些不常见的用法示例:
完。
Linux Kernel API的更多相关文章
- linux kernel API and google android compile guide
(1)linux kernel API website: http://docs.knobbits.org/local/linux-doc/html/regulator/index.html http ...
- Linux kernel API的查看
一般来说Linux上查看一些函数API的说明咱们可以man一下.man 2是syscall,man 3是一些库的函数API. 以下是man sections的一些说明 The table below ...
- Linux kernel的中断子系统之(五):驱动申请中断API
返回目录:<ARM-Linux中断系统>. 总结:二重点区分了抢占式内核和非抢占式内核的区别:抢占式内核可以在内核空间进行抢占,通过对中断处理进行线程化可以提高Linux内核实时性. 三介 ...
- Linux kernel中断子系统之(五):驱动申请中断API【转】
转自:http://www.wowotech.net/linux_kenrel/request_threaded_irq.html 一.前言 本文主要的议题是作为一个普通的驱动工程师,在撰写自己负责的 ...
- Intel 80x86 Linux Kernel Interrupt(中断)、Interrupt Priority、Interrupt nesting、Prohibit Things Whthin CPU In The Interrupt Off State
目录 . 引言 . Linux 中断的概念 . 中断处理流程 . Linux 中断相关的源代码分析 . Linux 硬件中断 . Linux 软中断 . 中断优先级 . CPU在关中断状态下编程要注意 ...
- Linux Kernel(Android) 加密算法汇总(三)-应用程序调用内核加密算法接口
于Linux Kernel(Android) 加密算法总结(cipher.compress.digest)文章中.介绍了怎样在内核中增加三种不同类型的内核加密算法, 并给出了在内核模块中怎样调用他们的 ...
- 【嵌入式开发】 Linux Kernel 下载 配置 编译 安装 及 驱动简介
作者 : 韩曙亮 转载请出名出处 : http://blog.csdn.net/shulianghan/article/details/38636827 一. Linux 内核简介 1. 内核功能简介 ...
- Linux kernel的中断子系统之(一):综述
返回目录:<ARM-Linux中断系统>. 总结: 一从作为一名驱动工程师角度看,用好中断需要正确认识request_threaded_irq/request_irq关系.中断临界区保护. ...
- Linux kernel的中断子系统之(三):IRQ number和中断描述符
返回目录:<ARM-Linux中断系统>. 总结: 二描述了中断处理示意图,以及关中断.开中断,和IRQ number重要概念. 三介绍了三个重要的结构体,irq_desc.irq_dat ...
随机推荐
- 设置sde表空间为自动增长
有的用户在测试数据时,希望在SDE表空间里面不受限制地导入数据,于是需要将SDE的表空间设置为自动增长. 过程描述 1.可以在创建sde表空间的时候,添加参数Autoextend on,修改后创建命令 ...
- VMware安装操作系统提示 " Intel VT-x 处于禁用状态"解决方法
VMWARE WORKSTATION 在安装64为操作系统(kali)报错,报错内容为:“已将该虚拟机配置为使用 64 位客户机操作系统.但是,无法执行 64 位操作. 此主机支持 Intel VT- ...
- 51Nod1675 序列变换 数论 莫比乌斯反演
原文http://www.cnblogs.com/zhouzhendong/p/8665675.html 题目传送门 - 51Nod1675 题意 给定序列$a,b$,让你求满足$\gcd(x,y)= ...
- BZOJ1066 [SCOI2007]蜥蜴 网络流 最大流 SAP
由于本题和HDU2732几乎相同,所以读者可以看-> HDU2732题解传送门: http://www.cnblogs.com/zhouzhendong/p/8362002.html
- HUE的自动化安装部署
HUE=Hadoop User Experience(Hadoop用户体验),直白来说就一个开源的Apache Hadoop UI系统,由Cloudera Desktop演化而来,最后Cloudera ...
- 无向图的 DFS 和 BFS实现 (以邻接表存储的图)
#include <iostream> #include <queue> using namespace std; #define MaxVertexNum 10 typede ...
- Vue 中 computed、watch对比
computed:就像调用VUE的DATA一样 watch的对比 :监听事件
- python编码问题在此终结
转载:https://www.cnblogs.com/whatisfantasy/p/6422028.html 1 版本差异概览 1.1 Python 2.X: str(用于8位文本和二进制数据) ...
- POJ 1094 Sorting It All Out 【拓扑排序】
<题目链接> 题目大意: 对于N个大写字母,给定它们的一些关系,要求判断出经过多少个关系之后可以确定它们的排序或者排序存在冲突,或者所有的偏序关系用上之后依旧无法确定唯一的排序. 解题分析 ...
- centos6.5安装/升级到python2.7
https://www.cnblogs.com/harrymore/p/9024287.html