xref: /freebsd-src/sys/compat/linuxkpi/common/include/linux/module.h (revision 28a59100b54ff245a45fbd328266266f1c14eb8c)
18d59ecb2SHans Petter Selasky /*-
28d59ecb2SHans Petter Selasky  * Copyright (c) 2010 Isilon Systems, Inc.
38d59ecb2SHans Petter Selasky  * Copyright (c) 2010 iX Systems, Inc.
48d59ecb2SHans Petter Selasky  * Copyright (c) 2010 Panasas, Inc.
58d59ecb2SHans Petter Selasky  * Copyright (c) 2013, 2014 Mellanox Technologies, Ltd.
68d59ecb2SHans Petter Selasky  * All rights reserved.
78d59ecb2SHans Petter Selasky  *
88d59ecb2SHans Petter Selasky  * Redistribution and use in source and binary forms, with or without
98d59ecb2SHans Petter Selasky  * modification, are permitted provided that the following conditions
108d59ecb2SHans Petter Selasky  * are met:
118d59ecb2SHans Petter Selasky  * 1. Redistributions of source code must retain the above copyright
128d59ecb2SHans Petter Selasky  *    notice unmodified, this list of conditions, and the following
138d59ecb2SHans Petter Selasky  *    disclaimer.
148d59ecb2SHans Petter Selasky  * 2. Redistributions in binary form must reproduce the above copyright
158d59ecb2SHans Petter Selasky  *    notice, this list of conditions and the following disclaimer in the
168d59ecb2SHans Petter Selasky  *    documentation and/or other materials provided with the distribution.
178d59ecb2SHans Petter Selasky  *
188d59ecb2SHans Petter Selasky  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
198d59ecb2SHans Petter Selasky  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
208d59ecb2SHans Petter Selasky  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
218d59ecb2SHans Petter Selasky  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
228d59ecb2SHans Petter Selasky  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
238d59ecb2SHans Petter Selasky  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
248d59ecb2SHans Petter Selasky  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
258d59ecb2SHans Petter Selasky  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
268d59ecb2SHans Petter Selasky  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
278d59ecb2SHans Petter Selasky  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
288d59ecb2SHans Petter Selasky  */
29307f78f3SVladimir Kondratyev #ifndef	_LINUXKPI_LINUX_MODULE_H_
30307f78f3SVladimir Kondratyev #define	_LINUXKPI_LINUX_MODULE_H_
318d59ecb2SHans Petter Selasky 
328d59ecb2SHans Petter Selasky #include <sys/types.h>
33df38ada2SBjoern A. Zeeb #include <sys/param.h>
348d59ecb2SHans Petter Selasky #include <sys/module.h>
35*28a59100SAustin Shafer #include <sys/queue.h>
36*28a59100SAustin Shafer #include <sys/linker.h>
378d59ecb2SHans Petter Selasky 
388d59ecb2SHans Petter Selasky #include <linux/list.h>
398d59ecb2SHans Petter Selasky #include <linux/compiler.h>
4043b4c006SBjoern A. Zeeb #include <linux/stringify.h>
419b6197dfSMark Johnston #include <linux/kmod.h>
428d59ecb2SHans Petter Selasky #include <linux/kobject.h>
438e7baabcSHans Petter Selasky #include <linux/sysfs.h>
448d59ecb2SHans Petter Selasky #include <linux/moduleparam.h>
458d59ecb2SHans Petter Selasky #include <linux/slab.h>
46a041e75aSHans Petter Selasky #include <linux/export.h>
478d59ecb2SHans Petter Selasky 
488d59ecb2SHans Petter Selasky #define MODULE_AUTHOR(name)
498d59ecb2SHans Petter Selasky #define MODULE_DESCRIPTION(name)
508d59ecb2SHans Petter Selasky #define MODULE_LICENSE(name)
51cb564d24SMark Johnston #define	MODULE_INFO(tag, info)
52cb564d24SMark Johnston #define	MODULE_FIRMWARE(firmware)
53c5eec7b5SBjoern A. Zeeb #define	MODULE_SUPPORTED_DEVICE(name)
54f6fb9b52SBjoern A. Zeeb #define	MODULE_IMPORT_NS(_name)
558d59ecb2SHans Petter Selasky 
56*28a59100SAustin Shafer /*
57*28a59100SAustin Shafer  * THIS_MODULE is used to differentiate modules on Linux. We currently
58*28a59100SAustin Shafer  * completely stub out any Linux struct module usage, but THIS_MODULE is still
59*28a59100SAustin Shafer  * used to populate the "owner" fields of various drivers.  Even though we
60*28a59100SAustin Shafer  * don't actually dereference these "owner" fields they are still used by
61*28a59100SAustin Shafer  * drivers to check if devices/dmabufs/etc come from different modules. For
62*28a59100SAustin Shafer  * example, during DRM GEM import some drivers check if the dmabuf's owner
63*28a59100SAustin Shafer  * matches the dev's owner. If they match because they are both NULL drivers
64*28a59100SAustin Shafer  * may incorrectly think two resources come from the same module.
65*28a59100SAustin Shafer  *
66*28a59100SAustin Shafer  * To handle this we specify an undefined symbol __this_linker_file, which
67*28a59100SAustin Shafer  * will get special treatment from the linker when resolving. This will
68*28a59100SAustin Shafer  * populate the usages of __this_linker_file with the linker_file_t of the
69*28a59100SAustin Shafer  * module.
70*28a59100SAustin Shafer  */
71*28a59100SAustin Shafer #ifdef KLD_MODULE
72*28a59100SAustin Shafer #define	THIS_MODULE	((struct module *)&__this_linker_file)
73*28a59100SAustin Shafer #else
748d59ecb2SHans Petter Selasky #define	THIS_MODULE	((struct module *)0)
75*28a59100SAustin Shafer #endif
768d59ecb2SHans Petter Selasky 
778961c483SHans Petter Selasky #define	__MODULE_STRING(x) __stringify(x)
788d59ecb2SHans Petter Selasky 
798d59ecb2SHans Petter Selasky /* OFED pre-module initialization */
808d59ecb2SHans Petter Selasky #define	SI_SUB_OFED_PREINIT	(SI_SUB_ROOT_CONF - 2)
818d59ecb2SHans Petter Selasky /* OFED default module initialization */
828d59ecb2SHans Petter Selasky #define	SI_SUB_OFED_MODINIT	(SI_SUB_ROOT_CONF - 1)
838d59ecb2SHans Petter Selasky 
848d59ecb2SHans Petter Selasky #include <sys/linker.h>
858d59ecb2SHans Petter Selasky 
868d59ecb2SHans Petter Selasky static inline void
_module_run(void * arg)878d59ecb2SHans Petter Selasky _module_run(void *arg)
888d59ecb2SHans Petter Selasky {
898d59ecb2SHans Petter Selasky 	void (*fn)(void);
908d59ecb2SHans Petter Selasky #ifdef OFED_DEBUG_INIT
918d59ecb2SHans Petter Selasky 	char name[1024];
928d59ecb2SHans Petter Selasky 	caddr_t pc;
938d59ecb2SHans Petter Selasky 	long offset;
948d59ecb2SHans Petter Selasky 
958d59ecb2SHans Petter Selasky 	pc = (caddr_t)arg;
968d59ecb2SHans Petter Selasky 	if (linker_search_symbol_name(pc, name, sizeof(name), &offset) != 0)
978d59ecb2SHans Petter Selasky 		printf("Running ??? (%p)\n", pc);
988d59ecb2SHans Petter Selasky 	else
998d59ecb2SHans Petter Selasky 		printf("Running %s (%p)\n", name, pc);
1008d59ecb2SHans Petter Selasky #endif
1018d59ecb2SHans Petter Selasky 	fn = arg;
1028d59ecb2SHans Petter Selasky 	fn();
1038d59ecb2SHans Petter Selasky }
1048d59ecb2SHans Petter Selasky 
1058d59ecb2SHans Petter Selasky #define	module_init(fn)							\
1068d59ecb2SHans Petter Selasky 	SYSINIT(fn, SI_SUB_OFED_MODINIT, SI_ORDER_FIRST, _module_run, (fn))
1078d59ecb2SHans Petter Selasky 
1088d59ecb2SHans Petter Selasky #define	module_exit(fn)						\
1098d59ecb2SHans Petter Selasky 	SYSUNINIT(fn, SI_SUB_OFED_MODINIT, SI_ORDER_SECOND, _module_run, (fn))
1108d59ecb2SHans Petter Selasky 
1118d59ecb2SHans Petter Selasky /*
1128d59ecb2SHans Petter Selasky  * The following two macros are a workaround for not having a module
1138d59ecb2SHans Petter Selasky  * load and unload order resolver:
1148d59ecb2SHans Petter Selasky  */
1158d59ecb2SHans Petter Selasky #define	module_init_order(fn, order)					\
1168d59ecb2SHans Petter Selasky 	SYSINIT(fn, SI_SUB_OFED_MODINIT, (order), _module_run, (fn))
1178d59ecb2SHans Petter Selasky 
1188d59ecb2SHans Petter Selasky #define	module_exit_order(fn, order)				\
1198d59ecb2SHans Petter Selasky 	SYSUNINIT(fn, SI_SUB_OFED_MODINIT, (order), _module_run, (fn))
1208d59ecb2SHans Petter Selasky 
1218d59ecb2SHans Petter Selasky #define	module_get(module)
1228d59ecb2SHans Petter Selasky #define	module_put(module)
1238d59ecb2SHans Petter Selasky #define	try_module_get(module)	1
1248d59ecb2SHans Petter Selasky 
1257e1a02baSMark Johnston #define	postcore_initcall(fn)	module_init(fn)
1267e1a02baSMark Johnston 
127307f78f3SVladimir Kondratyev #endif	/* _LINUXKPI_LINUX_MODULE_H_ */
128