1.. include:: ../disclaimer-zh_CN.rst 2 3:Original: Documentation/core-api/kernel-api.rst 4 5:翻译: 6 7 司延腾 Yanteng Si <siyanteng@loongson.cn> 8 周彬彬 Binbin Zhou <zhoubinbin@loongson.cn> 9 10.. _cn_kernel-api.rst: 11 12============ 13Linux内核API 14============ 15 16 17列表管理函数 18============ 19 20该API在以下内核代码中: 21 22include/linux/list.h 23 24基本的C库函数 25============= 26 27在编写驱动程序时,一般不能使用C库中的例程。部分函数通常很有用,它们在 28下面被列出。这些函数的行为可能会与ANSI定义的略有不同,这些偏差会在文中 29注明。 30 31字符串转换 32---------- 33 34该API在以下内核代码中: 35 36lib/vsprintf.c 37 38include/linux/kernel.h 39 40include/linux/kernel.h 41 42lib/kstrtox.c 43 44lib/string_helpers.c 45 46字符串处理 47---------- 48 49该API在以下内核代码中: 50 51include/linux/fortify-string.h 52 53lib/string.c 54 55include/linux/string.h 56 57mm/util.c 58 59基本的内核库函数 60================ 61 62Linux内核提供了很多实用的基本函数。 63 64位运算 65------ 66 67该API在以下内核代码中: 68 69include/asm-generic/bitops/instrumented-atomic.h 70 71include/asm-generic/bitops/instrumented-non-atomic.h 72 73include/asm-generic/bitops/instrumented-lock.h 74 75位图运算 76-------- 77 78该API在以下内核代码中: 79 80lib/bitmap.c 81 82include/linux/bitmap.h 83 84include/linux/bitmap.h 85 86include/linux/bitmap.h 87 88lib/bitmap.c 89 90lib/bitmap.c 91 92include/linux/bitmap.h 93 94命令行解析 95---------- 96 97该API在以下内核代码中: 98 99lib/cmdline.c 100 101排序 102---- 103 104该API在以下内核代码中: 105 106lib/sort.c 107 108lib/list_sort.c 109 110文本检索 111-------- 112 113该API在以下内核代码中: 114 115lib/textsearch.c 116 117lib/textsearch.c 118 119include/linux/textsearch.h 120 121Linux中的CRC和数学函数 122====================== 123 124算术溢出检查 125------------ 126 127该API在以下内核代码中: 128 129include/linux/overflow.h 130 131CRC函数 132------- 133 134*译注:CRC,Cyclic Redundancy Check,循环冗余校验* 135 136该API在以下内核代码中: 137 138lib/crc4.c 139 140lib/crc7.c 141 142lib/crc8.c 143 144lib/crc16.c 145 146lib/crc32.c 147 148lib/crc-ccitt.c 149 150lib/crc-itu-t.c 151 152基数为2的对数和幂函数 153--------------------- 154 155该API在以下内核代码中: 156 157include/linux/log2.h 158 159整数幂函数 160---------- 161 162该API在以下内核代码中: 163 164lib/math/int_pow.c 165 166lib/math/int_sqrt.c 167 168除法函数 169-------- 170 171该API在以下内核代码中: 172 173include/asm-generic/div64.h 174 175include/linux/math64.h 176 177lib/math/gcd.c 178 179UUID/GUID 180--------- 181 182该API在以下内核代码中: 183 184lib/uuid.c 185 186内核IPC设备 187=========== 188 189IPC实用程序 190----------- 191 192该API在以下内核代码中: 193 194ipc/util.c 195 196FIFO 缓冲区 197=========== 198 199kfifo接口 200--------- 201 202该API在以下内核代码中: 203 204include/linux/kfifo.h 205 206转发接口支持 207============ 208 209转发接口支持旨在为工具和设备提供一种有效的机制,将大量数据从内核空间 210转发到用户空间。 211 212转发接口 213-------- 214 215该API在以下内核代码中: 216 217kernel/relay.c 218 219kernel/relay.c 220 221模块支持 222======== 223 224模块加载 225-------- 226 227该API在以下内核代码中: 228 229kernel/module/kmod.c 230 231模块接口支持 232------------ 233 234更多信息请参阅kernel/module/目录下的文件。 235 236硬件接口 237======== 238 239 240该API在以下内核代码中: 241 242kernel/dma.c 243 244资源管理 245-------- 246 247该API在以下内核代码中: 248 249kernel/resource.c 250 251kernel/resource.c 252 253MTRR处理 254-------- 255 256该API在以下内核代码中: 257 258arch/x86/kernel/cpu/mtrr/mtrr.c 259 260安全框架 261======== 262 263该API在以下内核代码中: 264 265security/security.c 266 267security/inode.c 268 269审计接口 270======== 271 272该API在以下内核代码中: 273 274kernel/audit.c 275 276kernel/auditsc.c 277 278kernel/auditfilter.c 279 280核算框架 281======== 282 283该API在以下内核代码中: 284 285kernel/acct.c 286 287块设备 288====== 289 290该API在以下内核代码中: 291 292include/linux/bio.h 293 294block/blk-core.c 295 296block/blk-core.c 297 298block/blk-map.c 299 300block/blk-sysfs.c 301 302block/blk-settings.c 303 304block/blk-flush.c 305 306block/blk-lib.c 307 308block/blk-integrity.c 309 310kernel/trace/blktrace.c 311 312block/genhd.c 313 314block/genhd.c 315 316字符设备 317======== 318 319该API在以下内核代码中: 320 321fs/char_dev.c 322 323时钟框架 324======== 325 326时钟框架定义了编程接口,以支持系统时钟树的软件管理。该框架广泛用于系统级芯片(SOC)平 327台,以支持电源管理和各种可能需要自定义时钟速率的设备。请注意,这些 “时钟”与计时或实 328时时钟(RTC)无关,它们都有单独的框架。这些:c:type: `struct clk <clk>` 实例可用于管理 329各种时钟信号,例如一个96理例如96MHz的时钟信号,该信号可被用于总线或外设的数据交换,或以 330其他方式触发系统硬件中的同步状态机转换。 331 332通过明确的软件时钟门控来支持电源管理:未使用的时钟被禁用,因此系统不会因为改变不在使用 333中的晶体管的状态而浪费电源。在某些系统中,这可能是由硬件时钟门控支持的,其中时钟被门控 334而不在软件中被禁用。芯片的部分,在供电但没有时钟的情况下,可能会保留其最后的状态。这种 335低功耗状态通常被称为*保留模式*。这种模式仍然会产生漏电流,特别是在电路几何结构较细的情 336况下,但对于CMOS电路来说,电能主要是随着时钟翻转而被消耗的。 337 338电源感知驱动程序只有在其管理的设备处于活动使用状态时才会启用时钟。此外,系统睡眠状态通 339常根据哪些时钟域处于活动状态而有所不同:“待机”状态可能允许从多个活动域中唤醒,而 340"mem"(暂停到RAM)状态可能需要更全面地关闭来自高速PLL和振荡器的时钟,从而限制了可能 341的唤醒事件源的数量。驱动器的暂停方法可能需要注意目标睡眠状态的系统特定时钟约束。 342 343一些平台支持可编程时钟发生器。这些可以被各种外部芯片使用,如其他CPU、多媒体编解码器以 344及对接口时钟有严格要求的设备。 345 346该API在以下内核代码中: 347 348include/linux/clk.h 349 350同步原语 351======== 352 353读-复制-更新(RCU) 354------------------- 355 356该API在以下内核代码中: 357 358include/linux/rcupdate.h 359 360kernel/rcu/tree.c 361 362kernel/rcu/tree_exp.h 363 364kernel/rcu/update.c 365 366include/linux/srcu.h 367 368kernel/rcu/srcutree.c 369 370include/linux/rculist_bl.h 371 372include/linux/rculist.h 373 374include/linux/rculist_nulls.h 375 376include/linux/rcu_sync.h 377 378kernel/rcu/sync.c 379