2019-05-20 09:19:02 +02:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2005-04-16 15:20:36 -07:00
|
|
|
#ifndef __LINUX_KMOD_H__
|
|
|
|
|
#define __LINUX_KMOD_H__
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* include/linux/kmod.h
|
|
|
|
|
*/
|
|
|
|
|
|
2017-09-08 16:17:08 -07:00
|
|
|
#include <linux/umh.h>
|
2008-07-25 01:45:38 -07:00
|
|
|
#include <linux/gfp.h>
|
2005-06-23 22:00:51 -07:00
|
|
|
#include <linux/stddef.h>
|
2005-04-16 15:20:36 -07:00
|
|
|
#include <linux/errno.h>
|
|
|
|
|
#include <linux/compiler.h>
|
2010-05-26 14:42:58 -07:00
|
|
|
#include <linux/workqueue.h>
|
2011-04-01 17:07:50 -04:00
|
|
|
#include <linux/sysctl.h>
|
2005-04-16 15:20:36 -07:00
|
|
|
|
|
|
|
|
#define KMOD_PATH_LEN 256
|
|
|
|
|
|
2008-07-08 19:00:17 +02:00
|
|
|
#ifdef CONFIG_MODULES
|
2010-03-10 15:24:06 -08:00
|
|
|
extern char modprobe_path[]; /* for sysctl */
|
2005-04-16 15:20:36 -07:00
|
|
|
/* modprobe exit status on success, -ve on error. Return value
|
|
|
|
|
* usually useless though. */
|
2011-10-31 17:11:33 -07:00
|
|
|
extern __printf(2, 3)
|
|
|
|
|
int __request_module(bool wait, const char *name, ...);
|
2009-02-08 10:42:01 -08:00
|
|
|
#define request_module(mod...) __request_module(true, mod)
|
|
|
|
|
#define request_module_nowait(mod...) __request_module(false, mod)
|
|
|
|
|
#define try_then_request_module(x, mod...) \
|
2009-04-09 10:35:47 +08:00
|
|
|
((x) ?: (__request_module(true, mod), (x)))
|
2005-04-16 15:20:36 -07:00
|
|
|
#else
|
2009-02-08 10:42:01 -08:00
|
|
|
static inline int request_module(const char *name, ...) { return -ENOSYS; }
|
|
|
|
|
static inline int request_module_nowait(const char *name, ...) { return -ENOSYS; }
|
2008-07-08 19:00:18 +02:00
|
|
|
#define try_then_request_module(x, mod...) (x)
|
2005-04-16 15:20:36 -07:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#endif /* __LINUX_KMOD_H__ */
|