From: Mathieu Desnoyers Date: Mon, 13 Apr 2020 18:51:23 +0000 (-0400) Subject: wrapper: remove genhd wrapper X-Git-Tag: for-upstreaming-review-1~80 X-Git-Url: http://git.liburcu.org/?p=lttng-modules.git;a=commitdiff_plain;h=6afd444b862a34b0cce8309bfabaef7ec9f9054d wrapper: remove genhd wrapper --- diff --git a/lttng-statedump-impl.c b/lttng-statedump-impl.c index a40ef760..657031ec 100644 --- a/lttng-statedump-impl.c +++ b/lttng-statedump-impl.c @@ -34,10 +34,10 @@ #include #include #include +#include #include #include -#include /* Define the tracepoints, but do not build the probes */ #define CREATE_TRACE_POINTS @@ -114,19 +114,11 @@ enum lttng_process_status { static int lttng_enumerate_block_devices(struct lttng_session *session) { - struct class *ptr_block_class; - struct device_type *ptr_disk_type; struct class_dev_iter iter; struct device *dev; - ptr_block_class = wrapper_get_block_class(); - if (!ptr_block_class) - return -ENOSYS; - ptr_disk_type = wrapper_get_disk_type(); - if (!ptr_disk_type) { - return -ENOSYS; - } - class_dev_iter_init(&iter, ptr_block_class, NULL, ptr_disk_type); + class_dev_iter_init(&iter, gendisk_block_class(), NULL, + gendisk_device_type()); while ((dev = class_dev_iter_next(&iter))) { struct disk_part_iter piter; struct gendisk *disk = dev_to_disk(dev); @@ -145,7 +137,7 @@ int lttng_enumerate_block_devices(struct lttng_session *session) char name_buf[BDEVNAME_SIZE]; char *p; - p = wrapper_disk_name(disk, part->partno, name_buf); + p = gendisk_name(disk, part->partno, name_buf); if (!p) { disk_part_iter_exit(&piter); class_dev_iter_exit(&iter); diff --git a/wrapper/genhd.h b/wrapper/genhd.h deleted file mode 100644 index 807074dd..00000000 --- a/wrapper/genhd.h +++ /dev/null @@ -1,100 +0,0 @@ -/* SPDX-License-Identifier: (GPL-2.0-only or LGPL-2.1-only) - * - * wrapper/genhd.h - * - * wrapper around block layer functions and data structures. Using - * KALLSYMS to get its address when available, else we need to have a - * kernel that exports this function to GPL modules. - * - * Copyright (C) 2011-2014 Mathieu Desnoyers - */ - -#ifndef _LTTNG_WRAPPER_GENHD_H -#define _LTTNG_WRAPPER_GENHD_H - -#include - -#ifdef CONFIG_KALLSYMS - -#include -#include - -static inline -char *wrapper_disk_name(struct gendisk *hd, int partno, char *buf) -{ - char *(*disk_name_sym)(struct gendisk *hd, int partno, char *buf); - - disk_name_sym = (void *) kallsyms_lookup_funcptr("disk_name"); - if (disk_name_sym) { - return disk_name_sym(hd, partno, buf); - } else { - printk_once(KERN_WARNING "LTTng: disk_name symbol lookup failed.\n"); - return NULL; - } -} - -#else - -static inline -char *wrapper_disk_name(struct gendisk *hd, int partno, char *buf) -{ - return disk_name(hd, partno, buf); -} - -#endif - -#ifdef CONFIG_KALLSYMS_ALL - -static inline -struct class *wrapper_get_block_class(void) -{ - struct class *ptr_block_class; - - ptr_block_class = (struct class *) kallsyms_lookup_dataptr("block_class"); - if (!ptr_block_class) { - printk_once(KERN_WARNING "LTTng: block_class symbol lookup failed.\n"); - return NULL; - } - return ptr_block_class; -} - -static inline -struct device_type *wrapper_get_disk_type(void) -{ - struct device_type *ptr_disk_type; - - ptr_disk_type = (struct device_type *) kallsyms_lookup_dataptr("disk_type"); - if (!ptr_disk_type) { - printk_once(KERN_WARNING "LTTng: disk_type symbol lookup failed.\n"); - return NULL; - } - return ptr_disk_type; -} - -#else - -static inline -struct class *wrapper_get_block_class(void) -{ - /* - * Symbol block_class is not exported. - * TODO: return &block_class; - */ - /* Feature currently unavailable without KALLSYMS_ALL */ - return NULL; -} - -static inline -struct device_type *wrapper_get_disk_type(void) -{ - /* - * Symbol disk_type is not exported. - * TODO: return &disk_type; - */ - /* Feature currently unavailable without KALLSYMS_ALL */ - return NULL; -} - -#endif - -#endif /* _LTTNG_WRAPPER_GENHD_H */