Commit 9b07ef5d authored by Arnaldo Carvalho de Melo's avatar Arnaldo Carvalho de Melo Committed by David S. Miller

[DCCP] ackvec: Introduce dccp_ackvec_slab

Signed-off-by: default avatarArnaldo Carvalho de Melo <acme@mandriva.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent fa23e2ec
...@@ -13,10 +13,16 @@ ...@@ -13,10 +13,16 @@
#include "dccp.h" #include "dccp.h"
#include <linux/dccp.h> #include <linux/dccp.h>
#include <linux/init.h>
#include <linux/errno.h>
#include <linux/kernel.h>
#include <linux/skbuff.h> #include <linux/skbuff.h>
#include <linux/slab.h>
#include <net/sock.h> #include <net/sock.h>
static kmem_cache_t *dccp_ackvec_slab;
int dccp_insert_option_ackvec(struct sock *sk, struct sk_buff *skb) int dccp_insert_option_ackvec(struct sock *sk, struct sk_buff *skb)
{ {
struct dccp_sock *dp = dccp_sk(sk); struct dccp_sock *dp = dccp_sk(sk);
...@@ -96,7 +102,7 @@ int dccp_insert_option_ackvec(struct sock *sk, struct sk_buff *skb) ...@@ -96,7 +102,7 @@ int dccp_insert_option_ackvec(struct sock *sk, struct sk_buff *skb)
struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority) struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority)
{ {
struct dccp_ackvec *av = kmalloc(sizeof(*av), priority); struct dccp_ackvec *av = kmem_cache_alloc(dccp_ackvec_slab, priority);
if (av != NULL) { if (av != NULL) {
av->dccpav_buf_head = av->dccpav_buf_head =
...@@ -115,7 +121,7 @@ struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority) ...@@ -115,7 +121,7 @@ struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority)
void dccp_ackvec_free(struct dccp_ackvec *av) void dccp_ackvec_free(struct dccp_ackvec *av)
{ {
kfree(av); kmem_cache_free(dccp_ackvec_slab, av);
} }
static inline u8 dccp_ackvec_state(const struct dccp_ackvec *av, static inline u8 dccp_ackvec_state(const struct dccp_ackvec *av,
...@@ -420,3 +426,27 @@ int dccp_ackvec_parse(struct sock *sk, const struct sk_buff *skb, ...@@ -420,3 +426,27 @@ int dccp_ackvec_parse(struct sock *sk, const struct sk_buff *skb,
len, value); len, value);
return 0; return 0;
} }
static char dccp_ackvec_slab_msg[] __initdata =
KERN_CRIT "DCCP: Unable to create ack vectors slab cache\n";
int __init dccp_ackvec_init(void)
{
dccp_ackvec_slab = kmem_cache_create("dccp_ackvec",
sizeof(struct dccp_ackvec), 0,
SLAB_HWCACHE_ALIGN, NULL, NULL);
if (dccp_ackvec_slab == NULL) {
printk(dccp_ackvec_slab_msg);
return -ENOBUFS;
}
return 0;
}
void dccp_ackvec_exit(void)
{
if (dccp_ackvec_slab != NULL) {
kmem_cache_destroy(dccp_ackvec_slab);
dccp_ackvec_slab = NULL;
}
}
...@@ -71,6 +71,9 @@ struct sock; ...@@ -71,6 +71,9 @@ struct sock;
struct sk_buff; struct sk_buff;
#ifdef CONFIG_IP_DCCP_ACKVEC #ifdef CONFIG_IP_DCCP_ACKVEC
extern int dccp_ackvec_init(void);
extern void dccp_ackvec_exit(void);
extern struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority); extern struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority);
extern void dccp_ackvec_free(struct dccp_ackvec *av); extern void dccp_ackvec_free(struct dccp_ackvec *av);
...@@ -89,6 +92,15 @@ static inline int dccp_ackvec_pending(const struct dccp_ackvec *av) ...@@ -89,6 +92,15 @@ static inline int dccp_ackvec_pending(const struct dccp_ackvec *av)
return av->dccpav_sent_len != av->dccpav_vec_len; return av->dccpav_sent_len != av->dccpav_vec_len;
} }
#else /* CONFIG_IP_DCCP_ACKVEC */ #else /* CONFIG_IP_DCCP_ACKVEC */
static inline int dccp_ackvec_init(void)
{
return 0;
}
static inline void dccp_ackvec_exit(void)
{
}
static inline struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority) static inline struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority)
{ {
return NULL; return NULL;
......
...@@ -877,11 +877,17 @@ static int __init dccp_init(void) ...@@ -877,11 +877,17 @@ static int __init dccp_init(void)
inet_register_protosw(&dccp_v4_protosw); inet_register_protosw(&dccp_v4_protosw);
rc = dccp_ctl_sock_init(); rc = dccp_ackvec_init();
if (rc) if (rc)
goto out_unregister_protosw; goto out_unregister_protosw;
rc = dccp_ctl_sock_init();
if (rc)
goto out_ackvec_exit;
out: out:
return rc; return rc;
out_ackvec_exit:
dccp_ackvec_exit();
out_unregister_protosw: out_unregister_protosw:
inet_unregister_protosw(&dccp_v4_protosw); inet_unregister_protosw(&dccp_v4_protosw);
inet_del_protocol(&dccp_protocol, IPPROTO_DCCP); inet_del_protocol(&dccp_protocol, IPPROTO_DCCP);
...@@ -923,6 +929,7 @@ static void __exit dccp_fini(void) ...@@ -923,6 +929,7 @@ static void __exit dccp_fini(void)
sizeof(struct inet_ehash_bucket))); sizeof(struct inet_ehash_bucket)));
kmem_cache_destroy(dccp_hashinfo.bind_bucket_cachep); kmem_cache_destroy(dccp_hashinfo.bind_bucket_cachep);
proto_unregister(&dccp_prot); proto_unregister(&dccp_prot);
dccp_ackvec_exit();
} }
module_init(dccp_init); module_init(dccp_init);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment