aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/net/sctp/tsnmap.h14
-rw-r--r--net/sctp/sm_make_chunk.c6
-rw-r--r--net/sctp/tsnmap.c15
3 files changed, 15 insertions, 20 deletions
diff --git a/include/net/sctp/tsnmap.h b/include/net/sctp/tsnmap.h
index 6dabbee8bbd3..4aabc5a96cf6 100644
--- a/include/net/sctp/tsnmap.h
+++ b/include/net/sctp/tsnmap.h
@@ -94,11 +94,8 @@ struct sctp_tsnmap {
94 * every SACK. Store up to SCTP_MAX_DUP_TSNS worth of 94 * every SACK. Store up to SCTP_MAX_DUP_TSNS worth of
95 * information. 95 * information.
96 */ 96 */
97 __be32 dup_tsns[SCTP_MAX_DUP_TSNS];
98 __u16 num_dup_tsns; 97 __u16 num_dup_tsns;
99 98 __be32 dup_tsns[SCTP_MAX_DUP_TSNS];
100 /* Record gap ack block information here. */
101 struct sctp_gap_ack_block gabs[SCTP_MAX_GABS];
102}; 99};
103 100
104struct sctp_tsnmap_iter { 101struct sctp_tsnmap_iter {
@@ -151,17 +148,12 @@ static inline __be32 *sctp_tsnmap_get_dups(struct sctp_tsnmap *map)
151} 148}
152 149
153/* How many gap ack blocks do we have recorded? */ 150/* How many gap ack blocks do we have recorded? */
154__u16 sctp_tsnmap_num_gabs(struct sctp_tsnmap *map); 151__u16 sctp_tsnmap_num_gabs(struct sctp_tsnmap *map,
152 struct sctp_gap_ack_block *gabs);
155 153
156/* Refresh the count on pending data. */ 154/* Refresh the count on pending data. */
157__u16 sctp_tsnmap_pending(struct sctp_tsnmap *map); 155__u16 sctp_tsnmap_pending(struct sctp_tsnmap *map);
158 156
159/* Return pointer to gap ack blocks as needed by SACK. */
160static inline struct sctp_gap_ack_block *sctp_tsnmap_get_gabs(struct sctp_tsnmap *map)
161{
162 return map->gabs;
163}
164
165/* Is there a gap in the TSN map? */ 157/* Is there a gap in the TSN map? */
166static inline int sctp_tsnmap_has_gap(const struct sctp_tsnmap *map) 158static inline int sctp_tsnmap_has_gap(const struct sctp_tsnmap *map)
167{ 159{
diff --git a/net/sctp/sm_make_chunk.c b/net/sctp/sm_make_chunk.c
index 6dd9b3ef33d0..fd8acb48c3f2 100644
--- a/net/sctp/sm_make_chunk.c
+++ b/net/sctp/sm_make_chunk.c
@@ -702,12 +702,14 @@ struct sctp_chunk *sctp_make_sack(const struct sctp_association *asoc)
702 __u32 ctsn; 702 __u32 ctsn;
703 __u16 num_gabs, num_dup_tsns; 703 __u16 num_gabs, num_dup_tsns;
704 struct sctp_tsnmap *map = (struct sctp_tsnmap *)&asoc->peer.tsn_map; 704 struct sctp_tsnmap *map = (struct sctp_tsnmap *)&asoc->peer.tsn_map;
705 struct sctp_gap_ack_block gabs[SCTP_MAX_GABS];
705 706
707 memset(gabs, 0, sizeof(gabs));
706 ctsn = sctp_tsnmap_get_ctsn(map); 708 ctsn = sctp_tsnmap_get_ctsn(map);
707 SCTP_DEBUG_PRINTK("sackCTSNAck sent: 0x%x.\n", ctsn); 709 SCTP_DEBUG_PRINTK("sackCTSNAck sent: 0x%x.\n", ctsn);
708 710
709 /* How much room is needed in the chunk? */ 711 /* How much room is needed in the chunk? */
710 num_gabs = sctp_tsnmap_num_gabs(map); 712 num_gabs = sctp_tsnmap_num_gabs(map, gabs);
711 num_dup_tsns = sctp_tsnmap_num_dups(map); 713 num_dup_tsns = sctp_tsnmap_num_dups(map);
712 714
713 /* Initialize the SACK header. */ 715 /* Initialize the SACK header. */
@@ -763,7 +765,7 @@ struct sctp_chunk *sctp_make_sack(const struct sctp_association *asoc)
763 /* Add the gap ack block information. */ 765 /* Add the gap ack block information. */
764 if (num_gabs) 766 if (num_gabs)
765 sctp_addto_chunk(retval, sizeof(__u32) * num_gabs, 767 sctp_addto_chunk(retval, sizeof(__u32) * num_gabs,
766 sctp_tsnmap_get_gabs(map)); 768 gabs);
767 769
768 /* Add the duplicate TSN information. */ 770 /* Add the duplicate TSN information. */
769 if (num_dup_tsns) 771 if (num_dup_tsns)
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)