aboutsummaryrefslogtreecommitdiffstats
path: root/net/dccp/ccids/lib
diff options
context:
space:
mode:
authorArnaldo Carvalho de Melo <acme@redhat.com>2007-12-06 09:28:13 -0500
committerDavid S. Miller <davem@davemloft.net>2008-01-28 17:56:41 -0500
commit34a9e7ea91bb4acb45ae5331e7403304029329b2 (patch)
tree196c60bbe79f4d480cefa9d141a6096f3450fa75 /net/dccp/ccids/lib
parente9c8b24a6ade50315f3c080799da45ddadf42269 (diff)
[TFRC]: Make the rx history slab be global
This is in preparation for merging the new rx history code written by Gerrit Renker. Signed-off-by: Gerrit Renker <gerrit@erg.abdn.ac.uk> Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/dccp/ccids/lib')
-rw-r--r--net/dccp/ccids/lib/packet_history.c95
-rw-r--r--net/dccp/ccids/lib/packet_history.h43
2 files changed, 54 insertions, 84 deletions
diff --git a/net/dccp/ccids/lib/packet_history.c b/net/dccp/ccids/lib/packet_history.c
index b628714fb2ab..e1ab853c38df 100644
--- a/net/dccp/ccids/lib/packet_history.c
+++ b/net/dccp/ccids/lib/packet_history.c
@@ -114,48 +114,33 @@ EXPORT_SYMBOL_GPL(tfrc_tx_hist_rtt);
114/* 114/*
115 * Receiver History Routines 115 * Receiver History Routines
116 */ 116 */
117struct dccp_rx_hist *dccp_rx_hist_new(const char *name) 117static struct kmem_cache *tfrc_rx_hist_slab;
118
119struct dccp_rx_hist_entry *dccp_rx_hist_entry_new(const u32 ndp,
120 const struct sk_buff *skb,
121 const gfp_t prio)
118{ 122{
119 struct dccp_rx_hist *hist = kmalloc(sizeof(*hist), GFP_ATOMIC); 123 struct dccp_rx_hist_entry *entry = kmem_cache_alloc(tfrc_rx_hist_slab,
120 static const char dccp_rx_hist_mask[] = "rx_hist_%s"; 124 prio);
121 char *slab_name;
122
123 if (hist == NULL)
124 goto out;
125
126 slab_name = kmalloc(strlen(name) + sizeof(dccp_rx_hist_mask) - 1,
127 GFP_ATOMIC);
128 if (slab_name == NULL)
129 goto out_free_hist;
130
131 sprintf(slab_name, dccp_rx_hist_mask, name);
132 hist->dccprxh_slab = kmem_cache_create(slab_name,
133 sizeof(struct dccp_rx_hist_entry),
134 0, SLAB_HWCACHE_ALIGN, NULL);
135 if (hist->dccprxh_slab == NULL)
136 goto out_free_slab_name;
137out:
138 return hist;
139out_free_slab_name:
140 kfree(slab_name);
141out_free_hist:
142 kfree(hist);
143 hist = NULL;
144 goto out;
145}
146 125
147EXPORT_SYMBOL_GPL(dccp_rx_hist_new); 126 if (entry != NULL) {
127 const struct dccp_hdr *dh = dccp_hdr(skb);
148 128
149void dccp_rx_hist_delete(struct dccp_rx_hist *hist) 129 entry->dccphrx_seqno = DCCP_SKB_CB(skb)->dccpd_seq;
150{ 130 entry->dccphrx_ccval = dh->dccph_ccval;
151 const char* name = kmem_cache_name(hist->dccprxh_slab); 131 entry->dccphrx_type = dh->dccph_type;
132 entry->dccphrx_ndp = ndp;
133 entry->dccphrx_tstamp = ktime_get_real();
134 }
152 135
153 kmem_cache_destroy(hist->dccprxh_slab); 136 return entry;
154 kfree(name);
155 kfree(hist);
156} 137}
138EXPORT_SYMBOL_GPL(dccp_rx_hist_entry_new);
157 139
158EXPORT_SYMBOL_GPL(dccp_rx_hist_delete); 140static inline void dccp_rx_hist_entry_delete(struct dccp_rx_hist_entry *entry)
141{
142 kmem_cache_free(tfrc_rx_hist_slab, entry);
143}
159 144
160int dccp_rx_hist_find_entry(const struct list_head *list, const u64 seq, 145int dccp_rx_hist_find_entry(const struct list_head *list, const u64 seq,
161 u8 *ccval) 146 u8 *ccval)
@@ -192,11 +177,10 @@ struct dccp_rx_hist_entry *
192 177
193EXPORT_SYMBOL_GPL(dccp_rx_hist_find_data_packet); 178EXPORT_SYMBOL_GPL(dccp_rx_hist_find_data_packet);
194 179
195void dccp_rx_hist_add_packet(struct dccp_rx_hist *hist, 180void dccp_rx_hist_add_packet(struct list_head *rx_list,
196 struct list_head *rx_list, 181 struct list_head *li_list,
197 struct list_head *li_list, 182 struct dccp_rx_hist_entry *packet,
198 struct dccp_rx_hist_entry *packet, 183 u64 nonloss_seqno)
199 u64 nonloss_seqno)
200{ 184{
201 struct dccp_rx_hist_entry *entry, *next; 185 struct dccp_rx_hist_entry *entry, *next;
202 u8 num_later = 0; 186 u8 num_later = 0;
@@ -211,7 +195,7 @@ void dccp_rx_hist_add_packet(struct dccp_rx_hist *hist,
211 if (after48(nonloss_seqno, 195 if (after48(nonloss_seqno,
212 entry->dccphrx_seqno)) { 196 entry->dccphrx_seqno)) {
213 list_del_init(&entry->dccphrx_node); 197 list_del_init(&entry->dccphrx_node);
214 dccp_rx_hist_entry_delete(hist, entry); 198 dccp_rx_hist_entry_delete(entry);
215 } 199 }
216 } else if (dccp_rx_hist_entry_data_packet(entry)) 200 } else if (dccp_rx_hist_entry_data_packet(entry))
217 --num_later; 201 --num_later;
@@ -253,7 +237,7 @@ void dccp_rx_hist_add_packet(struct dccp_rx_hist *hist,
253 break; 237 break;
254 case 3: 238 case 3:
255 list_del_init(&entry->dccphrx_node); 239 list_del_init(&entry->dccphrx_node);
256 dccp_rx_hist_entry_delete(hist, entry); 240 dccp_rx_hist_entry_delete(entry);
257 break; 241 break;
258 } 242 }
259 } else if (dccp_rx_hist_entry_data_packet(entry)) 243 } else if (dccp_rx_hist_entry_data_packet(entry))
@@ -264,13 +248,13 @@ void dccp_rx_hist_add_packet(struct dccp_rx_hist *hist,
264 248
265EXPORT_SYMBOL_GPL(dccp_rx_hist_add_packet); 249EXPORT_SYMBOL_GPL(dccp_rx_hist_add_packet);
266 250
267void dccp_rx_hist_purge(struct dccp_rx_hist *hist, struct list_head *list) 251void dccp_rx_hist_purge(struct list_head *list)
268{ 252{
269 struct dccp_rx_hist_entry *entry, *next; 253 struct dccp_rx_hist_entry *entry, *next;
270 254
271 list_for_each_entry_safe(entry, next, list, dccphrx_node) { 255 list_for_each_entry_safe(entry, next, list, dccphrx_node) {
272 list_del_init(&entry->dccphrx_node); 256 list_del_init(&entry->dccphrx_node);
273 kmem_cache_free(hist->dccprxh_slab, entry); 257 dccp_rx_hist_entry_delete(entry);
274 } 258 }
275} 259}
276 260
@@ -281,8 +265,22 @@ __init int packet_history_init(void)
281 tfrc_tx_hist_slab = kmem_cache_create("tfrc_tx_hist", 265 tfrc_tx_hist_slab = kmem_cache_create("tfrc_tx_hist",
282 sizeof(struct tfrc_tx_hist_entry), 0, 266 sizeof(struct tfrc_tx_hist_entry), 0,
283 SLAB_HWCACHE_ALIGN, NULL); 267 SLAB_HWCACHE_ALIGN, NULL);
268 if (tfrc_tx_hist_slab == NULL)
269 goto out_err;
284 270
285 return tfrc_tx_hist_slab == NULL ? -ENOBUFS : 0; 271 tfrc_rx_hist_slab = kmem_cache_create("tfrc_rx_hist",
272 sizeof(struct dccp_rx_hist_entry), 0,
273 SLAB_HWCACHE_ALIGN, NULL);
274 if (tfrc_rx_hist_slab == NULL)
275 goto out_free_tx;
276
277 return 0;
278
279out_free_tx:
280 kmem_cache_destroy(tfrc_tx_hist_slab);
281 tfrc_tx_hist_slab = NULL;
282out_err:
283 return -ENOBUFS;
286} 284}
287 285
288void packet_history_exit(void) 286void packet_history_exit(void)
@@ -291,4 +289,9 @@ void packet_history_exit(void)
291 kmem_cache_destroy(tfrc_tx_hist_slab); 289 kmem_cache_destroy(tfrc_tx_hist_slab);
292 tfrc_tx_hist_slab = NULL; 290 tfrc_tx_hist_slab = NULL;
293 } 291 }
292
293 if (tfrc_rx_hist_slab != NULL) {
294 kmem_cache_destroy(tfrc_rx_hist_slab);
295 tfrc_rx_hist_slab = NULL;
296 }
294} 297}
diff --git a/net/dccp/ccids/lib/packet_history.h b/net/dccp/ccids/lib/packet_history.h
index 9a2642ed684f..34b180b0edaa 100644
--- a/net/dccp/ccids/lib/packet_history.h
+++ b/net/dccp/ccids/lib/packet_history.h
@@ -66,34 +66,10 @@ struct dccp_rx_hist_entry {
66 ktime_t dccphrx_tstamp; 66 ktime_t dccphrx_tstamp;
67}; 67};
68 68
69struct dccp_rx_hist { 69extern struct dccp_rx_hist_entry *
70 struct kmem_cache *dccprxh_slab; 70 dccp_rx_hist_entry_new(const u32 ndp,
71};
72
73extern struct dccp_rx_hist *dccp_rx_hist_new(const char *name);
74extern void dccp_rx_hist_delete(struct dccp_rx_hist *hist);
75
76static inline struct dccp_rx_hist_entry *
77 dccp_rx_hist_entry_new(struct dccp_rx_hist *hist,
78 const u32 ndp,
79 const struct sk_buff *skb, 71 const struct sk_buff *skb,
80 const gfp_t prio) 72 const gfp_t prio);
81{
82 struct dccp_rx_hist_entry *entry = kmem_cache_alloc(hist->dccprxh_slab,
83 prio);
84
85 if (entry != NULL) {
86 const struct dccp_hdr *dh = dccp_hdr(skb);
87
88 entry->dccphrx_seqno = DCCP_SKB_CB(skb)->dccpd_seq;
89 entry->dccphrx_ccval = dh->dccph_ccval;
90 entry->dccphrx_type = dh->dccph_type;
91 entry->dccphrx_ndp = ndp;
92 entry->dccphrx_tstamp = ktime_get_real();
93 }
94
95 return entry;
96}
97 73
98static inline struct dccp_rx_hist_entry * 74static inline struct dccp_rx_hist_entry *
99 dccp_rx_hist_head(struct list_head *list) 75 dccp_rx_hist_head(struct list_head *list)
@@ -111,21 +87,12 @@ extern int dccp_rx_hist_find_entry(const struct list_head *list, const u64 seq,
111extern struct dccp_rx_hist_entry * 87extern struct dccp_rx_hist_entry *
112 dccp_rx_hist_find_data_packet(const struct list_head *list); 88 dccp_rx_hist_find_data_packet(const struct list_head *list);
113 89
114extern void dccp_rx_hist_add_packet(struct dccp_rx_hist *hist, 90extern void dccp_rx_hist_add_packet(struct list_head *rx_list,
115 struct list_head *rx_list,
116 struct list_head *li_list, 91 struct list_head *li_list,
117 struct dccp_rx_hist_entry *packet, 92 struct dccp_rx_hist_entry *packet,
118 u64 nonloss_seqno); 93 u64 nonloss_seqno);
119 94
120static inline void dccp_rx_hist_entry_delete(struct dccp_rx_hist *hist, 95extern void dccp_rx_hist_purge(struct list_head *list);
121 struct dccp_rx_hist_entry *entry)
122{
123 if (entry != NULL)
124 kmem_cache_free(hist->dccprxh_slab, entry);
125}
126
127extern void dccp_rx_hist_purge(struct dccp_rx_hist *hist,
128 struct list_head *list);
129 96
130static inline int 97static inline int
131 dccp_rx_hist_entry_data_packet(const struct dccp_rx_hist_entry *entry) 98 dccp_rx_hist_entry_data_packet(const struct dccp_rx_hist_entry *entry)