aboutsummaryrefslogtreecommitdiffstats
path: root/net/sctp/tsnmap.c
diff options
context:
space:
mode:
authorVlad Yasevich <vladislav.yasevich@hp.com>2008-10-08 17:19:01 -0400
committerDavid S. Miller <davem@davemloft.net>2008-10-08 17:19:01 -0400
commit02015180e2509afd2e3fe3790a333b30708a116b (patch)
treed2d92b62758f01375602cd7e44cb9ffbb3e44d59 /net/sctp/tsnmap.c
parent8e1ee18c332e08bee9d8bd66e63cd564fbf17fc2 (diff)
sctp: shrink sctp_tsnmap some more by removing gabs array
The gabs array in the sctp_tsnmap structure is only used in one place, sctp_make_sack(). As such, carrying the array around in the sctp_tsnmap and thus directly in the sctp_association is rather pointless since most of the time it's just taking up space. Now, let sctp_make_sack create and populate it and then throw it away when it's done. Signed-off-by: Vlad Yasevich <vladislav.yasevich@hp.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sctp/tsnmap.c')
-rw-r--r--net/sctp/tsnmap.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/net/sctp/tsnmap.c b/net/sctp/tsnmap.c
index 142ed7ca424d..35c73e82553a 100644
--- a/net/sctp/tsnmap.c
+++ b/net/sctp/tsnmap.c
@@ -335,10 +335,11 @@ void sctp_tsnmap_renege(struct sctp_tsnmap *map, __u32 tsn)
335} 335}
336 336
337/* How many gap ack blocks do we have recorded? */ 337/* How many gap ack blocks do we have recorded? */
338__u16 sctp_tsnmap_num_gabs(struct sctp_tsnmap *map) 338__u16 sctp_tsnmap_num_gabs(struct sctp_tsnmap *map,
339 struct sctp_gap_ack_block *gabs)
339{ 340{
340 struct sctp_tsnmap_iter iter; 341 struct sctp_tsnmap_iter iter;
341 int gabs = 0; 342 int ngaps = 0;
342 343
343 /* Refresh the gap ack information. */ 344 /* Refresh the gap ack information. */
344 if (sctp_tsnmap_has_gap(map)) { 345 if (sctp_tsnmap_has_gap(map)) {
@@ -348,14 +349,14 @@ __u16 sctp_tsnmap_num_gabs(struct sctp_tsnmap *map)
348 &start, 349 &start,
349 &end)) { 350 &end)) {
350 351
351 map->gabs[gabs].start = htons(start); 352 gabs[ngaps].start = htons(start);
352 map->gabs[gabs].end = htons(end); 353 gabs[ngaps].end = htons(end);
353 gabs++; 354 ngaps++;
354 if (gabs >= SCTP_MAX_GABS) 355 if (ngaps >= SCTP_MAX_GABS)
355 break; 356 break;
356 } 357 }
357 } 358 }
358 return gabs; 359 return ngaps;
359} 360}
360 361
361static int sctp_tsnmap_grow(struct sctp_tsnmap *map, u16 gap) 362static int sctp_tsnmap_grow(struct sctp_tsnmap *map, u16 gap)