Почему «__tracepoint_sched_switch» не определено - PullRequest
0 голосов
/ 11 февраля 2019

Я хочу скомпилировать и загрузить модуль из этого ответа https://stackoverflow.com/a/29526520/9609843 Произошли некоторые ошибки: я включил <linux/sched/clock.h>, потому что он необходим sched_clock, и передал параметр bool ignr после void* ignore, потому что оннужен (un)register_trace_sched_switch.Итак, теперь мой код компилируется, но есть предупреждение от make:

WARNING: "__tracepoint_sched_switch" [/some_path/myclock.ko] undefined!

И когда я пытаюсь выполнить insmod, возникает ошибка:

insmod: ERROR: could not insert module myclock.ko: Unknown symbol in module

Итак, что мне нужно сделать, чтобы это сработало?

UPD: весь код, который у меня есть на данный момент

#include <linux/sched/clock.h>
#include <linux/sched.h>
#include <linux/module.h>
#include <linux/printk.h>
#include <linux/types.h>
#include <linux/tracepoint.h>
#include <trace/events/sched.h>


MODULE_LICENSE("GPL");
MODULE_AUTHOR("somebody");


void my_sched_switch_probe(void* ignore, bool ignr, struct task_struct* prev, struct task_struct* next) {
    printk("my_sched_switch_probe: %s -> %s at %lu\n", prev->comm, next->comm,
    (unsigned long) sched_clock());
}


int cswtracer_init(void) {
    register_trace_sched_switch(my_sched_switch_probe, 0);
    return 0;
}


void cswtracer_fini(void) {
    unregister_trace_sched_switch(my_sched_switch_probe, 0);
}


module_init(cswtracer_init);
module_exit(cswtracer_fini);

UPD: кажется, __tracepoint_sched_switch не экспортируется для использования другими модулями:

$ sudo cat /proc/kallsyms | grep __tracepoint_sched_switch
ffffffff91c123a0 D __tracepoint_sched_switch
$ cat /lib/modules/`uname -r`/build/Module.symvers | grep __tracepoint_sched_switch
$ (nothing was shown)

Возможномой Makefile неправильный и есть способ использовать __tracepoint_sched_switch, используя какой-либо параметр в Makefile?Вот оно:

ifneq ($(KERNELRELEASE),)
    obj-m := myclock.o
else
    CURRENT = $(shell uname -r)
    KDIR = /lib/modules/$(CURRENT)/build
    PWD = $(shell pwd)
default:
    $(MAKE) -C $(KDIR) M=$(PWD) modules
clean:
    rm *.o
    rm *.mod.c
    rm *.symvers
    rm *.order
    rm .cache.mk
    rm .*.*.cmd
    rm -r .tmp_versions
endif

1 Ответ

0 голосов
/ 11 февраля 2019

В ядре символ __tracepoint_sched_switch() экспортируется следующим образом:

EXPORT_TRACEPOINT_SYMBOL_GPL(sched_switch);

Это означает, что только код GPL разрешен для доступа к этому символу.Вам нужно будет объявить лицензию вашего модуля совместимой с GPL следующим образом:

MODULE_LICENSE("GPL");

После этого ваш код должен скомпилироваться и связаться с ядром без предупреждений / ошибок.

...