OXIESEC PANEL
- Current Dir:
/
/
usr
/
src
/
linux-headers-4.15.0-213
/
include
/
linux
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
π
..
-
05/09/2024 07:14:15 AM
rwxr-xr-x
π
8250_pci.h
1.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
a.out.h
354 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
acct.h
2.49 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
acpi.h
36.89 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
acpi_dma.h
3.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
acpi_iort.h
2.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
acpi_pmtmr.h
674 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
adb.h
1.79 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
adfs_fs.h
574 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
aer.h
1.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
agp_backend.h
3.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
agpgart.h
3.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ahci-remap.h
607 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
ahci_platform.h
1.67 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
aio.h
673 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
alarmtimer.h
1.83 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
altera_jtaguart.h
379 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
altera_uart.h
397 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
amba
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
amd-iommu.h
6.78 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
amifd.h
1.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
amifdreg.h
2.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
anon_inodes.h
494 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
apm-emulation.h
1.54 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
apm_bios.h
2.68 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
apple-gmux.h
1.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
apple_bl.h
498 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
arch_topology.h
840 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
arm-cci.h
2.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
arm-smccc.h
12.79 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
arm_sdei.h
2.33 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
asn1.h
1.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
asn1_ber_bytecode.h
2.72 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
asn1_decoder.h
675 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
assoc_array.h
3.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
assoc_array_priv.h
5.49 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
async.h
1.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
async_tx.h
6.81 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ata.h
33.61 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ata_platform.h
729 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
atalk.h
4.36 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ath9k_platform.h
1.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
atm.h
287 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
atm_suni.h
253 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
atm_tcp.h
511 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
atmdev.h
10.21 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
atmel-mci.h
1.4 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
atmel-ssc.h
9.74 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
atmel_pdc.h
1.47 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
atmel_tc.h
11.33 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
atomic.h
30.5 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
attribute_container.h
2.47 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
audit.h
17.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
auto_dev-ioctl.h
454 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
auto_fs.h
436 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
auxvec.h
304 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
average.h
2.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
avf
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
b1pcmcia.h
666 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
backing-dev-defs.h
8.53 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
backing-dev.h
13.8 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
backlight.h
5.3 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
badblocks.h
2.14 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
balloon_compaction.h
7.2 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bcd.h
559 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
bch.h
2.6 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bcm47xx_nvram.h
1.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bcm47xx_sprom.h
600 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
bcm47xx_wdt.h
555 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
bcm963xx_nvram.h
2.96 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bcm963xx_tag.h
3.6 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bcma
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
bfin_mac.h
559 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
binfmts.h
4.77 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bio.h
20.17 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
bit_spinlock.h
2.3 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bitfield.h
3.2 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
bitmap.h
16.68 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
bitops.h
6.69 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
bitrev.h
2.53 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
bits.h
883 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
blk-cgroup.h
22.2 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
blk-mq-pci.h
247 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
blk-mq-rdma.h
232 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
blk-mq-virtio.h
288 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
blk-mq.h
9.09 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
blk_types.h
10.52 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
blkdev.h
58.96 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
blkpg.h
436 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
blktrace_api.h
3.87 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
blockgroup_lock.h
810 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
bma150.h
1.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bootmem.h
11.7 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bottom_half.h
803 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
bpf-cgroup.h
4.53 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bpf.h
18.51 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
bpf_trace.h
196 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
bpf_types.h
1.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bpf_verifier.h
6.76 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
brcmphy.h
9.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bsearch.h
275 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
bsg-lib.h
2.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
bsg.h
773 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
btree-128.h
2.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
btree-type.h
3.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
btree.h
6.83 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
btrfs.h
145 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
buffer_head.h
14.38 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
bug.h
1.92 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
build_bug.h
3.15 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
bvec.h
4.39 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
byteorder
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
c2port.h
1.49 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cache.h
2.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cacheinfo.h
3.27 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
can
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
capability.h
7.6 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cb710.h
5.69 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cciss_ioctl.h
1.03 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ccp.h
18.26 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cdev.h
845 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
cdrom.h
8.75 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ceph
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
cfag12864b.h
2.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cgroup-defs.h
25.38 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cgroup.h
26.12 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cgroup_rdma.h
1.33 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cgroup_subsys.h
1.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
circ_buf.h
1.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cleancache.h
3.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
clk
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
clk-provider.h
34.29 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
clk.h
19.38 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
clkdev.h
1.54 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
clock_cooling.h
2.06 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
clockchips.h
7.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
clocksource.h
8.31 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cm4000_cs.h
199 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
cma.h
1.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cmdline-parser.h
1.21 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cn_proc.h
1.85 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cnt32_to_63.h
3.6 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
coda.h
2.16 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
coda_psdev.h
2.98 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
compaction.h
7.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
compat.h
27.39 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
compiler-clang.h
1.31 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
compiler-gcc.h
12.6 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
compiler-intel.h
1.3 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
compiler.h
10.06 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
compiler_types.h
7.5 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
completion.h
4.05 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
component.h
1.37 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
concap.h
3.69 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
configfs.h
9.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
connector.h
2.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
console.h
6.72 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
console_struct.h
6.87 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
consolemap.h
1.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
const.h
157 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
container.h
668 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
context_tracking.h
4.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
context_tracking_state.h
1.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cordic.h
1.75 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
coredump.h
783 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
coresight-pmu.h
1.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
coresight-stm.h
152 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
coresight.h
9.86 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
count_zeros.h
1.62 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cper.h
16.11 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cpu.h
6.86 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cpu_cooling.h
3.59 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cpu_pm.h
2.78 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cpu_rmap.h
1.86 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cpufeature.h
1.85 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cpufreq.h
27.62 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cpuhotplug.h
12.05 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cpuidle.h
8.68 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cpumask.h
25.38 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cpuset.h
7.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
crash_core.h
2.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
crash_dump.h
2.98 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
crc-ccitt.h
369 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
crc-itu-t.h
613 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
crc-t10dif.h
415 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
crc16.h
622 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
crc32.h
2.83 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
crc32c.h
293 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
crc4.h
192 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
crc7.h
316 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
crc8.h
3.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cred.h
12.29 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
crush
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
crypto.h
55.52 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
cryptohash.h
319 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
cs5535.h
6.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ctype.h
1.75 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
cuda.h
501 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
cyclades.h
10.36 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
davinci_emac.h
1.12 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dax.h
3.65 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
dca.h
2.63 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dcache.h
18.78 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
dccp.h
10.73 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dcookies.h
1.3 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
debug_locks.h
1.51 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
debugfs.h
11.09 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
debugobjects.h
3.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
decompress
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
delay.h
1.83 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
delayacct.h
5.17 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
delayed_call.h
709 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
dell-led.h
128 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
devcoredump.h
2.78 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
devfreq-event.h
5.64 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
devfreq.h
12.53 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
devfreq_cooling.h
3.54 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
device-mapper.h
17.85 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
device.h
55.51 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
device_cgroup.h
1.86 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
devpts_fs.h
1.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
digsig.h
1.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dim.h
8.98 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
dio.h
10.97 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dirent.h
216 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
dlm.h
6.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dlm_plock.h
678 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
dm-dirty-log.h
3.94 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dm-io.h
1.93 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dm-kcopyd.h
2.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dm-region-hash.h
3.11 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dm9000.h
1.11 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dma
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
dma-buf.h
14.7 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dma-contiguous.h
4.48 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dma-debug.h
5.61 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dma-direction.h
338 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
dma-fence-array.h
2.49 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
dma-fence.h
17.29 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dma-iommu.h
3.62 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
dma-mapping.h
24.61 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
dma_remapping.h
1.46 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dmaengine.h
46.04 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
dmapool.h
1.09 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dmar.h
7.94 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
dmi.h
4.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dnotify.h
1.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dns_resolver.h
1.31 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dqblk_qtree.h
2.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dqblk_v1.h
327 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
dqblk_v2.h
406 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
drbd.h
10.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
drbd_genl.h
21.49 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
drbd_genl_api.h
1.77 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
drbd_limits.h
7.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ds2782_battery.h
158 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
dsa
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
dtlk.h
3.5 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dw_apb_timer.h
1.7 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
dynamic_debug.h
5.08 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
dynamic_queue_limits.h
3.7 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
earlycpio.h
359 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
ecryptfs.h
3.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
edac.h
20.26 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
edd.h
1.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
edma.h
807 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
eeprom_93cx6.h
2.94 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
eeprom_93xx46.h
879 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
efi-bgrt.h
644 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
efi.h
49.13 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
efs_vh.h
1.55 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
eisa.h
2.96 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
elevator.h
9.26 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
elf-fdpic.h
2.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
elf-randomize.h
583 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
elf.h
1.53 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
elfcore-compat.h
1.24 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
elfcore.h
2.52 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
elfnote.h
3.54 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
enclosure.h
4.6 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
err.h
1.55 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
errno.h
1.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
errqueue.h
524 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
errseq.h
373 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
etherdevice.h
15.65 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ethtool.h
17.3 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
eventfd.h
2.36 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
eventpoll.h
2.16 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
evm.h
2.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
export.h
3.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
exportfs.h
7.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ext2_fs.h
967 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
extable.h
999 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
extcon
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
extcon-provider.h
4.33 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
extcon.h
10.4 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
f2fs_fs.h
17.51 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
f75375s.h
541 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
falloc.h
792 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
fanotify.h
245 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
fault-inject.h
1.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fb.h
28.74 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
fbcon.h
492 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
fcdevice.h
988 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
fcntl.h
1.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fd.h
490 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
fddidevice.h
1.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fdtable.h
3.28 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
fec.h
609 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
file.h
2.18 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
filter.h
27.5 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
fips.h
167 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
firewire.h
13.4 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
firmware
-
05/09/2024 07:14:14 AM
rwxr-xr-x
π
firmware-map.h
1.32 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
firmware.h
2.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fixp-arith.h
4.41 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
flat.h
1.61 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
flex_array.h
4.31 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
flex_proportions.h
2.81 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fmc-sdb.h
1.29 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fmc.h
9.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
font.h
1.6 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
fpga
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
frame.h
813 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
freezer.h
8.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
frontswap.h
2.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fs.h
110.97 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
fs_enet_pd.h
3.38 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fs_pin.h
619 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
fs_stack.h
811 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
fs_struct.h
1.03 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fs_uart_pd.h
1.49 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fscache-cache.h
18.4 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
fscache.h
27.54 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fscrypt.h
8.93 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
fscrypt_notsupp.h
4.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fscrypt_supp.h
6.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fsi.h
2.37 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fsl
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
fsl-diu-fb.h
4.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fsl_devices.h
4.32 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fsl_hypervisor.h
2.76 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fsl_ifc.h
25.13 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
fsldma.h
398 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
fsnotify.h
7.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
fsnotify_backend.h
16.66 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ftrace.h
29.91 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ftrace_irq.h
823 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
futex.h
2.4 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
fwnode.h
4.41 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
gameport.h
5.56 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
gcd.h
193 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
genalloc.h
5.92 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
genetlink.h
1.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
genhd.h
22.77 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
genl_magic_func.h
12.05 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
genl_magic_struct.h
7.66 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
getcpu.h
641 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
gfp.h
23.37 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
glob.h
256 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
goldfish.h
605 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
gpio
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
gpio-pxa.h
571 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
gpio.h
5.19 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
gpio_keys.h
1.63 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hardirq.h
1.95 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hash.h
3 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hashtable.h
6.63 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hdlc.h
3.33 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hdlcdrv.h
6.32 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hdmi.h
9.36 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hid-debug.h
2.07 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hid-roccat.h
688 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
hid-sensor-hub.h
9.25 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hid-sensor-ids.h
7.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hid.h
35.93 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hiddev.h
2.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hidraw.h
1.49 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
highmem.h
5.84 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
highuid.h
3.12 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hil.h
18.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hil_mlc.h
5.13 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hippidevice.h
1.23 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hmm.h
18.19 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
host1x.h
9.02 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hp_sdc.h
14.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hpet.h
2.55 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hrtimer.h
14.02 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hsi
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
htcpld.h
617 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
huge_mm.h
10.1 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hugetlb.h
17 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hugetlb_cgroup.h
2.93 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hugetlb_inline.h
374 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
hw_breakpoint.h
3.85 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hw_random.h
2.03 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hwmon-sysfs.h
1.98 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hwmon-vid.h
1.48 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hwmon.h
12.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hwspinlock.h
11.06 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
hyperv.h
38.89 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
hypervisor.h
400 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
i2c-algo-bit.h
2.24 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-algo-pca.h
2.89 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
i2c-algo-pcf.h
1.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-dev.h
1.03 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-gpio.h
1.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-mux-gpio.h
1.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-mux.h
2.29 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-ocores.h
757 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-omap.h
1.21 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-pca-platform.h
441 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-pnx.h
923 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-pxa.h
438 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-smbus.h
1.94 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c-xiic.h
1.41 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i2c.h
30.91 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
i7300_idle.h
1.95 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i8042.h
2.14 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
i8253.h
809 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
icmp.h
863 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
icmpv6.h
2.5 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ide.h
46.27 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
idr.h
7.82 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ieee80211.h
83.19 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ieee802154.h
11.5 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
if_arp.h
1.86 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
if_bridge.h
2.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
if_eql.h
1.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
if_ether.h
1.47 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
if_fddi.h
3.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
if_frad.h
2.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
if_link.h
554 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
if_ltalk.h
188 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
if_macvlan.h
2.2 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
if_phonet.h
319 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
if_pppol2tp.h
727 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
if_pppox.h
3.05 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
if_tap.h
2.24 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
if_team.h
7.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
if_tun.h
1.14 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
if_tunnel.h
409 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
if_vlan.h
19.2 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
igmp.h
4.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ihex.h
1.95 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
iio
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
ima.h
2.53 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
imx-media.h
811 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
in.h
2.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
in6.h
1.85 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
inet.h
2.8 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
inet_diag.h
2.42 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
inetdevice.h
8.25 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
init.h
9.1 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
init_ohci1394_dma.h
196 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
init_task.h
7.84 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
initrd.h
685 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
inotify.h
696 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
input
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
input-polldev.h
2.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
input.h
18.7 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
integrity.h
1.05 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
intel-iommu.h
16.85 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
intel-pti.h
1.56 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
intel-svm.h
4.96 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
interrupt.h
21.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
interval_tree.h
831 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
interval_tree_generic.h
8 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
io-64-nonatomic-hi-lo.h
1.14 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
io-64-nonatomic-lo-hi.h
1.14 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
io-mapping.h
4.36 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
io.h
5.86 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ioc3.h
3.14 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ioc4.h
5.78 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
iocontext.h
4.76 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
iomap.h
3.95 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
iommu-common.h
1.41 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
iommu-helper.h
950 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
iommu.h
21.74 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
iopoll.h
5.72 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ioport.h
10.74 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ioprio.h
1.96 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
iova.h
7.03 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ip.h
1.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ipack.h
8.85 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ipc.h
695 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
ipc_namespace.h
4.81 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ipmi-fru.h
3.64 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ipmi.h
11.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ipmi_smi.h
8.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ipv6.h
8.92 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ipv6_route.h
594 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
irq.h
39.04 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
irq_cpustat.h
949 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
irq_poll.h
575 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
irq_sim.h
1.16 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
irq_work.h
1.3 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
irqbypass.h
3.59 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
irqchip
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
irqchip.h
1.54 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
irqdesc.h
8.15 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
irqdomain.h
19.21 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
irqflags.h
4.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
irqhandler.h
362 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
irqnr.h
856 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
irqreturn.h
503 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
isa.h
2.12 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
isapnp.h
3.8 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
iscsi_boot_sysfs.h
4.09 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
iscsi_ibft.h
1.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
isdn
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
isdn.h
22.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
isdn_divertif.h
1.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
isdn_ppp.h
6.64 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
isdnif.h
19.26 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
isicom.h
1.49 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
jbd2.h
47.14 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
jhash.h
4.62 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
jiffies.h
15.4 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
journal-head.h
2.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
joystick.h
1.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
jump_label.h
13.32 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
jump_label_ratelimit.h
1.12 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
jz4740-adc.h
1023 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
jz4780-nemc.h
1.16 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kallsyms.h
3.59 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kasan-checks.h
441 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
kasan.h
4.48 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kbd_diacr.h
198 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
kbd_kern.h
3.84 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kbuild.h
380 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
kconfig.h
2.53 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
kcore.h
664 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
kcov.h
802 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
kdb.h
7.3 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kdebug.h
487 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
kdev_t.h
1.8 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
kern_levels.h
1.58 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kernel-page-flags.h
505 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
kernel.h
31.31 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
kernel_stat.h
2.5 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kernelcapi.h
4.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kernfs.h
16.88 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
kexec.h
10.06 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
key-type.h
6.16 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
key.h
12.75 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
keyboard.h
665 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
kfifo.h
24.84 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
kgdb.h
10.72 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
khugepaged.h
2.36 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
klist.h
1.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kmemleak.h
3.86 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kmod.h
1.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kmsg_dump.h
2.85 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kobj_map.h
545 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
kobject.h
7.62 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
kobject_ns.h
1.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kprobes.h
14.71 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
kref.h
3.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ks0108.h
1.57 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ks8842.h
1.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ks8851_mll.h
1.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ksm.h
2.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kthread.h
6.7 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ktime.h
6.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kvm_host.h
37.83 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
kvm_irqfd.h
2.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
kvm_para.h
284 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
kvm_types.h
1.67 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
l2tp.h
261 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
lapb.h
1.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
latencytop.h
1.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
lcd.h
4.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
lcm.h
275 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
led-class-flash.h
5.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
led-lm3530.h
3.7 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
leds-bd2802.h
642 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
leds-lp3944.h
1.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
leds-lp3952.h
2.5 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
leds-pca9532.h
1.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
leds-regulator.h
1.29 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
leds-tca6507.h
1.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
leds.h
13.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
leds_pwm.h
407 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
libata.h
64.88 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
libfdt.h
244 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
libfdt_env.h
494 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
libgcc.h
1.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
libnvdimm.h
7.16 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
libps2.h
1.75 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
license.h
374 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
lightnvm.h
10.95 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
linkage.h
2.64 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
linux_logo.h
2.06 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
lis3lv02d.h
5 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
list.h
23.71 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
list_bl.h
4.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
list_lru.h
6.29 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
list_nulls.h
3.47 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
list_sort.h
277 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
livepatch.h
6.94 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
llc.h
749 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
llist.h
9.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
lockd
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
lockdep.h
18.61 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
lockref.h
1.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
log2.h
5.48 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
logic_pio.h
3.24 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
lp.h
2.76 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
lru_cache.h
12.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
lsm_audit.h
2.73 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
lsm_hooks.h
88.04 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
lz4.h
26.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
lzo.h
1.37 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mISDNdsp.h
1.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mISDNhw.h
5.78 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mISDNif.h
14.91 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mailbox
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
mailbox_client.h
1.79 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mailbox_controller.h
5.4 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
maple.h
2.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
marvell_phy.h
1.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
math64.h
6.42 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
max17040_battery.h
474 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mbcache.h
1.57 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mbus.h
3.09 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mc146818rtc.h
4.46 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mc6821.h
1.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mcb.h
3.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mdev.h
4.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mdio-bitbang.h
1.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mdio-mux.h
1021 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mdio.h
9.01 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mei_cl_bus.h
3.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mem_encrypt.h
1.21 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
memblock.h
14.6 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
memcontrol.h
29.63 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
memory.h
4.52 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
memory_hotplug.h
10.29 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mempolicy.h
7.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mempool.h
2.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
memremap.h
7.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
memstick.h
9.73 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mfd
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
mic_bus.h
3.2 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
micrel_phy.h
1.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
microchipphy.h
2.84 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
migrate.h
10.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
migrate_mode.h
758 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mii.h
8.74 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
miscdevice.h
2.81 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mlx4
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
mlx5
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
mm-arch-hooks.h
679 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mm.h
85.89 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mm_inline.h
3.44 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mm_types.h
19.25 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mm_types_task.h
2.4 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mman.h
3.26 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mmc
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
mmdebug.h
2.32 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mmiotrace.h
3.05 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mmu_context.h
378 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mmu_notifier.h
15.84 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mmzone.h
39.66 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mnt_namespace.h
617 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
mod_devicetable.h
19.33 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
module.h
22.23 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
moduleloader.h
2.72 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
moduleparam.h
19.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mount.h
3.45 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mpage.h
761 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mpi.h
5.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mpls.h
394 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mpls_iptunnel.h
178 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mroute.h
4.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mroute6.h
3.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
msdos_fs.h
273 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
msg.h
1.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
msi.h
11.79 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mtd
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
mutex.h
6.91 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
mux
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
mv643xx.h
52.4 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mv643xx_eth.h
1.95 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
mv643xx_i2c.h
545 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mvebu-pmsu.h
520 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
mxm-wmi.h
1.05 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
n_r3964.h
4.06 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
namei.h
3.41 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nd.h
5.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
net.h
11.33 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
netdev_features.h
9.39 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
netdevice.h
140.44 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
netfilter
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
netfilter.h
11.74 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
netfilter_arp
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
netfilter_bridge
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
netfilter_bridge.h
1.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
netfilter_defs.h
239 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
netfilter_ingress.h
1.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
netfilter_ipv4
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
netfilter_ipv4.h
424 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
netfilter_ipv6
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
netfilter_ipv6.h
1.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
netlink.h
6.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
netpoll.h
2.69 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nfs.h
1.31 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nfs3.h
260 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
nfs4.h
17.5 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
nfs_fs.h
16.12 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
nfs_fs_i.h
308 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
nfs_fs_sb.h
8.81 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nfs_iostat.h
4.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nfs_page.h
6.26 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
nfs_xdr.h
38.79 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
nfsacl.h
1.15 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nl802154.h
4.23 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nls.h
3.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nmi.h
6.56 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
node.h
3 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nodemask.h
17.08 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
nospec.h
2.21 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
notifier.h
7.72 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ns_common.h
235 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
nsc_gpio.h
1.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nsproxy.h
2.48 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ntb.h
46.52 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ntb_transport.h
3.8 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nubus.h
4.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
numa.h
292 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
nvme-fc-driver.h
38.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nvme-fc.h
8.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nvme-rdma.h
2.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nvme.h
26.61 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nvmem-consumer.h
4.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nvmem-provider.h
1.52 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
nvram.h
495 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
of.h
40.4 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
of_address.h
4.47 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_device.h
3.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_dma.h
2.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_fdt.h
4.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_gpio.h
4.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_graph.h
3.56 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_iommu.h
1 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_irq.h
3.6 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_mdio.h
2.98 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_net.h
708 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
of_pci.h
2.23 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_pdt.h
1.4 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_platform.h
4.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
of_reserved_mem.h
2.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
oid_registry.h
3.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
olpc-ec.h
1.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
omap-dma.h
10.5 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
omap-dmaengine.h
583 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
omap-gpmc.h
2.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
omap-iommu.h
520 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
omap-mailbox.h
777 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
omapfb.h
1.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
once.h
2.8 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
oom.h
3.15 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
openvswitch.h
844 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
oprofile.h
6.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
osq_lock.h
1.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
overflow.h
9.26 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
oxu210hp.h
197 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
padata.h
5.82 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
page-flags-layout.h
2.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
page-flags.h
23.91 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
page-isolation.h
1.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
page_counter.h
1.46 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
page_ext.h
1.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
page_idle.h
2.62 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
page_owner.h
2.3 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
page_ref.h
4.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pageblock-flags.h
3.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pagemap.h
19.02 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pagevec.h
2.3 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
parman.h
2.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
parport.h
17.84 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
parport_pc.h
6.56 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
parser.h
1.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pata_arasan_cf_data.h
1.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
patchkey.h
757 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
path.h
572 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pch_dma.h
999 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pci-acpi.h
3.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pci-aspm.h
882 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
pci-ats.h
1.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pci-dma-compat.h
4.41 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pci-dma.h
454 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pci-ecam.h
2.54 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pci-ep-cfs.h
1.09 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pci-epc.h
5.38 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pci-epf.h
4.83 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pci.h
81.59 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pci_hotplug.h
6.91 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pci_ids.h
120.12 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pcieport_if.h
2.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pda_power.h
1.12 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pe.h
15.6 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
percpu-defs.h
18.13 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
percpu-refcount.h
9.93 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
percpu-rwsem.h
4.09 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
percpu.h
5.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
percpu_counter.h
4.26 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
percpu_ida.h
2.32 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
perf
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
perf_event.h
38.78 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
perf_regs.h
1.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
personality.h
393 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pfn.h
666 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pfn_t.h
3.23 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
phonet.h
1.12 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
phy
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
phy.h
31.11 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
phy_fixed.h
1.64 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
phy_led_triggers.h
1.46 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
phylink.h
5.06 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pid.h
5.77 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pid_namespace.h
2.33 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pim.h
2.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pinctrl
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
pipe_fs_i.h
6.46 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pkeys.h
916 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pktcdvd.h
5.87 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pl320-ipc.h
758 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
platform_data
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
platform_device.h
12.43 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
plist.h
8.69 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pm-trace.h
940 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pm.h
34.21 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pm2301_charger.h
1.68 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pm_clock.h
2.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pm_domain.h
9.03 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pm_opp.h
10.08 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pm_qos.h
8.51 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pm_runtime.h
8.52 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pm_wakeirq.h
1.31 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pm_wakeup.h
6.61 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pmbus.h
1.58 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pmu.h
2.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pnfs_osd_xdr.h
9.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pnp.h
14.89 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
poison.h
2.66 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
poll.h
3.24 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
posix-clock.h
4.55 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
posix-timers.h
3.55 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
posix_acl.h
3.06 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
posix_acl_xattr.h
1.58 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
power
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
power_supply.h
13.41 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
powercap.h
12.59 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ppp-comp.h
3.1 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ppp_channel.h
3.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ppp_defs.h
454 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pps-gpio.h
1.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pps_kernel.h
3.55 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pr.h
566 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
prandom.h
2.81 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
preempt.h
9.33 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
prefetch.h
1.54 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
prime_numbers.h
1.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
printk.h
15.24 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
proc_fs.h
3.26 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
proc_ns.h
2.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
processor.h
2.14 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
profile.h
2.68 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
projid.h
2.34 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
property.h
9.79 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
psci.h
1.87 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pstore.h
7.58 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pstore_ram.h
2.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
pti.h
240 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
ptp_classify.h
2.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ptp_clock_kernel.h
8.56 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ptr_ring.h
16.29 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ptrace.h
14.57 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
purgatory.h
589 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pvclock_gtod.h
548 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pwm.h
16.8 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
pwm_backlight.h
740 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pxa168_eth.h
728 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
pxa2xx_ssp.h
9.8 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
qcom_scm.h
4.12 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
qed
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
qnx6_fs.h
3.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
quicklist.h
2.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
quota.h
18.87 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
quotaops.h
10.17 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
radix-tree.h
21.77 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
raid
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
raid_class.h
2.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ramfs.h
762 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
random.h
3.98 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
range.h
651 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
ras.h
1.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ratelimit.h
2.81 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rational.h
639 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
rbtree.h
5.36 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rbtree_augmented.h
8.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rbtree_latch.h
6.62 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rcu_node_tree.h
4.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rcu_segcblist.h
3.26 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rcu_sync.h
2.57 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rculist.h
23.53 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rculist_bl.h
4.36 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rculist_nulls.h
6.17 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rcupdate.h
33.26 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rcupdate_wait.h
1.63 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rcutiny.h
3.64 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rcutree.h
3.56 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rcuwait.h
1.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
reboot-mode.h
600 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
reboot.h
2.05 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
reciprocal_div.h
1.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
refcount.h
2.6 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
regmap.h
42.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
regset.h
15.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
regulator
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
relay.h
8.84 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
remoteproc
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
remoteproc.h
18.48 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
reservation.h
8.12 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
reset
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
reset-controller.h
2.16 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
reset.h
13.69 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
resource.h
339 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
resource_ext.h
2.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
restart_block.h
1.11 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rfkill.h
9.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rhashtable.h
38.24 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ring_buffer.h
6.79 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rio.h
19.23 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rio_drv.h
14.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rio_ids.h
1.29 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rio_regs.h
19.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rmap.h
9.08 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rmi.h
12.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rndis.h
16.86 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rodata_test.h
559 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
root_dev.h
579 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
rpmsg
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
rpmsg.h
8.37 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rslib.h
2.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rtc
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
rtc.h
8.71 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rtmutex.h
3.47 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rtnetlink.h
4.27 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rtsx_common.h
1.44 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rtsx_pci.h
40.14 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rtsx_usb.h
15.95 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
rwlock.h
4.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rwlock_api_smp.h
7.67 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rwlock_types.h
1.12 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rwsem-spinlock.h
1.58 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
rwsem.h
6 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
s3c_adc_battery.h
971 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sa11x0-dma.h
572 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sbitmap.h
13.56 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
scatterlist.h
13.29 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
scc.h
2.84 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sched
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
sched.h
47.45 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
sched_clock.h
661 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
scif.h
58.85 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
scpi_protocol.h
2.58 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
screen_info.h
191 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sctp.h
21.92 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
scx200.h
1.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
scx200_gpio.h
2.38 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sdb.h
4.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sdla.h
6.9 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
seccomp.h
2.66 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
securebits.h
239 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
security.h
47.81 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
sed-opal.h
1.94 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
seg6.h
121 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
seg6_genl.h
136 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
seg6_hmac.h
136 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
seg6_iptunnel.h
148 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
seg6_local.h
100 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
selection.h
1.41 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
selinux.h
910 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sem.h
2.02 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
semaphore.h
1.36 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
seq_buf.h
3.15 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
seq_file.h
6.68 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
seq_file_net.h
713 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
seqlock.h
16.48 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
seqno-fence.h
3.96 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
serdev.h
9.48 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
serial.h
630 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
serial_8250.h
6.01 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
serial_bcm63xx.h
4.73 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
serial_core.h
17.72 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
serial_max3100.h
1.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
serial_pnx8xxx.h
2.61 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
serial_s3c.h
9.24 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
serial_sci.h
1.57 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
serio.h
4.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
set_memory.h
740 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sfi.h
5.75 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sfi_acpi.h
3.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sfp.h
10.4 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sh_clk.h
5.96 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sh_dma.h
3.61 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sh_eth.h
417 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sh_intc.h
3.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sh_timer.h
172 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
shdma-base.h
4.41 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
shm.h
1.71 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
shmem_fs.h
5.33 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
shrinker.h
2.82 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
signal.h
12.57 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
signal_types.h
1.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
signalfd.h
817 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
siphash.h
5.59 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
sirfsoc_dma.h
162 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sizes.h
1.26 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
skb_array.h
5.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
skbuff.h
120.16 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
slab.h
21.45 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
slab_def.h
2.37 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
slub_def.h
5.44 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
sm501-regs.h
11.76 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sm501.h
4.63 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
smc911x.h
294 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
smc91x.h
1.57 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
smp.h
5.67 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
smpboot.h
2.17 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
smsc911x.h
2.29 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
smscphy.h
1.25 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
soc
-
05/09/2024 07:14:15 AM
rwxr-xr-x
π
sock_diag.h
2.16 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
socket.h
11.35 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
sonet.h
469 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sony-laptop.h
1.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sonypi.h
2.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sort.h
247 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sound.h
807 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
soundcard.h
1.59 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
spi
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
spinlock.h
11.04 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
spinlock_api_smp.h
5.4 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
spinlock_api_up.h
3.31 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
spinlock_types.h
1.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
spinlock_types_up.h
726 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
spinlock_up.h
2.16 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
splice.h
3.01 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
spmi.h
5.95 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sram.h
844 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
srcu.h
6.38 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
srcutiny.h
3.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
srcutree.h
5.15 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ssb
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
ssbi.h
1.11 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
stackdepot.h
967 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
stackprotector.h
324 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
stacktrace.h
1.45 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
start_kernel.h
334 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
stat.h
1.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
statfs.h
1.31 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
static_key.h
30 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
stddef.h
620 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
ste_modem_shm.h
1.59 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
stm.h
4.75 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
stmmac.h
5.39 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
stmp3xxx_rtc_wdt.h
332 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
stmp_device.h
619 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
stop_machine.h
4.68 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
string.h
14.97 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
string_helpers.h
2.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
stringhash.h
2.65 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
stringify.h
341 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sudmac.h
1.24 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sungem_phy.h
3.94 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sunrpc
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
sunserialcore.h
1.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sunxi-rsb.h
2.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
superhyway.h
2.81 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
suspend.h
19.13 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
svga.h
3.75 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sw842.h
328 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
swab.h
569 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
swait.h
9.33 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
swap.h
21.58 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
swap_cgroup.h
971 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
swap_slots.h
840 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
swapfile.h
556 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
swapops.h
9.27 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
swiotlb.h
3.8 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
switchtec.h
8.1 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
sxgbe_platform.h
1.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sync_file.h
1.57 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
synclink.h
989 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sys.h
960 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sys_soc.h
1.21 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
syscalls.h
39.85 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
syscore_ops.h
635 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
sysctl.h
7.55 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
sysfs.h
15.41 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
syslog.h
1.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sysrq.h
1.79 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
sysv_fs.h
9.03 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
t10-pi.h
1.21 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
task_io_accounting.h
1.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
task_io_accounting_ops.h
2.55 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
task_work.h
617 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
taskstats_kern.h
957 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
tboot.h
3.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
tc.h
3.45 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
tca6416_keypad.h
847 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
tcp.h
15.13 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
tee_drv.h
8.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
textsearch.h
4.73 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
textsearch_fsm.h
1.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
tfrc.h
1.89 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
thermal.h
19.62 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
thinkpad_acpi.h
320 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
thread_info.h
4.1 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
threads.h
1.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
thunderbolt.h
19.02 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ti_wilink_st.h
14.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
tick.h
7.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
tifm.h
4.8 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
timb_dma.h
1.74 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
timb_gpio.h
1.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
time.h
3.71 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
time32.h
5.64 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
time64.h
4.01 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
timecounter.h
4.58 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
timekeeper_internal.h
5.01 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
timekeeping.h
5.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
timekeeping32.h
3.13 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
timer.h
6.74 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
timerfd.h
508 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
timeriomem-rng.h
475 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
timerqueue.h
1.19 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
timex.h
6.61 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
tnum.h
2.74 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
topology.h
4.85 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
torture.h
3.58 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
toshiba.h
904 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
tpm.h
3 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
tpm_command.h
847 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
trace.h
964 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
trace_clock.h
667 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
trace_events.h
16.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
trace_seq.h
3.74 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
tracefs.h
1.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
tracehook.h
7.08 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
tracepoint-defs.h
778 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
tracepoint.h
16.26 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
transport_class.h
2.5 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ts-nbus.h
532 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
tsacct_kern.h
1.2 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
tty.h
28.03 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
tty_driver.h
15.45 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
tty_flip.h
1.62 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
tty_ldisc.h
7.69 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
typecheck.h
624 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
types.h
5.61 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
u64_stats_sync.h
5.43 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
uaccess.h
9.95 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ucb1400.h
4.26 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ucs2_string.h
662 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
udp.h
3.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
uidgid.h
4.07 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
uio.h
7.66 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
uio_driver.h
4.07 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
ulpi
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
umh.h
1.79 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
unaligned
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
uprobes.h
6.28 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
usb
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
usb.h
75.97 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
usb_usual.h
3.58 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
usbdevice_fs.h
2.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
user-return-notifier.h
1.18 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
user.h
22 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
user_namespace.h
4.34 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
userfaultfd_k.h
3.57 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
util_macros.h
1.17 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
uts.h
388 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
utsname.h
1.72 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
uuid.h
2.35 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
uwb
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
uwb.h
25.22 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
verification.h
1.57 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
vermagic.h
1.05 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vexpress.h
1.44 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vfio.h
6.32 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vfs.h
116 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
vga_switcheroo.h
8.4 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
vgaarb.h
5.12 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
via-core.h
7.27 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
via-gpio.h
334 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
via.h
932 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
via_i2c.h
1.48 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
videodev2.h
2.68 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
virtio.h
7.07 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
virtio_byteorder.h
1.46 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
virtio_caif.h
492 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
virtio_config.h
12.82 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
virtio_console.h
1.93 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
virtio_net.h
5.33 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
virtio_ring.h
2.96 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
virtio_vsock.h
5.05 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
vlynq.h
3.88 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vm_event_item.h
2.96 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
vm_sockets.h
703 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
vmacache.h
932 bytes
06/16/2023 05:32:39 PM
rw-r--r--
π
vmalloc.h
6.29 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
vme.h
5.66 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vmpressure.h
1.7 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vmstat.h
10.93 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vmw_vmci_api.h
3.19 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vmw_vmci_defs.h
27.93 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
vringh.h
7.76 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vt.h
611 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
vt_buffer.h
1.49 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
vt_kern.h
6.21 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
vtime.h
3.57 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
w1-gpio.h
729 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
w1.h
9.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
wait.h
36.36 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
wait_bit.h
9.85 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
wanrouter.h
210 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
watchdog.h
7.81 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
wimax
-
05/09/2024 07:14:16 AM
rwxr-xr-x
π
win_minmax.h
832 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
wireless.h
1.4 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
wkup_m3_ipc.h
1.53 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
wl12xx.h
1.39 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
wm97xx.h
10.61 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
wmi.h
1.94 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
workqueue.h
21.56 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
writeback.h
12.13 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
ww_mutex.h
12.42 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
xattr.h
3.38 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
xxhash.h
7.65 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
xz.h
11.16 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
yam.h
2.82 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
z2_battery.h
318 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
zbud.h
740 bytes
01/28/2018 09:20:33 PM
rw-r--r--
π
zconf.h
1.73 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
zlib.h
27.97 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
zorro.h
3.94 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
zpool.h
2.99 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
zsmalloc.h
1.64 KB
06/16/2023 05:32:39 PM
rw-r--r--
π
zstd.h
48.64 KB
01/28/2018 09:20:33 PM
rw-r--r--
π
zutil.h
2.73 KB
01/28/2018 09:20:33 PM
rw-r--r--
Editing: crypto.h
Close
/* * Scatterlist Cryptographic API. * * Copyright (c) 2002 James Morris <jmorris@intercode.com.au> * Copyright (c) 2002 David S. Miller (davem@redhat.com) * Copyright (c) 2005 Herbert Xu <herbert@gondor.apana.org.au> * * Portions derived from Cryptoapi, by Alexander Kjeldaas <astor@fast.no> * and Nettle, by Niels MΓΆller. * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation; either version 2 of the License, or (at your option) * any later version. * */ #ifndef _LINUX_CRYPTO_H #define _LINUX_CRYPTO_H #include <linux/atomic.h> #include <linux/kernel.h> #include <linux/list.h> #include <linux/bug.h> #include <linux/slab.h> #include <linux/string.h> #include <linux/uaccess.h> #include <linux/completion.h> /* * Autoloaded crypto modules should only use a prefixed name to avoid allowing * arbitrary modules to be loaded. Loading from userspace may still need the * unprefixed names, so retains those aliases as well. * This uses __MODULE_INFO directly instead of MODULE_ALIAS because pre-4.3 * gcc (e.g. avr32 toolchain) uses __LINE__ for uniqueness, and this macro * expands twice on the same line. Instead, use a separate base name for the * alias. */ #define MODULE_ALIAS_CRYPTO(name) \ __MODULE_INFO(alias, alias_userspace, name); \ __MODULE_INFO(alias, alias_crypto, "crypto-" name) /* * Algorithm masks and types. */ #define CRYPTO_ALG_TYPE_MASK 0x0000000f #define CRYPTO_ALG_TYPE_CIPHER 0x00000001 #define CRYPTO_ALG_TYPE_COMPRESS 0x00000002 #define CRYPTO_ALG_TYPE_AEAD 0x00000003 #define CRYPTO_ALG_TYPE_BLKCIPHER 0x00000004 #define CRYPTO_ALG_TYPE_ABLKCIPHER 0x00000005 #define CRYPTO_ALG_TYPE_SKCIPHER 0x00000005 #define CRYPTO_ALG_TYPE_GIVCIPHER 0x00000006 #define CRYPTO_ALG_TYPE_KPP 0x00000008 #define CRYPTO_ALG_TYPE_ACOMPRESS 0x0000000a #define CRYPTO_ALG_TYPE_SCOMPRESS 0x0000000b #define CRYPTO_ALG_TYPE_RNG 0x0000000c #define CRYPTO_ALG_TYPE_AKCIPHER 0x0000000d #define CRYPTO_ALG_TYPE_DIGEST 0x0000000e #define CRYPTO_ALG_TYPE_HASH 0x0000000e #define CRYPTO_ALG_TYPE_SHASH 0x0000000e #define CRYPTO_ALG_TYPE_AHASH 0x0000000f #define CRYPTO_ALG_TYPE_HASH_MASK 0x0000000e #define CRYPTO_ALG_TYPE_AHASH_MASK 0x0000000e #define CRYPTO_ALG_TYPE_BLKCIPHER_MASK 0x0000000c #define CRYPTO_ALG_TYPE_ACOMPRESS_MASK 0x0000000e #define CRYPTO_ALG_LARVAL 0x00000010 #define CRYPTO_ALG_DEAD 0x00000020 #define CRYPTO_ALG_DYING 0x00000040 #define CRYPTO_ALG_ASYNC 0x00000080 /* * Set this bit if and only if the algorithm requires another algorithm of * the same type to handle corner cases. */ #define CRYPTO_ALG_NEED_FALLBACK 0x00000100 /* * This bit is set for symmetric key ciphers that have already been wrapped * with a generic IV generator to prevent them from being wrapped again. */ #define CRYPTO_ALG_GENIV 0x00000200 /* * Set if the algorithm has passed automated run-time testing. Note that * if there is no run-time testing for a given algorithm it is considered * to have passed. */ #define CRYPTO_ALG_TESTED 0x00000400 /* * Set if the algorithm is an instance that is built from templates. */ #define CRYPTO_ALG_INSTANCE 0x00000800 /* Set this bit if the algorithm provided is hardware accelerated but * not available to userspace via instruction set or so. */ #define CRYPTO_ALG_KERN_DRIVER_ONLY 0x00001000 /* * Mark a cipher as a service implementation only usable by another * cipher and never by a normal user of the kernel crypto API */ #define CRYPTO_ALG_INTERNAL 0x00002000 /* * Set if the algorithm has a ->setkey() method but can be used without * calling it first, i.e. there is a default key. */ #define CRYPTO_ALG_OPTIONAL_KEY 0x00004000 /* * Don't trigger module loading */ #define CRYPTO_NOLOAD 0x00008000 /* * Transform masks and values (for crt_flags). */ #define CRYPTO_TFM_NEED_KEY 0x00000001 #define CRYPTO_TFM_REQ_MASK 0x000fff00 #define CRYPTO_TFM_RES_MASK 0xfff00000 #define CRYPTO_TFM_REQ_WEAK_KEY 0x00000100 #define CRYPTO_TFM_REQ_MAY_SLEEP 0x00000200 #define CRYPTO_TFM_REQ_MAY_BACKLOG 0x00000400 #define CRYPTO_TFM_RES_WEAK_KEY 0x00100000 #define CRYPTO_TFM_RES_BAD_KEY_LEN 0x00200000 #define CRYPTO_TFM_RES_BAD_KEY_SCHED 0x00400000 #define CRYPTO_TFM_RES_BAD_BLOCK_LEN 0x00800000 #define CRYPTO_TFM_RES_BAD_FLAGS 0x01000000 /* * Miscellaneous stuff. */ #define CRYPTO_MAX_ALG_NAME 128 /* * The macro CRYPTO_MINALIGN_ATTR (along with the void * type in the actual * declaration) is used to ensure that the crypto_tfm context structure is * aligned correctly for the given architecture so that there are no alignment * faults for C data types. In particular, this is required on platforms such * as arm where pointers are 32-bit aligned but there are data types such as * u64 which require 64-bit alignment. */ #define CRYPTO_MINALIGN ARCH_KMALLOC_MINALIGN #define CRYPTO_MINALIGN_ATTR __attribute__ ((__aligned__(CRYPTO_MINALIGN))) struct scatterlist; struct crypto_ablkcipher; struct crypto_async_request; struct crypto_blkcipher; struct crypto_tfm; struct crypto_type; struct skcipher_givcrypt_request; typedef void (*crypto_completion_t)(struct crypto_async_request *req, int err); /** * DOC: Block Cipher Context Data Structures * * These data structures define the operating context for each block cipher * type. */ struct crypto_async_request { struct list_head list; crypto_completion_t complete; void *data; struct crypto_tfm *tfm; u32 flags; }; struct ablkcipher_request { struct crypto_async_request base; unsigned int nbytes; void *info; struct scatterlist *src; struct scatterlist *dst; void *__ctx[] CRYPTO_MINALIGN_ATTR; }; struct blkcipher_desc { struct crypto_blkcipher *tfm; void *info; u32 flags; }; struct cipher_desc { struct crypto_tfm *tfm; void (*crfn)(struct crypto_tfm *tfm, u8 *dst, const u8 *src); unsigned int (*prfn)(const struct cipher_desc *desc, u8 *dst, const u8 *src, unsigned int nbytes); void *info; }; /** * DOC: Block Cipher Algorithm Definitions * * These data structures define modular crypto algorithm implementations, * managed via crypto_register_alg() and crypto_unregister_alg(). */ /** * struct ablkcipher_alg - asynchronous block cipher definition * @min_keysize: Minimum key size supported by the transformation. This is the * smallest key length supported by this transformation algorithm. * This must be set to one of the pre-defined values as this is * not hardware specific. Possible values for this field can be * found via git grep "_MIN_KEY_SIZE" include/crypto/ * @max_keysize: Maximum key size supported by the transformation. This is the * largest key length supported by this transformation algorithm. * This must be set to one of the pre-defined values as this is * not hardware specific. Possible values for this field can be * found via git grep "_MAX_KEY_SIZE" include/crypto/ * @setkey: Set key for the transformation. This function is used to either * program a supplied key into the hardware or store the key in the * transformation context for programming it later. Note that this * function does modify the transformation context. This function can * be called multiple times during the existence of the transformation * object, so one must make sure the key is properly reprogrammed into * the hardware. This function is also responsible for checking the key * length for validity. In case a software fallback was put in place in * the @cra_init call, this function might need to use the fallback if * the algorithm doesn't support all of the key sizes. * @encrypt: Encrypt a scatterlist of blocks. This function is used to encrypt * the supplied scatterlist containing the blocks of data. The crypto * API consumer is responsible for aligning the entries of the * scatterlist properly and making sure the chunks are correctly * sized. In case a software fallback was put in place in the * @cra_init call, this function might need to use the fallback if * the algorithm doesn't support all of the key sizes. In case the * key was stored in transformation context, the key might need to be * re-programmed into the hardware in this function. This function * shall not modify the transformation context, as this function may * be called in parallel with the same transformation object. * @decrypt: Decrypt a single block. This is a reverse counterpart to @encrypt * and the conditions are exactly the same. * @givencrypt: Update the IV for encryption. With this function, a cipher * implementation may provide the function on how to update the IV * for encryption. * @givdecrypt: Update the IV for decryption. This is the reverse of * @givencrypt . * @geniv: The transformation implementation may use an "IV generator" provided * by the kernel crypto API. Several use cases have a predefined * approach how IVs are to be updated. For such use cases, the kernel * crypto API provides ready-to-use implementations that can be * referenced with this variable. * @ivsize: IV size applicable for transformation. The consumer must provide an * IV of exactly that size to perform the encrypt or decrypt operation. * * All fields except @givencrypt , @givdecrypt , @geniv and @ivsize are * mandatory and must be filled. */ struct ablkcipher_alg { int (*setkey)(struct crypto_ablkcipher *tfm, const u8 *key, unsigned int keylen); int (*encrypt)(struct ablkcipher_request *req); int (*decrypt)(struct ablkcipher_request *req); int (*givencrypt)(struct skcipher_givcrypt_request *req); int (*givdecrypt)(struct skcipher_givcrypt_request *req); const char *geniv; unsigned int min_keysize; unsigned int max_keysize; unsigned int ivsize; }; /** * struct blkcipher_alg - synchronous block cipher definition * @min_keysize: see struct ablkcipher_alg * @max_keysize: see struct ablkcipher_alg * @setkey: see struct ablkcipher_alg * @encrypt: see struct ablkcipher_alg * @decrypt: see struct ablkcipher_alg * @geniv: see struct ablkcipher_alg * @ivsize: see struct ablkcipher_alg * * All fields except @geniv and @ivsize are mandatory and must be filled. */ struct blkcipher_alg { int (*setkey)(struct crypto_tfm *tfm, const u8 *key, unsigned int keylen); int (*encrypt)(struct blkcipher_desc *desc, struct scatterlist *dst, struct scatterlist *src, unsigned int nbytes); int (*decrypt)(struct blkcipher_desc *desc, struct scatterlist *dst, struct scatterlist *src, unsigned int nbytes); const char *geniv; unsigned int min_keysize; unsigned int max_keysize; unsigned int ivsize; }; /** * struct cipher_alg - single-block symmetric ciphers definition * @cia_min_keysize: Minimum key size supported by the transformation. This is * the smallest key length supported by this transformation * algorithm. This must be set to one of the pre-defined * values as this is not hardware specific. Possible values * for this field can be found via git grep "_MIN_KEY_SIZE" * include/crypto/ * @cia_max_keysize: Maximum key size supported by the transformation. This is * the largest key length supported by this transformation * algorithm. This must be set to one of the pre-defined values * as this is not hardware specific. Possible values for this * field can be found via git grep "_MAX_KEY_SIZE" * include/crypto/ * @cia_setkey: Set key for the transformation. This function is used to either * program a supplied key into the hardware or store the key in the * transformation context for programming it later. Note that this * function does modify the transformation context. This function * can be called multiple times during the existence of the * transformation object, so one must make sure the key is properly * reprogrammed into the hardware. This function is also * responsible for checking the key length for validity. * @cia_encrypt: Encrypt a single block. This function is used to encrypt a * single block of data, which must be @cra_blocksize big. This * always operates on a full @cra_blocksize and it is not possible * to encrypt a block of smaller size. The supplied buffers must * therefore also be at least of @cra_blocksize size. Both the * input and output buffers are always aligned to @cra_alignmask. * In case either of the input or output buffer supplied by user * of the crypto API is not aligned to @cra_alignmask, the crypto * API will re-align the buffers. The re-alignment means that a * new buffer will be allocated, the data will be copied into the * new buffer, then the processing will happen on the new buffer, * then the data will be copied back into the original buffer and * finally the new buffer will be freed. In case a software * fallback was put in place in the @cra_init call, this function * might need to use the fallback if the algorithm doesn't support * all of the key sizes. In case the key was stored in * transformation context, the key might need to be re-programmed * into the hardware in this function. This function shall not * modify the transformation context, as this function may be * called in parallel with the same transformation object. * @cia_decrypt: Decrypt a single block. This is a reverse counterpart to * @cia_encrypt, and the conditions are exactly the same. * * All fields are mandatory and must be filled. */ struct cipher_alg { unsigned int cia_min_keysize; unsigned int cia_max_keysize; int (*cia_setkey)(struct crypto_tfm *tfm, const u8 *key, unsigned int keylen); void (*cia_encrypt)(struct crypto_tfm *tfm, u8 *dst, const u8 *src); void (*cia_decrypt)(struct crypto_tfm *tfm, u8 *dst, const u8 *src); }; struct compress_alg { int (*coa_compress)(struct crypto_tfm *tfm, const u8 *src, unsigned int slen, u8 *dst, unsigned int *dlen); int (*coa_decompress)(struct crypto_tfm *tfm, const u8 *src, unsigned int slen, u8 *dst, unsigned int *dlen); }; #define cra_ablkcipher cra_u.ablkcipher #define cra_blkcipher cra_u.blkcipher #define cra_cipher cra_u.cipher #define cra_compress cra_u.compress /** * struct crypto_alg - definition of a cryptograpic cipher algorithm * @cra_flags: Flags describing this transformation. See include/linux/crypto.h * CRYPTO_ALG_* flags for the flags which go in here. Those are * used for fine-tuning the description of the transformation * algorithm. * @cra_blocksize: Minimum block size of this transformation. The size in bytes * of the smallest possible unit which can be transformed with * this algorithm. The users must respect this value. * In case of HASH transformation, it is possible for a smaller * block than @cra_blocksize to be passed to the crypto API for * transformation, in case of any other transformation type, an * error will be returned upon any attempt to transform smaller * than @cra_blocksize chunks. * @cra_ctxsize: Size of the operational context of the transformation. This * value informs the kernel crypto API about the memory size * needed to be allocated for the transformation context. * @cra_alignmask: Alignment mask for the input and output data buffer. The data * buffer containing the input data for the algorithm must be * aligned to this alignment mask. The data buffer for the * output data must be aligned to this alignment mask. Note that * the Crypto API will do the re-alignment in software, but * only under special conditions and there is a performance hit. * The re-alignment happens at these occasions for different * @cra_u types: cipher -- For both input data and output data * buffer; ahash -- For output hash destination buf; shash -- * For output hash destination buf. * This is needed on hardware which is flawed by design and * cannot pick data from arbitrary addresses. * @cra_priority: Priority of this transformation implementation. In case * multiple transformations with same @cra_name are available to * the Crypto API, the kernel will use the one with highest * @cra_priority. * @cra_name: Generic name (usable by multiple implementations) of the * transformation algorithm. This is the name of the transformation * itself. This field is used by the kernel when looking up the * providers of particular transformation. * @cra_driver_name: Unique name of the transformation provider. This is the * name of the provider of the transformation. This can be any * arbitrary value, but in the usual case, this contains the * name of the chip or provider and the name of the * transformation algorithm. * @cra_type: Type of the cryptographic transformation. This is a pointer to * struct crypto_type, which implements callbacks common for all * transformation types. There are multiple options: * &crypto_blkcipher_type, &crypto_ablkcipher_type, * &crypto_ahash_type, &crypto_rng_type. * This field might be empty. In that case, there are no common * callbacks. This is the case for: cipher, compress, shash. * @cra_u: Callbacks implementing the transformation. This is a union of * multiple structures. Depending on the type of transformation selected * by @cra_type and @cra_flags above, the associated structure must be * filled with callbacks. This field might be empty. This is the case * for ahash, shash. * @cra_init: Initialize the cryptographic transformation object. This function * is used to initialize the cryptographic transformation object. * This function is called only once at the instantiation time, right * after the transformation context was allocated. In case the * cryptographic hardware has some special requirements which need to * be handled by software, this function shall check for the precise * requirement of the transformation and put any software fallbacks * in place. * @cra_exit: Deinitialize the cryptographic transformation object. This is a * counterpart to @cra_init, used to remove various changes set in * @cra_init. * @cra_module: Owner of this transformation implementation. Set to THIS_MODULE * @cra_list: internally used * @cra_users: internally used * @cra_refcnt: internally used * @cra_destroy: internally used * * The struct crypto_alg describes a generic Crypto API algorithm and is common * for all of the transformations. Any variable not documented here shall not * be used by a cipher implementation as it is internal to the Crypto API. */ struct crypto_alg { struct list_head cra_list; struct list_head cra_users; u32 cra_flags; unsigned int cra_blocksize; unsigned int cra_ctxsize; unsigned int cra_alignmask; int cra_priority; atomic_t cra_refcnt; char cra_name[CRYPTO_MAX_ALG_NAME]; char cra_driver_name[CRYPTO_MAX_ALG_NAME]; const struct crypto_type *cra_type; union { struct ablkcipher_alg ablkcipher; struct blkcipher_alg blkcipher; struct cipher_alg cipher; struct compress_alg compress; } cra_u; int (*cra_init)(struct crypto_tfm *tfm); void (*cra_exit)(struct crypto_tfm *tfm); void (*cra_destroy)(struct crypto_alg *alg); struct module *cra_module; } CRYPTO_MINALIGN_ATTR; /* * A helper struct for waiting for completion of async crypto ops */ struct crypto_wait { struct completion completion; int err; }; /* * Macro for declaring a crypto op async wait object on stack */ #define DECLARE_CRYPTO_WAIT(_wait) \ struct crypto_wait _wait = { \ COMPLETION_INITIALIZER_ONSTACK((_wait).completion), 0 } /* * Async ops completion helper functioons */ void crypto_req_done(struct crypto_async_request *req, int err); static inline int crypto_wait_req(int err, struct crypto_wait *wait) { switch (err) { case -EINPROGRESS: case -EBUSY: wait_for_completion(&wait->completion); reinit_completion(&wait->completion); err = wait->err; break; }; return err; } static inline void crypto_init_wait(struct crypto_wait *wait) { init_completion(&wait->completion); } /* * Algorithm registration interface. */ int crypto_register_alg(struct crypto_alg *alg); int crypto_unregister_alg(struct crypto_alg *alg); int crypto_register_algs(struct crypto_alg *algs, int count); int crypto_unregister_algs(struct crypto_alg *algs, int count); /* * Algorithm query interface. */ int crypto_has_alg(const char *name, u32 type, u32 mask); /* * Transforms: user-instantiated objects which encapsulate algorithms * and core processing logic. Managed via crypto_alloc_*() and * crypto_free_*(), as well as the various helpers below. */ struct ablkcipher_tfm { int (*setkey)(struct crypto_ablkcipher *tfm, const u8 *key, unsigned int keylen); int (*encrypt)(struct ablkcipher_request *req); int (*decrypt)(struct ablkcipher_request *req); struct crypto_ablkcipher *base; unsigned int ivsize; unsigned int reqsize; }; struct blkcipher_tfm { void *iv; int (*setkey)(struct crypto_tfm *tfm, const u8 *key, unsigned int keylen); int (*encrypt)(struct blkcipher_desc *desc, struct scatterlist *dst, struct scatterlist *src, unsigned int nbytes); int (*decrypt)(struct blkcipher_desc *desc, struct scatterlist *dst, struct scatterlist *src, unsigned int nbytes); }; struct cipher_tfm { int (*cit_setkey)(struct crypto_tfm *tfm, const u8 *key, unsigned int keylen); void (*cit_encrypt_one)(struct crypto_tfm *tfm, u8 *dst, const u8 *src); void (*cit_decrypt_one)(struct crypto_tfm *tfm, u8 *dst, const u8 *src); }; struct compress_tfm { int (*cot_compress)(struct crypto_tfm *tfm, const u8 *src, unsigned int slen, u8 *dst, unsigned int *dlen); int (*cot_decompress)(struct crypto_tfm *tfm, const u8 *src, unsigned int slen, u8 *dst, unsigned int *dlen); }; #define crt_ablkcipher crt_u.ablkcipher #define crt_blkcipher crt_u.blkcipher #define crt_cipher crt_u.cipher #define crt_compress crt_u.compress struct crypto_tfm { u32 crt_flags; union { struct ablkcipher_tfm ablkcipher; struct blkcipher_tfm blkcipher; struct cipher_tfm cipher; struct compress_tfm compress; } crt_u; void (*exit)(struct crypto_tfm *tfm); struct crypto_alg *__crt_alg; void *__crt_ctx[] CRYPTO_MINALIGN_ATTR; }; struct crypto_ablkcipher { struct crypto_tfm base; }; struct crypto_blkcipher { struct crypto_tfm base; }; struct crypto_cipher { struct crypto_tfm base; }; struct crypto_comp { struct crypto_tfm base; }; enum { CRYPTOA_UNSPEC, CRYPTOA_ALG, CRYPTOA_TYPE, CRYPTOA_U32, __CRYPTOA_MAX, }; #define CRYPTOA_MAX (__CRYPTOA_MAX - 1) /* Maximum number of (rtattr) parameters for each template. */ #define CRYPTO_MAX_ATTRS 32 struct crypto_attr_alg { char name[CRYPTO_MAX_ALG_NAME]; }; struct crypto_attr_type { u32 type; u32 mask; }; struct crypto_attr_u32 { u32 num; }; /* * Transform user interface. */ struct crypto_tfm *crypto_alloc_base(const char *alg_name, u32 type, u32 mask); void crypto_destroy_tfm(void *mem, struct crypto_tfm *tfm); static inline void crypto_free_tfm(struct crypto_tfm *tfm) { return crypto_destroy_tfm(tfm, tfm); } int alg_test(const char *driver, const char *alg, u32 type, u32 mask); /* * Transform helpers which query the underlying algorithm. */ static inline const char *crypto_tfm_alg_name(struct crypto_tfm *tfm) { return tfm->__crt_alg->cra_name; } static inline const char *crypto_tfm_alg_driver_name(struct crypto_tfm *tfm) { return tfm->__crt_alg->cra_driver_name; } static inline int crypto_tfm_alg_priority(struct crypto_tfm *tfm) { return tfm->__crt_alg->cra_priority; } static inline u32 crypto_tfm_alg_type(struct crypto_tfm *tfm) { return tfm->__crt_alg->cra_flags & CRYPTO_ALG_TYPE_MASK; } static inline unsigned int crypto_tfm_alg_blocksize(struct crypto_tfm *tfm) { return tfm->__crt_alg->cra_blocksize; } static inline unsigned int crypto_tfm_alg_alignmask(struct crypto_tfm *tfm) { return tfm->__crt_alg->cra_alignmask; } static inline u32 crypto_tfm_get_flags(struct crypto_tfm *tfm) { return tfm->crt_flags; } static inline void crypto_tfm_set_flags(struct crypto_tfm *tfm, u32 flags) { tfm->crt_flags |= flags; } static inline void crypto_tfm_clear_flags(struct crypto_tfm *tfm, u32 flags) { tfm->crt_flags &= ~flags; } static inline void *crypto_tfm_ctx(struct crypto_tfm *tfm) { return tfm->__crt_ctx; } static inline unsigned int crypto_tfm_ctx_alignment(void) { struct crypto_tfm *tfm; return __alignof__(tfm->__crt_ctx); } /* * API wrappers. */ static inline struct crypto_ablkcipher *__crypto_ablkcipher_cast( struct crypto_tfm *tfm) { return (struct crypto_ablkcipher *)tfm; } static inline u32 crypto_skcipher_type(u32 type) { type &= ~(CRYPTO_ALG_TYPE_MASK | CRYPTO_ALG_GENIV); type |= CRYPTO_ALG_TYPE_BLKCIPHER; return type; } static inline u32 crypto_skcipher_mask(u32 mask) { mask &= ~(CRYPTO_ALG_TYPE_MASK | CRYPTO_ALG_GENIV); mask |= CRYPTO_ALG_TYPE_BLKCIPHER_MASK; return mask; } /** * DOC: Asynchronous Block Cipher API * * Asynchronous block cipher API is used with the ciphers of type * CRYPTO_ALG_TYPE_ABLKCIPHER (listed as type "ablkcipher" in /proc/crypto). * * Asynchronous cipher operations imply that the function invocation for a * cipher request returns immediately before the completion of the operation. * The cipher request is scheduled as a separate kernel thread and therefore * load-balanced on the different CPUs via the process scheduler. To allow * the kernel crypto API to inform the caller about the completion of a cipher * request, the caller must provide a callback function. That function is * invoked with the cipher handle when the request completes. * * To support the asynchronous operation, additional information than just the * cipher handle must be supplied to the kernel crypto API. That additional * information is given by filling in the ablkcipher_request data structure. * * For the asynchronous block cipher API, the state is maintained with the tfm * cipher handle. A single tfm can be used across multiple calls and in * parallel. For asynchronous block cipher calls, context data supplied and * only used by the caller can be referenced the request data structure in * addition to the IV used for the cipher request. The maintenance of such * state information would be important for a crypto driver implementer to * have, because when calling the callback function upon completion of the * cipher operation, that callback function may need some information about * which operation just finished if it invoked multiple in parallel. This * state information is unused by the kernel crypto API. */ static inline struct crypto_tfm *crypto_ablkcipher_tfm( struct crypto_ablkcipher *tfm) { return &tfm->base; } /** * crypto_free_ablkcipher() - zeroize and free cipher handle * @tfm: cipher handle to be freed */ static inline void crypto_free_ablkcipher(struct crypto_ablkcipher *tfm) { crypto_free_tfm(crypto_ablkcipher_tfm(tfm)); } /** * crypto_has_ablkcipher() - Search for the availability of an ablkcipher. * @alg_name: is the cra_name / name or cra_driver_name / driver name of the * ablkcipher * @type: specifies the type of the cipher * @mask: specifies the mask for the cipher * * Return: true when the ablkcipher is known to the kernel crypto API; false * otherwise */ static inline int crypto_has_ablkcipher(const char *alg_name, u32 type, u32 mask) { return crypto_has_alg(alg_name, crypto_skcipher_type(type), crypto_skcipher_mask(mask)); } static inline struct ablkcipher_tfm *crypto_ablkcipher_crt( struct crypto_ablkcipher *tfm) { return &crypto_ablkcipher_tfm(tfm)->crt_ablkcipher; } /** * crypto_ablkcipher_ivsize() - obtain IV size * @tfm: cipher handle * * The size of the IV for the ablkcipher referenced by the cipher handle is * returned. This IV size may be zero if the cipher does not need an IV. * * Return: IV size in bytes */ static inline unsigned int crypto_ablkcipher_ivsize( struct crypto_ablkcipher *tfm) { return crypto_ablkcipher_crt(tfm)->ivsize; } /** * crypto_ablkcipher_blocksize() - obtain block size of cipher * @tfm: cipher handle * * The block size for the ablkcipher referenced with the cipher handle is * returned. The caller may use that information to allocate appropriate * memory for the data returned by the encryption or decryption operation * * Return: block size of cipher */ static inline unsigned int crypto_ablkcipher_blocksize( struct crypto_ablkcipher *tfm) { return crypto_tfm_alg_blocksize(crypto_ablkcipher_tfm(tfm)); } static inline unsigned int crypto_ablkcipher_alignmask( struct crypto_ablkcipher *tfm) { return crypto_tfm_alg_alignmask(crypto_ablkcipher_tfm(tfm)); } static inline u32 crypto_ablkcipher_get_flags(struct crypto_ablkcipher *tfm) { return crypto_tfm_get_flags(crypto_ablkcipher_tfm(tfm)); } static inline void crypto_ablkcipher_set_flags(struct crypto_ablkcipher *tfm, u32 flags) { crypto_tfm_set_flags(crypto_ablkcipher_tfm(tfm), flags); } static inline void crypto_ablkcipher_clear_flags(struct crypto_ablkcipher *tfm, u32 flags) { crypto_tfm_clear_flags(crypto_ablkcipher_tfm(tfm), flags); } /** * crypto_ablkcipher_setkey() - set key for cipher * @tfm: cipher handle * @key: buffer holding the key * @keylen: length of the key in bytes * * The caller provided key is set for the ablkcipher referenced by the cipher * handle. * * Note, the key length determines the cipher type. Many block ciphers implement * different cipher modes depending on the key size, such as AES-128 vs AES-192 * vs. AES-256. When providing a 16 byte key for an AES cipher handle, AES-128 * is performed. * * Return: 0 if the setting of the key was successful; < 0 if an error occurred */ static inline int crypto_ablkcipher_setkey(struct crypto_ablkcipher *tfm, const u8 *key, unsigned int keylen) { struct ablkcipher_tfm *crt = crypto_ablkcipher_crt(tfm); return crt->setkey(crt->base, key, keylen); } /** * crypto_ablkcipher_reqtfm() - obtain cipher handle from request * @req: ablkcipher_request out of which the cipher handle is to be obtained * * Return the crypto_ablkcipher handle when furnishing an ablkcipher_request * data structure. * * Return: crypto_ablkcipher handle */ static inline struct crypto_ablkcipher *crypto_ablkcipher_reqtfm( struct ablkcipher_request *req) { return __crypto_ablkcipher_cast(req->base.tfm); } /** * crypto_ablkcipher_encrypt() - encrypt plaintext * @req: reference to the ablkcipher_request handle that holds all information * needed to perform the cipher operation * * Encrypt plaintext data using the ablkcipher_request handle. That data * structure and how it is filled with data is discussed with the * ablkcipher_request_* functions. * * Return: 0 if the cipher operation was successful; < 0 if an error occurred */ static inline int crypto_ablkcipher_encrypt(struct ablkcipher_request *req) { struct ablkcipher_tfm *crt = crypto_ablkcipher_crt(crypto_ablkcipher_reqtfm(req)); return crt->encrypt(req); } /** * crypto_ablkcipher_decrypt() - decrypt ciphertext * @req: reference to the ablkcipher_request handle that holds all information * needed to perform the cipher operation * * Decrypt ciphertext data using the ablkcipher_request handle. That data * structure and how it is filled with data is discussed with the * ablkcipher_request_* functions. * * Return: 0 if the cipher operation was successful; < 0 if an error occurred */ static inline int crypto_ablkcipher_decrypt(struct ablkcipher_request *req) { struct ablkcipher_tfm *crt = crypto_ablkcipher_crt(crypto_ablkcipher_reqtfm(req)); return crt->decrypt(req); } /** * DOC: Asynchronous Cipher Request Handle * * The ablkcipher_request data structure contains all pointers to data * required for the asynchronous cipher operation. This includes the cipher * handle (which can be used by multiple ablkcipher_request instances), pointer * to plaintext and ciphertext, asynchronous callback function, etc. It acts * as a handle to the ablkcipher_request_* API calls in a similar way as * ablkcipher handle to the crypto_ablkcipher_* API calls. */ /** * crypto_ablkcipher_reqsize() - obtain size of the request data structure * @tfm: cipher handle * * Return: number of bytes */ static inline unsigned int crypto_ablkcipher_reqsize( struct crypto_ablkcipher *tfm) { return crypto_ablkcipher_crt(tfm)->reqsize; } /** * ablkcipher_request_set_tfm() - update cipher handle reference in request * @req: request handle to be modified * @tfm: cipher handle that shall be added to the request handle * * Allow the caller to replace the existing ablkcipher handle in the request * data structure with a different one. */ static inline void ablkcipher_request_set_tfm( struct ablkcipher_request *req, struct crypto_ablkcipher *tfm) { req->base.tfm = crypto_ablkcipher_tfm(crypto_ablkcipher_crt(tfm)->base); } static inline struct ablkcipher_request *ablkcipher_request_cast( struct crypto_async_request *req) { return container_of(req, struct ablkcipher_request, base); } /** * ablkcipher_request_alloc() - allocate request data structure * @tfm: cipher handle to be registered with the request * @gfp: memory allocation flag that is handed to kmalloc by the API call. * * Allocate the request data structure that must be used with the ablkcipher * encrypt and decrypt API calls. During the allocation, the provided ablkcipher * handle is registered in the request data structure. * * Return: allocated request handle in case of success, or NULL if out of memory */ static inline struct ablkcipher_request *ablkcipher_request_alloc( struct crypto_ablkcipher *tfm, gfp_t gfp) { struct ablkcipher_request *req; req = kmalloc(sizeof(struct ablkcipher_request) + crypto_ablkcipher_reqsize(tfm), gfp); if (likely(req)) ablkcipher_request_set_tfm(req, tfm); return req; } /** * ablkcipher_request_free() - zeroize and free request data structure * @req: request data structure cipher handle to be freed */ static inline void ablkcipher_request_free(struct ablkcipher_request *req) { kzfree(req); } /** * ablkcipher_request_set_callback() - set asynchronous callback function * @req: request handle * @flags: specify zero or an ORing of the flags * CRYPTO_TFM_REQ_MAY_BACKLOG the request queue may back log and * increase the wait queue beyond the initial maximum size; * CRYPTO_TFM_REQ_MAY_SLEEP the request processing may sleep * @compl: callback function pointer to be registered with the request handle * @data: The data pointer refers to memory that is not used by the kernel * crypto API, but provided to the callback function for it to use. Here, * the caller can provide a reference to memory the callback function can * operate on. As the callback function is invoked asynchronously to the * related functionality, it may need to access data structures of the * related functionality which can be referenced using this pointer. The * callback function can access the memory via the "data" field in the * crypto_async_request data structure provided to the callback function. * * This function allows setting the callback function that is triggered once the * cipher operation completes. * * The callback function is registered with the ablkcipher_request handle and * must comply with the following template:: * * void callback_function(struct crypto_async_request *req, int error) */ static inline void ablkcipher_request_set_callback( struct ablkcipher_request *req, u32 flags, crypto_completion_t compl, void *data) { req->base.complete = compl; req->base.data = data; req->base.flags = flags; } /** * ablkcipher_request_set_crypt() - set data buffers * @req: request handle * @src: source scatter / gather list * @dst: destination scatter / gather list * @nbytes: number of bytes to process from @src * @iv: IV for the cipher operation which must comply with the IV size defined * by crypto_ablkcipher_ivsize * * This function allows setting of the source data and destination data * scatter / gather lists. * * For encryption, the source is treated as the plaintext and the * destination is the ciphertext. For a decryption operation, the use is * reversed - the source is the ciphertext and the destination is the plaintext. */ static inline void ablkcipher_request_set_crypt( struct ablkcipher_request *req, struct scatterlist *src, struct scatterlist *dst, unsigned int nbytes, void *iv) { req->src = src; req->dst = dst; req->nbytes = nbytes; req->info = iv; } /** * DOC: Synchronous Block Cipher API * * The synchronous block cipher API is used with the ciphers of type * CRYPTO_ALG_TYPE_BLKCIPHER (listed as type "blkcipher" in /proc/crypto) * * Synchronous calls, have a context in the tfm. But since a single tfm can be * used in multiple calls and in parallel, this info should not be changeable * (unless a lock is used). This applies, for example, to the symmetric key. * However, the IV is changeable, so there is an iv field in blkcipher_tfm * structure for synchronous blkcipher api. So, its the only state info that can * be kept for synchronous calls without using a big lock across a tfm. * * The block cipher API allows the use of a complete cipher, i.e. a cipher * consisting of a template (a block chaining mode) and a single block cipher * primitive (e.g. AES). * * The plaintext data buffer and the ciphertext data buffer are pointed to * by using scatter/gather lists. The cipher operation is performed * on all segments of the provided scatter/gather lists. * * The kernel crypto API supports a cipher operation "in-place" which means that * the caller may provide the same scatter/gather list for the plaintext and * cipher text. After the completion of the cipher operation, the plaintext * data is replaced with the ciphertext data in case of an encryption and vice * versa for a decryption. The caller must ensure that the scatter/gather lists * for the output data point to sufficiently large buffers, i.e. multiples of * the block size of the cipher. */ static inline struct crypto_blkcipher *__crypto_blkcipher_cast( struct crypto_tfm *tfm) { return (struct crypto_blkcipher *)tfm; } static inline struct crypto_blkcipher *crypto_blkcipher_cast( struct crypto_tfm *tfm) { BUG_ON(crypto_tfm_alg_type(tfm) != CRYPTO_ALG_TYPE_BLKCIPHER); return __crypto_blkcipher_cast(tfm); } /** * crypto_alloc_blkcipher() - allocate synchronous block cipher handle * @alg_name: is the cra_name / name or cra_driver_name / driver name of the * blkcipher cipher * @type: specifies the type of the cipher * @mask: specifies the mask for the cipher * * Allocate a cipher handle for a block cipher. The returned struct * crypto_blkcipher is the cipher handle that is required for any subsequent * API invocation for that block cipher. * * Return: allocated cipher handle in case of success; IS_ERR() is true in case * of an error, PTR_ERR() returns the error code. */ static inline struct crypto_blkcipher *crypto_alloc_blkcipher( const char *alg_name, u32 type, u32 mask) { type &= ~CRYPTO_ALG_TYPE_MASK; type |= CRYPTO_ALG_TYPE_BLKCIPHER; mask |= CRYPTO_ALG_TYPE_MASK; return __crypto_blkcipher_cast(crypto_alloc_base(alg_name, type, mask)); } static inline struct crypto_tfm *crypto_blkcipher_tfm( struct crypto_blkcipher *tfm) { return &tfm->base; } /** * crypto_free_blkcipher() - zeroize and free the block cipher handle * @tfm: cipher handle to be freed */ static inline void crypto_free_blkcipher(struct crypto_blkcipher *tfm) { crypto_free_tfm(crypto_blkcipher_tfm(tfm)); } /** * crypto_has_blkcipher() - Search for the availability of a block cipher * @alg_name: is the cra_name / name or cra_driver_name / driver name of the * block cipher * @type: specifies the type of the cipher * @mask: specifies the mask for the cipher * * Return: true when the block cipher is known to the kernel crypto API; false * otherwise */ static inline int crypto_has_blkcipher(const char *alg_name, u32 type, u32 mask) { type &= ~CRYPTO_ALG_TYPE_MASK; type |= CRYPTO_ALG_TYPE_BLKCIPHER; mask |= CRYPTO_ALG_TYPE_MASK; return crypto_has_alg(alg_name, type, mask); } /** * crypto_blkcipher_name() - return the name / cra_name from the cipher handle * @tfm: cipher handle * * Return: The character string holding the name of the cipher */ static inline const char *crypto_blkcipher_name(struct crypto_blkcipher *tfm) { return crypto_tfm_alg_name(crypto_blkcipher_tfm(tfm)); } static inline struct blkcipher_tfm *crypto_blkcipher_crt( struct crypto_blkcipher *tfm) { return &crypto_blkcipher_tfm(tfm)->crt_blkcipher; } static inline struct blkcipher_alg *crypto_blkcipher_alg( struct crypto_blkcipher *tfm) { return &crypto_blkcipher_tfm(tfm)->__crt_alg->cra_blkcipher; } /** * crypto_blkcipher_ivsize() - obtain IV size * @tfm: cipher handle * * The size of the IV for the block cipher referenced by the cipher handle is * returned. This IV size may be zero if the cipher does not need an IV. * * Return: IV size in bytes */ static inline unsigned int crypto_blkcipher_ivsize(struct crypto_blkcipher *tfm) { return crypto_blkcipher_alg(tfm)->ivsize; } /** * crypto_blkcipher_blocksize() - obtain block size of cipher * @tfm: cipher handle * * The block size for the block cipher referenced with the cipher handle is * returned. The caller may use that information to allocate appropriate * memory for the data returned by the encryption or decryption operation. * * Return: block size of cipher */ static inline unsigned int crypto_blkcipher_blocksize( struct crypto_blkcipher *tfm) { return crypto_tfm_alg_blocksize(crypto_blkcipher_tfm(tfm)); } static inline unsigned int crypto_blkcipher_alignmask( struct crypto_blkcipher *tfm) { return crypto_tfm_alg_alignmask(crypto_blkcipher_tfm(tfm)); } static inline u32 crypto_blkcipher_get_flags(struct crypto_blkcipher *tfm) { return crypto_tfm_get_flags(crypto_blkcipher_tfm(tfm)); } static inline void crypto_blkcipher_set_flags(struct crypto_blkcipher *tfm, u32 flags) { crypto_tfm_set_flags(crypto_blkcipher_tfm(tfm), flags); } static inline void crypto_blkcipher_clear_flags(struct crypto_blkcipher *tfm, u32 flags) { crypto_tfm_clear_flags(crypto_blkcipher_tfm(tfm), flags); } /** * crypto_blkcipher_setkey() - set key for cipher * @tfm: cipher handle * @key: buffer holding the key * @keylen: length of the key in bytes * * The caller provided key is set for the block cipher referenced by the cipher * handle. * * Note, the key length determines the cipher type. Many block ciphers implement * different cipher modes depending on the key size, such as AES-128 vs AES-192 * vs. AES-256. When providing a 16 byte key for an AES cipher handle, AES-128 * is performed. * * Return: 0 if the setting of the key was successful; < 0 if an error occurred */ static inline int crypto_blkcipher_setkey(struct crypto_blkcipher *tfm, const u8 *key, unsigned int keylen) { return crypto_blkcipher_crt(tfm)->setkey(crypto_blkcipher_tfm(tfm), key, keylen); } /** * crypto_blkcipher_encrypt() - encrypt plaintext * @desc: reference to the block cipher handle with meta data * @dst: scatter/gather list that is filled by the cipher operation with the * ciphertext * @src: scatter/gather list that holds the plaintext * @nbytes: number of bytes of the plaintext to encrypt. * * Encrypt plaintext data using the IV set by the caller with a preceding * call of crypto_blkcipher_set_iv. * * The blkcipher_desc data structure must be filled by the caller and can * reside on the stack. The caller must fill desc as follows: desc.tfm is filled * with the block cipher handle; desc.flags is filled with either * CRYPTO_TFM_REQ_MAY_SLEEP or 0. * * Return: 0 if the cipher operation was successful; < 0 if an error occurred */ static inline int crypto_blkcipher_encrypt(struct blkcipher_desc *desc, struct scatterlist *dst, struct scatterlist *src, unsigned int nbytes) { desc->info = crypto_blkcipher_crt(desc->tfm)->iv; return crypto_blkcipher_crt(desc->tfm)->encrypt(desc, dst, src, nbytes); } /** * crypto_blkcipher_encrypt_iv() - encrypt plaintext with dedicated IV * @desc: reference to the block cipher handle with meta data * @dst: scatter/gather list that is filled by the cipher operation with the * ciphertext * @src: scatter/gather list that holds the plaintext * @nbytes: number of bytes of the plaintext to encrypt. * * Encrypt plaintext data with the use of an IV that is solely used for this * cipher operation. Any previously set IV is not used. * * The blkcipher_desc data structure must be filled by the caller and can * reside on the stack. The caller must fill desc as follows: desc.tfm is filled * with the block cipher handle; desc.info is filled with the IV to be used for * the current operation; desc.flags is filled with either * CRYPTO_TFM_REQ_MAY_SLEEP or 0. * * Return: 0 if the cipher operation was successful; < 0 if an error occurred */ static inline int crypto_blkcipher_encrypt_iv(struct blkcipher_desc *desc, struct scatterlist *dst, struct scatterlist *src, unsigned int nbytes) { return crypto_blkcipher_crt(desc->tfm)->encrypt(desc, dst, src, nbytes); } /** * crypto_blkcipher_decrypt() - decrypt ciphertext * @desc: reference to the block cipher handle with meta data * @dst: scatter/gather list that is filled by the cipher operation with the * plaintext * @src: scatter/gather list that holds the ciphertext * @nbytes: number of bytes of the ciphertext to decrypt. * * Decrypt ciphertext data using the IV set by the caller with a preceding * call of crypto_blkcipher_set_iv. * * The blkcipher_desc data structure must be filled by the caller as documented * for the crypto_blkcipher_encrypt call above. * * Return: 0 if the cipher operation was successful; < 0 if an error occurred * */ static inline int crypto_blkcipher_decrypt(struct blkcipher_desc *desc, struct scatterlist *dst, struct scatterlist *src, unsigned int nbytes) { desc->info = crypto_blkcipher_crt(desc->tfm)->iv; return crypto_blkcipher_crt(desc->tfm)->decrypt(desc, dst, src, nbytes); } /** * crypto_blkcipher_decrypt_iv() - decrypt ciphertext with dedicated IV * @desc: reference to the block cipher handle with meta data * @dst: scatter/gather list that is filled by the cipher operation with the * plaintext * @src: scatter/gather list that holds the ciphertext * @nbytes: number of bytes of the ciphertext to decrypt. * * Decrypt ciphertext data with the use of an IV that is solely used for this * cipher operation. Any previously set IV is not used. * * The blkcipher_desc data structure must be filled by the caller as documented * for the crypto_blkcipher_encrypt_iv call above. * * Return: 0 if the cipher operation was successful; < 0 if an error occurred */ static inline int crypto_blkcipher_decrypt_iv(struct blkcipher_desc *desc, struct scatterlist *dst, struct scatterlist *src, unsigned int nbytes) { return crypto_blkcipher_crt(desc->tfm)->decrypt(desc, dst, src, nbytes); } /** * crypto_blkcipher_set_iv() - set IV for cipher * @tfm: cipher handle * @src: buffer holding the IV * @len: length of the IV in bytes * * The caller provided IV is set for the block cipher referenced by the cipher * handle. */ static inline void crypto_blkcipher_set_iv(struct crypto_blkcipher *tfm, const u8 *src, unsigned int len) { memcpy(crypto_blkcipher_crt(tfm)->iv, src, len); } /** * crypto_blkcipher_get_iv() - obtain IV from cipher * @tfm: cipher handle * @dst: buffer filled with the IV * @len: length of the buffer dst * * The caller can obtain the IV set for the block cipher referenced by the * cipher handle and store it into the user-provided buffer. If the buffer * has an insufficient space, the IV is truncated to fit the buffer. */ static inline void crypto_blkcipher_get_iv(struct crypto_blkcipher *tfm, u8 *dst, unsigned int len) { memcpy(dst, crypto_blkcipher_crt(tfm)->iv, len); } /** * DOC: Single Block Cipher API * * The single block cipher API is used with the ciphers of type * CRYPTO_ALG_TYPE_CIPHER (listed as type "cipher" in /proc/crypto). * * Using the single block cipher API calls, operations with the basic cipher * primitive can be implemented. These cipher primitives exclude any block * chaining operations including IV handling. * * The purpose of this single block cipher API is to support the implementation * of templates or other concepts that only need to perform the cipher operation * on one block at a time. Templates invoke the underlying cipher primitive * block-wise and process either the input or the output data of these cipher * operations. */ static inline struct crypto_cipher *__crypto_cipher_cast(struct crypto_tfm *tfm) { return (struct crypto_cipher *)tfm; } static inline struct crypto_cipher *crypto_cipher_cast(struct crypto_tfm *tfm) { BUG_ON(crypto_tfm_alg_type(tfm) != CRYPTO_ALG_TYPE_CIPHER); return __crypto_cipher_cast(tfm); } /** * crypto_alloc_cipher() - allocate single block cipher handle * @alg_name: is the cra_name / name or cra_driver_name / driver name of the * single block cipher * @type: specifies the type of the cipher * @mask: specifies the mask for the cipher * * Allocate a cipher handle for a single block cipher. The returned struct * crypto_cipher is the cipher handle that is required for any subsequent API * invocation for that single block cipher. * * Return: allocated cipher handle in case of success; IS_ERR() is true in case * of an error, PTR_ERR() returns the error code. */ static inline struct crypto_cipher *crypto_alloc_cipher(const char *alg_name, u32 type, u32 mask) { type &= ~CRYPTO_ALG_TYPE_MASK; type |= CRYPTO_ALG_TYPE_CIPHER; mask |= CRYPTO_ALG_TYPE_MASK; return __crypto_cipher_cast(crypto_alloc_base(alg_name, type, mask)); } static inline struct crypto_tfm *crypto_cipher_tfm(struct crypto_cipher *tfm) { return &tfm->base; } /** * crypto_free_cipher() - zeroize and free the single block cipher handle * @tfm: cipher handle to be freed */ static inline void crypto_free_cipher(struct crypto_cipher *tfm) { crypto_free_tfm(crypto_cipher_tfm(tfm)); } /** * crypto_has_cipher() - Search for the availability of a single block cipher * @alg_name: is the cra_name / name or cra_driver_name / driver name of the * single block cipher * @type: specifies the type of the cipher * @mask: specifies the mask for the cipher * * Return: true when the single block cipher is known to the kernel crypto API; * false otherwise */ static inline int crypto_has_cipher(const char *alg_name, u32 type, u32 mask) { type &= ~CRYPTO_ALG_TYPE_MASK; type |= CRYPTO_ALG_TYPE_CIPHER; mask |= CRYPTO_ALG_TYPE_MASK; return crypto_has_alg(alg_name, type, mask); } static inline struct cipher_tfm *crypto_cipher_crt(struct crypto_cipher *tfm) { return &crypto_cipher_tfm(tfm)->crt_cipher; } /** * crypto_cipher_blocksize() - obtain block size for cipher * @tfm: cipher handle * * The block size for the single block cipher referenced with the cipher handle * tfm is returned. The caller may use that information to allocate appropriate * memory for the data returned by the encryption or decryption operation * * Return: block size of cipher */ static inline unsigned int crypto_cipher_blocksize(struct crypto_cipher *tfm) { return crypto_tfm_alg_blocksize(crypto_cipher_tfm(tfm)); } static inline unsigned int crypto_cipher_alignmask(struct crypto_cipher *tfm) { return crypto_tfm_alg_alignmask(crypto_cipher_tfm(tfm)); } static inline u32 crypto_cipher_get_flags(struct crypto_cipher *tfm) { return crypto_tfm_get_flags(crypto_cipher_tfm(tfm)); } static inline void crypto_cipher_set_flags(struct crypto_cipher *tfm, u32 flags) { crypto_tfm_set_flags(crypto_cipher_tfm(tfm), flags); } static inline void crypto_cipher_clear_flags(struct crypto_cipher *tfm, u32 flags) { crypto_tfm_clear_flags(crypto_cipher_tfm(tfm), flags); } /** * crypto_cipher_setkey() - set key for cipher * @tfm: cipher handle * @key: buffer holding the key * @keylen: length of the key in bytes * * The caller provided key is set for the single block cipher referenced by the * cipher handle. * * Note, the key length determines the cipher type. Many block ciphers implement * different cipher modes depending on the key size, such as AES-128 vs AES-192 * vs. AES-256. When providing a 16 byte key for an AES cipher handle, AES-128 * is performed. * * Return: 0 if the setting of the key was successful; < 0 if an error occurred */ static inline int crypto_cipher_setkey(struct crypto_cipher *tfm, const u8 *key, unsigned int keylen) { return crypto_cipher_crt(tfm)->cit_setkey(crypto_cipher_tfm(tfm), key, keylen); } /** * crypto_cipher_encrypt_one() - encrypt one block of plaintext * @tfm: cipher handle * @dst: points to the buffer that will be filled with the ciphertext * @src: buffer holding the plaintext to be encrypted * * Invoke the encryption operation of one block. The caller must ensure that * the plaintext and ciphertext buffers are at least one block in size. */ static inline void crypto_cipher_encrypt_one(struct crypto_cipher *tfm, u8 *dst, const u8 *src) { crypto_cipher_crt(tfm)->cit_encrypt_one(crypto_cipher_tfm(tfm), dst, src); } /** * crypto_cipher_decrypt_one() - decrypt one block of ciphertext * @tfm: cipher handle * @dst: points to the buffer that will be filled with the plaintext * @src: buffer holding the ciphertext to be decrypted * * Invoke the decryption operation of one block. The caller must ensure that * the plaintext and ciphertext buffers are at least one block in size. */ static inline void crypto_cipher_decrypt_one(struct crypto_cipher *tfm, u8 *dst, const u8 *src) { crypto_cipher_crt(tfm)->cit_decrypt_one(crypto_cipher_tfm(tfm), dst, src); } static inline struct crypto_comp *__crypto_comp_cast(struct crypto_tfm *tfm) { return (struct crypto_comp *)tfm; } static inline struct crypto_comp *crypto_comp_cast(struct crypto_tfm *tfm) { BUG_ON((crypto_tfm_alg_type(tfm) ^ CRYPTO_ALG_TYPE_COMPRESS) & CRYPTO_ALG_TYPE_MASK); return __crypto_comp_cast(tfm); } static inline struct crypto_comp *crypto_alloc_comp(const char *alg_name, u32 type, u32 mask) { type &= ~CRYPTO_ALG_TYPE_MASK; type |= CRYPTO_ALG_TYPE_COMPRESS; mask |= CRYPTO_ALG_TYPE_MASK; return __crypto_comp_cast(crypto_alloc_base(alg_name, type, mask)); } static inline struct crypto_tfm *crypto_comp_tfm(struct crypto_comp *tfm) { return &tfm->base; } static inline void crypto_free_comp(struct crypto_comp *tfm) { crypto_free_tfm(crypto_comp_tfm(tfm)); } static inline int crypto_has_comp(const char *alg_name, u32 type, u32 mask) { type &= ~CRYPTO_ALG_TYPE_MASK; type |= CRYPTO_ALG_TYPE_COMPRESS; mask |= CRYPTO_ALG_TYPE_MASK; return crypto_has_alg(alg_name, type, mask); } static inline const char *crypto_comp_name(struct crypto_comp *tfm) { return crypto_tfm_alg_name(crypto_comp_tfm(tfm)); } static inline struct compress_tfm *crypto_comp_crt(struct crypto_comp *tfm) { return &crypto_comp_tfm(tfm)->crt_compress; } static inline int crypto_comp_compress(struct crypto_comp *tfm, const u8 *src, unsigned int slen, u8 *dst, unsigned int *dlen) { return crypto_comp_crt(tfm)->cot_compress(crypto_comp_tfm(tfm), src, slen, dst, dlen); } static inline int crypto_comp_decompress(struct crypto_comp *tfm, const u8 *src, unsigned int slen, u8 *dst, unsigned int *dlen) { return crypto_comp_crt(tfm)->cot_decompress(crypto_comp_tfm(tfm), src, slen, dst, dlen); } #endif /* _LINUX_CRYPTO_H */