X-Git-Url: https://git.lttng.org/?p=lttng-tools.git;a=blobdiff_plain;f=src%2Fbin%2Flttng-sessiond%2Fkernel.c;h=3b0d6e5f5ee05146aff5d2e31b61517577eed62b;hp=afa5e604fbefff9a9a2465fb5809cfe884d19f60;hb=096102bd1f0665d96f75ad12410ea23189fbf861;hpb=394016d17dedc581b892f2ca7889f715c77a08fd diff --git a/src/bin/lttng-sessiond/kernel.c b/src/bin/lttng-sessiond/kernel.c index afa5e604f..3b0d6e5f5 100644 --- a/src/bin/lttng-sessiond/kernel.c +++ b/src/bin/lttng-sessiond/kernel.c @@ -28,6 +28,7 @@ #include #include "kernel.h" +#include "kern-modules.h" /* * Add context on a kernel channel. @@ -606,3 +607,47 @@ error_fp: error: return -1; } + +/* + * Get kernel version and validate it. + */ +int kernel_validate_version(int tracer_fd) +{ + int ret; + struct lttng_kernel_tracer_version version; + + ret = kernctl_tracer_version(tracer_fd, &version); + if (ret < 0) { + ERR("Failed at getting the lttng-modules version"); + goto error; + } + + /* Validate version */ + if (version.version > KERN_MODULES_VERSION) { + goto error_version; + } else { + if (version.patchlevel > KERN_MODULES_PATCHLEVEL) { + goto error_version; + } + else { + if (version.sublevel > KERN_MODULES_SUBLEVEL) { + goto error_version; + } + } + } + + DBG2("Kernel tracer version validated (%d.%d.%d)", version.version, + version.patchlevel, version.sublevel); + + return 0; + +error_version: + ERR("Kernel version is not compatible %d.%d.%d (supporting <= %d.%d.%d)", + version.version, version.patchlevel, version.sublevel, + KERN_MODULES_VERSION, KERN_MODULES_PATCHLEVEL, + KERN_MODULES_SUBLEVEL); + ret = -1; + +error: + return ret; +}