[DCCP]: Introduce macro for incrementing modulo-48

Problem: DCCP sequence numbers are mostly stored in 48-bit bitfields
         which are acommodated within an u64 number. For these fields,
         dccp_inc_seqno() can not be used since it takes a u64 pointer.

Fix:     Solved by introducing an INC48() macro to increment modulo-2^48.
Note:    This macro can be used in several places within the ccid3 code.
         However, these changes affect others in turn and therefore require
         a separate patch.

Signed-off-by: Gerrit Renker <[EMAIL PROTECTED]>
---
 net/dccp/dccp.h |    3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

--- a/net/dccp/dccp.h
+++ b/net/dccp/dccp.h
@@ -102,6 +102,7 @@ extern int  sysctl_dccp_tx_qlen;
 #define TO_UNSIGNED48(x) (((x) >= 0)?         (x) :  COMPLEMENT48(-(x)))
 #define ADD48(a, b)     (((a) + (b)) & DCCP_MAX_SEQNO)
 #define SUB48(a, b)     ADD48((a), COMPLEMENT48(b))
+#define INC48(seqno)    seqno = ADD48(seqno, 1)
 
 static inline void dccp_set_seqno(u64 *seqno, u64 value)
 {
@@ -110,7 +111,7 @@ static inline void dccp_set_seqno(u64 *s
 
 static inline void dccp_inc_seqno(u64 *seqno)
 {
-       *seqno = ADD48(*seqno, 1);
+       INC48(*seqno);
 }
 
 /* return > 0 if seqno1 is `before' seqno2, <= 0 otherwise */
-
To unsubscribe from this list: send the line "unsubscribe dccp" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to