Blame view
kernel/kheaders.c
1.6 KB
d7d243b52 SMARC-iMX8MQ Linu... |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 |
// SPDX-License-Identifier: GPL-2.0 /* * Provide kernel headers useful to build tracing programs * such as for running eBPF tracing tools. * * (Borrowed code from kernel/configs.c) */ #include <linux/kernel.h> #include <linux/module.h> #include <linux/kobject.h> #include <linux/init.h> /* * Define kernel_headers_data and kernel_headers_data_end, within which the * compressed kernel headers are stored. The file is first compressed with xz. */ asm ( " .pushsection .rodata, \"a\" " " .global kernel_headers_data " "kernel_headers_data: " " .incbin \"kernel/kheaders_data.tar.xz\" " " .global kernel_headers_data_end " "kernel_headers_data_end: " " .popsection " ); extern char kernel_headers_data; extern char kernel_headers_data_end; static ssize_t ikheaders_read(struct file *file, struct kobject *kobj, struct bin_attribute *bin_attr, char *buf, loff_t off, size_t len) { memcpy(buf, &kernel_headers_data + off, len); return len; } static struct bin_attribute kheaders_attr __ro_after_init = { .attr = { .name = "kheaders.tar.xz", .mode = 0444, }, .read = &ikheaders_read, }; static int __init ikheaders_init(void) { kheaders_attr.size = (&kernel_headers_data_end - &kernel_headers_data); return sysfs_create_bin_file(kernel_kobj, &kheaders_attr); } static void __exit ikheaders_cleanup(void) { sysfs_remove_bin_file(kernel_kobj, &kheaders_attr); } module_init(ikheaders_init); module_exit(ikheaders_cleanup); MODULE_LICENSE("GPL v2"); MODULE_AUTHOR("Joel Fernandes"); MODULE_DESCRIPTION("Echo the kernel header artifacts used to build the kernel"); |