194c1fbd4SYanteng Si.. include:: ../disclaimer-zh_CN.rst
294c1fbd4SYanteng Si
394c1fbd4SYanteng Si:Original: Documentation/core-api/kernel-api.rst
48137a49eSYanteng Si
58137a49eSYanteng Si:翻译:
68137a49eSYanteng Si
78137a49eSYanteng Si 司延腾 Yanteng Si <siyanteng@loongson.cn>
8*b2fdf7f0SBinbin Zhou 周彬彬 Binbin Zhou <zhoubinbin@loongson.cn>
994c1fbd4SYanteng Si
1094c1fbd4SYanteng Si.. _cn_kernel-api.rst:
1194c1fbd4SYanteng Si
1294c1fbd4SYanteng Si============
1394c1fbd4SYanteng SiLinux内核API
1494c1fbd4SYanteng Si============
1594c1fbd4SYanteng Si
1694c1fbd4SYanteng Si
1794c1fbd4SYanteng Si列表管理函数
1894c1fbd4SYanteng Si============
1994c1fbd4SYanteng Si
2094c1fbd4SYanteng Si该API在以下内核代码中:
2194c1fbd4SYanteng Si
2294c1fbd4SYanteng Siinclude/linux/list.h
2394c1fbd4SYanteng Si
2494c1fbd4SYanteng Si基本的C库函数
2594c1fbd4SYanteng Si=============
2694c1fbd4SYanteng Si
2794c1fbd4SYanteng Si在编写驱动程序时,一般不能使用C库中的例程。部分函数通常很有用,它们在
2894c1fbd4SYanteng Si下面被列出。这些函数的行为可能会与ANSI定义的略有不同,这些偏差会在文中
2994c1fbd4SYanteng Si注明。
3094c1fbd4SYanteng Si
3194c1fbd4SYanteng Si字符串转换
3294c1fbd4SYanteng Si----------
3394c1fbd4SYanteng Si
3494c1fbd4SYanteng Si该API在以下内核代码中:
3594c1fbd4SYanteng Si
3694c1fbd4SYanteng Silib/vsprintf.c
3794c1fbd4SYanteng Si
3894c1fbd4SYanteng Siinclude/linux/kernel.h
3994c1fbd4SYanteng Si
4094c1fbd4SYanteng Siinclude/linux/kernel.h
4194c1fbd4SYanteng Si
4294c1fbd4SYanteng Silib/kstrtox.c
4394c1fbd4SYanteng Si
4494c1fbd4SYanteng Silib/string_helpers.c
4594c1fbd4SYanteng Si
4694c1fbd4SYanteng Si字符串处理
4794c1fbd4SYanteng Si----------
4894c1fbd4SYanteng Si
4994c1fbd4SYanteng Si该API在以下内核代码中:
5094c1fbd4SYanteng Si
5194c1fbd4SYanteng Silib/string.c
5294c1fbd4SYanteng Si
5394c1fbd4SYanteng Siinclude/linux/string.h
5494c1fbd4SYanteng Si
5594c1fbd4SYanteng Simm/util.c
5694c1fbd4SYanteng Si
5794c1fbd4SYanteng Si基本的内核库函数
5894c1fbd4SYanteng Si================
5994c1fbd4SYanteng Si
6094c1fbd4SYanteng SiLinux内核提供了很多实用的基本函数。
6194c1fbd4SYanteng Si
6294c1fbd4SYanteng Si位运算
6394c1fbd4SYanteng Si------
6494c1fbd4SYanteng Si
6594c1fbd4SYanteng Si该API在以下内核代码中:
6694c1fbd4SYanteng Si
6794c1fbd4SYanteng Siinclude/asm-generic/bitops/instrumented-atomic.h
6894c1fbd4SYanteng Si
6994c1fbd4SYanteng Siinclude/asm-generic/bitops/instrumented-non-atomic.h
7094c1fbd4SYanteng Si
7194c1fbd4SYanteng Siinclude/asm-generic/bitops/instrumented-lock.h
7294c1fbd4SYanteng Si
7394c1fbd4SYanteng Si位图运算
7494c1fbd4SYanteng Si--------
7594c1fbd4SYanteng Si
7694c1fbd4SYanteng Si该API在以下内核代码中:
7794c1fbd4SYanteng Si
7894c1fbd4SYanteng Silib/bitmap.c
7994c1fbd4SYanteng Si
8094c1fbd4SYanteng Siinclude/linux/bitmap.h
8194c1fbd4SYanteng Si
8294c1fbd4SYanteng Siinclude/linux/bitmap.h
8394c1fbd4SYanteng Si
8494c1fbd4SYanteng Siinclude/linux/bitmap.h
8594c1fbd4SYanteng Si
8694c1fbd4SYanteng Silib/bitmap.c
8794c1fbd4SYanteng Si
8894c1fbd4SYanteng Silib/bitmap.c
8994c1fbd4SYanteng Si
9094c1fbd4SYanteng Siinclude/linux/bitmap.h
9194c1fbd4SYanteng Si
9294c1fbd4SYanteng Si命令行解析
9394c1fbd4SYanteng Si----------
9494c1fbd4SYanteng Si
9594c1fbd4SYanteng Si该API在以下内核代码中:
9694c1fbd4SYanteng Si
9794c1fbd4SYanteng Silib/cmdline.c
9894c1fbd4SYanteng Si
9994c1fbd4SYanteng Si排序
10094c1fbd4SYanteng Si----
10194c1fbd4SYanteng Si
10294c1fbd4SYanteng Si该API在以下内核代码中:
10394c1fbd4SYanteng Si
10494c1fbd4SYanteng Silib/sort.c
10594c1fbd4SYanteng Si
10694c1fbd4SYanteng Silib/list_sort.c
10794c1fbd4SYanteng Si
10894c1fbd4SYanteng Si文本检索
10994c1fbd4SYanteng Si--------
11094c1fbd4SYanteng Si
11194c1fbd4SYanteng Si该API在以下内核代码中:
11294c1fbd4SYanteng Si
11394c1fbd4SYanteng Silib/textsearch.c
11494c1fbd4SYanteng Si
11594c1fbd4SYanteng Silib/textsearch.c
11694c1fbd4SYanteng Si
11794c1fbd4SYanteng Siinclude/linux/textsearch.h
11894c1fbd4SYanteng Si
11994c1fbd4SYanteng SiLinux中的CRC和数学函数
12094c1fbd4SYanteng Si======================
12194c1fbd4SYanteng Si
12294c1fbd4SYanteng Si
12394c1fbd4SYanteng SiCRC函数
12494c1fbd4SYanteng Si-------
12594c1fbd4SYanteng Si
12694c1fbd4SYanteng Si*译注:CRC,Cyclic Redundancy Check,循环冗余校验*
12794c1fbd4SYanteng Si
12894c1fbd4SYanteng Si该API在以下内核代码中:
12994c1fbd4SYanteng Si
13094c1fbd4SYanteng Silib/crc4.c
13194c1fbd4SYanteng Si
13294c1fbd4SYanteng Silib/crc7.c
13394c1fbd4SYanteng Si
13494c1fbd4SYanteng Silib/crc8.c
13594c1fbd4SYanteng Si
13694c1fbd4SYanteng Silib/crc16.c
13794c1fbd4SYanteng Si
13894c1fbd4SYanteng Silib/crc32.c
13994c1fbd4SYanteng Si
14094c1fbd4SYanteng Silib/crc-ccitt.c
14194c1fbd4SYanteng Si
14294c1fbd4SYanteng Silib/crc-itu-t.c
14394c1fbd4SYanteng Si
14494c1fbd4SYanteng Si基数为2的对数和幂函数
14594c1fbd4SYanteng Si---------------------
14694c1fbd4SYanteng Si
14794c1fbd4SYanteng Si该API在以下内核代码中:
14894c1fbd4SYanteng Si
14994c1fbd4SYanteng Siinclude/linux/log2.h
15094c1fbd4SYanteng Si
15194c1fbd4SYanteng Si整数幂函数
15294c1fbd4SYanteng Si----------
15394c1fbd4SYanteng Si
15494c1fbd4SYanteng Si该API在以下内核代码中:
15594c1fbd4SYanteng Si
15694c1fbd4SYanteng Silib/math/int_pow.c
15794c1fbd4SYanteng Si
15894c1fbd4SYanteng Silib/math/int_sqrt.c
15994c1fbd4SYanteng Si
16094c1fbd4SYanteng Si除法函数
16194c1fbd4SYanteng Si--------
16294c1fbd4SYanteng Si
16394c1fbd4SYanteng Si该API在以下内核代码中:
16494c1fbd4SYanteng Si
16594c1fbd4SYanteng Siinclude/asm-generic/div64.h
16694c1fbd4SYanteng Si
16794c1fbd4SYanteng Siinclude/linux/math64.h
16894c1fbd4SYanteng Si
16994c1fbd4SYanteng Silib/math/div64.c
17094c1fbd4SYanteng Si
17194c1fbd4SYanteng Silib/math/gcd.c
17294c1fbd4SYanteng Si
17394c1fbd4SYanteng SiUUID/GUID
17494c1fbd4SYanteng Si---------
17594c1fbd4SYanteng Si
17694c1fbd4SYanteng Si该API在以下内核代码中:
17794c1fbd4SYanteng Si
17894c1fbd4SYanteng Silib/uuid.c
17994c1fbd4SYanteng Si
18094c1fbd4SYanteng Si内核IPC设备
18194c1fbd4SYanteng Si===========
18294c1fbd4SYanteng Si
18394c1fbd4SYanteng SiIPC实用程序
18494c1fbd4SYanteng Si-----------
18594c1fbd4SYanteng Si
18694c1fbd4SYanteng Si该API在以下内核代码中:
18794c1fbd4SYanteng Si
18894c1fbd4SYanteng Siipc/util.c
18994c1fbd4SYanteng Si
19094c1fbd4SYanteng SiFIFO 缓冲区
19194c1fbd4SYanteng Si===========
19294c1fbd4SYanteng Si
19394c1fbd4SYanteng Sikfifo接口
19494c1fbd4SYanteng Si---------
19594c1fbd4SYanteng Si
19694c1fbd4SYanteng Si该API在以下内核代码中:
19794c1fbd4SYanteng Si
19894c1fbd4SYanteng Siinclude/linux/kfifo.h
19994c1fbd4SYanteng Si
20094c1fbd4SYanteng Si转发接口支持
20194c1fbd4SYanteng Si============
20294c1fbd4SYanteng Si
20394c1fbd4SYanteng Si转发接口支持旨在为工具和设备提供一种有效的机制,将大量数据从内核空间
20494c1fbd4SYanteng Si转发到用户空间。
20594c1fbd4SYanteng Si
20694c1fbd4SYanteng Si转发接口
20794c1fbd4SYanteng Si--------
20894c1fbd4SYanteng Si
20994c1fbd4SYanteng Si该API在以下内核代码中:
21094c1fbd4SYanteng Si
21194c1fbd4SYanteng Sikernel/relay.c
21294c1fbd4SYanteng Si
21394c1fbd4SYanteng Sikernel/relay.c
21494c1fbd4SYanteng Si
21594c1fbd4SYanteng Si模块支持
21694c1fbd4SYanteng Si========
21794c1fbd4SYanteng Si
21894c1fbd4SYanteng Si模块加载
21994c1fbd4SYanteng Si--------
22094c1fbd4SYanteng Si
22194c1fbd4SYanteng Si该API在以下内核代码中:
22294c1fbd4SYanteng Si
22394c1fbd4SYanteng Sikernel/kmod.c
22494c1fbd4SYanteng Si
22594c1fbd4SYanteng Si模块接口支持
22694c1fbd4SYanteng Si------------
22794c1fbd4SYanteng Si
22894c1fbd4SYanteng Si更多信息请参考文件kernel/module.c22994c1fbd4SYanteng Si
23094c1fbd4SYanteng Si硬件接口
23194c1fbd4SYanteng Si========
23294c1fbd4SYanteng Si
23394c1fbd4SYanteng Si
23494c1fbd4SYanteng Si该API在以下内核代码中:
23594c1fbd4SYanteng Si
23694c1fbd4SYanteng Sikernel/dma.c
23794c1fbd4SYanteng Si
23894c1fbd4SYanteng Si资源管理
23994c1fbd4SYanteng Si--------
24094c1fbd4SYanteng Si
24194c1fbd4SYanteng Si该API在以下内核代码中:
24294c1fbd4SYanteng Si
24394c1fbd4SYanteng Sikernel/resource.c
24494c1fbd4SYanteng Si
24594c1fbd4SYanteng Sikernel/resource.c
24694c1fbd4SYanteng Si
24794c1fbd4SYanteng SiMTRR处理
24894c1fbd4SYanteng Si--------
24994c1fbd4SYanteng Si
25094c1fbd4SYanteng Si该API在以下内核代码中:
25194c1fbd4SYanteng Si
25294c1fbd4SYanteng Siarch/x86/kernel/cpu/mtrr/mtrr.c
25394c1fbd4SYanteng Si
25494c1fbd4SYanteng Si安全框架
25594c1fbd4SYanteng Si========
25694c1fbd4SYanteng Si
25794c1fbd4SYanteng Si该API在以下内核代码中:
25894c1fbd4SYanteng Si
25994c1fbd4SYanteng Sisecurity/security.c
26094c1fbd4SYanteng Si
26194c1fbd4SYanteng Sisecurity/inode.c
26294c1fbd4SYanteng Si
26394c1fbd4SYanteng Si审计接口
26494c1fbd4SYanteng Si========
26594c1fbd4SYanteng Si
26694c1fbd4SYanteng Si该API在以下内核代码中:
26794c1fbd4SYanteng Si
26894c1fbd4SYanteng Sikernel/audit.c
26994c1fbd4SYanteng Si
27094c1fbd4SYanteng Sikernel/auditsc.c
27194c1fbd4SYanteng Si
27294c1fbd4SYanteng Sikernel/auditfilter.c
27394c1fbd4SYanteng Si
27494c1fbd4SYanteng Si核算框架
27594c1fbd4SYanteng Si========
27694c1fbd4SYanteng Si
27794c1fbd4SYanteng Si该API在以下内核代码中:
27894c1fbd4SYanteng Si
27994c1fbd4SYanteng Sikernel/acct.c
28094c1fbd4SYanteng Si
28194c1fbd4SYanteng Si块设备
28294c1fbd4SYanteng Si======
28394c1fbd4SYanteng Si
28494c1fbd4SYanteng Si该API在以下内核代码中:
28594c1fbd4SYanteng Si
286*b2fdf7f0SBinbin Zhouinclude/linux/bio.h
287*b2fdf7f0SBinbin Zhou
28894c1fbd4SYanteng Siblock/blk-core.c
28994c1fbd4SYanteng Si
29094c1fbd4SYanteng Siblock/blk-core.c
29194c1fbd4SYanteng Si
29294c1fbd4SYanteng Siblock/blk-map.c
29394c1fbd4SYanteng Si
29494c1fbd4SYanteng Siblock/blk-sysfs.c
29594c1fbd4SYanteng Si
29694c1fbd4SYanteng Siblock/blk-settings.c
29794c1fbd4SYanteng Si
29894c1fbd4SYanteng Siblock/blk-flush.c
29994c1fbd4SYanteng Si
30094c1fbd4SYanteng Siblock/blk-lib.c
30194c1fbd4SYanteng Si
30294c1fbd4SYanteng Siblock/blk-integrity.c
30394c1fbd4SYanteng Si
30494c1fbd4SYanteng Sikernel/trace/blktrace.c
30594c1fbd4SYanteng Si
30694c1fbd4SYanteng Siblock/genhd.c
30794c1fbd4SYanteng Si
30894c1fbd4SYanteng Siblock/genhd.c
30994c1fbd4SYanteng Si
31094c1fbd4SYanteng Si字符设备
31194c1fbd4SYanteng Si========
31294c1fbd4SYanteng Si
31394c1fbd4SYanteng Si该API在以下内核代码中:
31494c1fbd4SYanteng Si
31594c1fbd4SYanteng Sifs/char_dev.c
31694c1fbd4SYanteng Si
31794c1fbd4SYanteng Si时钟框架
31894c1fbd4SYanteng Si========
31994c1fbd4SYanteng Si
32094c1fbd4SYanteng Si时钟框架定义了编程接口,以支持系统时钟树的软件管理。该框架广泛用于系统级芯片(SOC)平
32194c1fbd4SYanteng Si台,以支持电源管理和各种可能需要自定义时钟速率的设备。请注意,这些 “时钟”与计时或实
32294c1fbd4SYanteng Si时时钟(RTC)无关,它们都有单独的框架。这些:c:type: `struct clk <clk>` 实例可用于管理
32394c1fbd4SYanteng Si各种时钟信号,例如一个96理例如96MHz的时钟信号,该信号可被用于总线或外设的数据交换,或以
32494c1fbd4SYanteng Si其他方式触发系统硬件中的同步状态机转换。
32594c1fbd4SYanteng Si
32694c1fbd4SYanteng Si通过明确的软件时钟门控来支持电源管理:未使用的时钟被禁用,因此系统不会因为改变不在使用
32794c1fbd4SYanteng Si中的晶体管的状态而浪费电源。在某些系统中,这可能是由硬件时钟门控支持的,其中时钟被门控
32894c1fbd4SYanteng Si而不在软件中被禁用。芯片的部分,在供电但没有时钟的情况下,可能会保留其最后的状态。这种
32994c1fbd4SYanteng Si低功耗状态通常被称为*保留模式*。这种模式仍然会产生漏电流,特别是在电路几何结构较细的情
33094c1fbd4SYanteng Si况下,但对于CMOS电路来说,电能主要是随着时钟翻转而被消耗的。
33194c1fbd4SYanteng Si
33294c1fbd4SYanteng Si电源感知驱动程序只有在其管理的设备处于活动使用状态时才会启用时钟。此外,系统睡眠状态通
33394c1fbd4SYanteng Si常根据哪些时钟域处于活动状态而有所不同:“待机”状态可能允许从多个活动域中唤醒,而
33494c1fbd4SYanteng Si"mem"(暂停到RAM)状态可能需要更全面地关闭来自高速PLL和振荡器的时钟,从而限制了可能
33594c1fbd4SYanteng Si的唤醒事件源的数量。驱动器的暂停方法可能需要注意目标睡眠状态的系统特定时钟约束。
33694c1fbd4SYanteng Si
33794c1fbd4SYanteng Si一些平台支持可编程时钟发生器。这些可以被各种外部芯片使用,如其他CPU、多媒体编解码器以
33894c1fbd4SYanteng Si及对接口时钟有严格要求的设备。
33994c1fbd4SYanteng Si
34094c1fbd4SYanteng Si该API在以下内核代码中:
34194c1fbd4SYanteng Si
34294c1fbd4SYanteng Siinclude/linux/clk.h
34394c1fbd4SYanteng Si
34494c1fbd4SYanteng Si同步原语
34594c1fbd4SYanteng Si========
34694c1fbd4SYanteng Si
34794c1fbd4SYanteng Si读-复制-更新(RCU)
34894c1fbd4SYanteng Si-------------------
34994c1fbd4SYanteng Si
35094c1fbd4SYanteng Si该API在以下内核代码中:
35194c1fbd4SYanteng Si
35294c1fbd4SYanteng Siinclude/linux/rcupdate.h
35394c1fbd4SYanteng Si
35494c1fbd4SYanteng Sikernel/rcu/tree.c
35594c1fbd4SYanteng Si
35694c1fbd4SYanteng Sikernel/rcu/tree_exp.h
35794c1fbd4SYanteng Si
35894c1fbd4SYanteng Sikernel/rcu/update.c
35994c1fbd4SYanteng Si
36094c1fbd4SYanteng Siinclude/linux/srcu.h
36194c1fbd4SYanteng Si
36294c1fbd4SYanteng Sikernel/rcu/srcutree.c
36394c1fbd4SYanteng Si
36494c1fbd4SYanteng Siinclude/linux/rculist_bl.h
36594c1fbd4SYanteng Si
36694c1fbd4SYanteng Siinclude/linux/rculist.h
36794c1fbd4SYanteng Si
36894c1fbd4SYanteng Siinclude/linux/rculist_nulls.h
36994c1fbd4SYanteng Si
37094c1fbd4SYanteng Siinclude/linux/rcu_sync.h
37194c1fbd4SYanteng Si
37294c1fbd4SYanteng Sikernel/rcu/sync.c
373