mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-07 22:03:14 +00:00
[NET_SCHED]: ematch: module autoloading
Signed-off-by: Patrick McHardy <kaber@trash.net> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
662ad4f8ef
commit
db3d99c090
@ -403,16 +403,13 @@ enum
|
||||
* 1..32767 Reserved for ematches inside kernel tree
|
||||
* 32768..65535 Free to use, not reliable
|
||||
*/
|
||||
enum
|
||||
{
|
||||
TCF_EM_CONTAINER,
|
||||
TCF_EM_CMP,
|
||||
TCF_EM_NBYTE,
|
||||
TCF_EM_U32,
|
||||
TCF_EM_META,
|
||||
TCF_EM_TEXT,
|
||||
__TCF_EM_MAX
|
||||
};
|
||||
#define TCF_EM_CONTAINER 0
|
||||
#define TCF_EM_CMP 1
|
||||
#define TCF_EM_NBYTE 2
|
||||
#define TCF_EM_U32 3
|
||||
#define TCF_EM_META 4
|
||||
#define TCF_EM_TEXT 5
|
||||
#define TCF_EM_MAX 5
|
||||
|
||||
enum
|
||||
{
|
||||
|
@ -306,6 +306,8 @@ static inline int tcf_em_tree_match(struct sk_buff *skb,
|
||||
return 1;
|
||||
}
|
||||
|
||||
#define MODULE_ALIAS_TCF_EMATCH(kind) MODULE_ALIAS("ematch-kind-" __stringify(kind))
|
||||
|
||||
#else /* CONFIG_NET_EMATCH */
|
||||
|
||||
struct tcf_ematch_tree
|
||||
|
@ -98,3 +98,4 @@ MODULE_LICENSE("GPL");
|
||||
module_init(init_em_cmp);
|
||||
module_exit(exit_em_cmp);
|
||||
|
||||
MODULE_ALIAS_TCF_EMATCH(TCF_EM_CMP);
|
||||
|
@ -848,3 +848,5 @@ MODULE_LICENSE("GPL");
|
||||
|
||||
module_init(init_em_meta);
|
||||
module_exit(exit_em_meta);
|
||||
|
||||
MODULE_ALIAS_TCF_EMATCH(TCF_EM_META);
|
||||
|
@ -76,3 +76,5 @@ MODULE_LICENSE("GPL");
|
||||
|
||||
module_init(init_em_nbyte);
|
||||
module_exit(exit_em_nbyte);
|
||||
|
||||
MODULE_ALIAS_TCF_EMATCH(TCF_EM_NBYTE);
|
||||
|
@ -150,3 +150,5 @@ MODULE_LICENSE("GPL");
|
||||
|
||||
module_init(init_em_text);
|
||||
module_exit(exit_em_text);
|
||||
|
||||
MODULE_ALIAS_TCF_EMATCH(TCF_EM_TEXT);
|
||||
|
@ -60,3 +60,5 @@ MODULE_LICENSE("GPL");
|
||||
|
||||
module_init(init_em_u32);
|
||||
module_exit(exit_em_u32);
|
||||
|
||||
MODULE_ALIAS_TCF_EMATCH(TCF_EM_U32);
|
||||
|
@ -222,6 +222,19 @@ static int tcf_em_validate(struct tcf_proto *tp,
|
||||
|
||||
if (em->ops == NULL) {
|
||||
err = -ENOENT;
|
||||
#ifdef CONFIG_KMOD
|
||||
__rtnl_unlock();
|
||||
request_module("ematch-kind-%u", em_hdr->kind);
|
||||
rtnl_lock();
|
||||
em->ops = tcf_em_lookup(em_hdr->kind);
|
||||
if (em->ops) {
|
||||
/* We dropped the RTNL mutex in order to
|
||||
* perform the module load. Tell the caller
|
||||
* to replay the request. */
|
||||
module_put(em->ops->owner);
|
||||
err = -EAGAIN;
|
||||
}
|
||||
#endif
|
||||
goto errout;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user