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