2edfb0e
From nobody Mon Sep 17 00:00:00 2001
2edfb0e
From: Paul P Komkoff Jr <i@stingr.net>
2edfb0e
Date: Sat, 10 Jun 2006 20:49:45 +0400
2edfb0e
Subject: [PATCH 2/8] Fix an "invalid lvalue in assignment" compile error.
2edfb0e
2edfb0e
---
2edfb0e
2edfb0e
 lib/ftchash.c |    2 +-
2edfb0e
 lib/ftio.c    |    4 ++--
2edfb0e
 lib/ftlib.h   |    3 ++-
2edfb0e
 lib/fttlv.c   |   34 +++++++++++++++++-----------------
2edfb0e
 lib/support.c |    5 +++++
2edfb0e
 5 files changed, 27 insertions(+), 21 deletions(-)
2edfb0e
2edfb0e
075301dae1b92110e6cc339b0df88b7fc82c31a6
2edfb0e
diff --git a/lib/ftchash.c b/lib/ftchash.c
2edfb0e
index 9cc7efa..28bafbf 100644
2edfb0e
--- a/lib/ftchash.c
2edfb0e
+++ b/lib/ftchash.c
2edfb0e
@@ -326,7 +326,7 @@ void *ftchash_foreach(struct ftchash *ft
2edfb0e
       (char*)ftch->traverse_chunk->base+ftch->traverse_chunk->next) {
2edfb0e
 
2edfb0e
       ret = ftch->traverse_rec;
2edfb0e
-      (char*)ftch->traverse_rec += ftch->d_size;
2edfb0e
+      ftch->traverse_rec = vpadd(ftch->traverse_rec, ftch->d_size);
2edfb0e
       return ret;
2edfb0e
 
2edfb0e
     } else {
2edfb0e
diff --git a/lib/ftio.c b/lib/ftio.c
2edfb0e
index f6c739c..1082416 100644
2edfb0e
--- a/lib/ftio.c
2edfb0e
+++ b/lib/ftio.c
2edfb0e
@@ -2267,7 +2267,7 @@ int readn(register int fd, register void
2edfb0e
         break;
2edfb0e
 
2edfb0e
       nleft -= nread;
2edfb0e
-      (char*)ptr += nread;
2edfb0e
+      ptr = vpadd(ptr, nread);
2edfb0e
   }
2edfb0e
   return (nbytes - nleft);
2edfb0e
 } /* readn */
2edfb0e
@@ -2292,7 +2292,7 @@ int writen(register int fd, register voi
2edfb0e
       return(nwritten); /* error */
2edfb0e
 
2edfb0e
     nleft -= nwritten;
2edfb0e
-    (char*)ptr += nwritten;
2edfb0e
+    ptr =  vpadd(ptr,nwritten);
2edfb0e
   }
2edfb0e
   return(nbytes - nleft);
2edfb0e
 } /* writen */
2edfb0e
diff --git a/lib/ftlib.h b/lib/ftlib.h
2edfb0e
index f91ad0a..66bf2f3 100644
2edfb0e
--- a/lib/ftlib.h
2edfb0e
+++ b/lib/ftlib.h
2edfb0e
@@ -152,7 +152,6 @@ #define FT_PDU_V8_11_MAXFLOWS 44  /* max
2edfb0e
 #define FT_PDU_V8_12_MAXFLOWS 44  /* max records in V8 DST_PREFIX_TOS packet */
2edfb0e
 #define FT_PDU_V8_13_MAXFLOWS 35  /* max records in V8 PREFIX_TOS packet */
2edfb0e
 #define FT_PDU_V8_14_MAXFLOWS 35  /* max records in V8 PREFIX_PORT_TOS packet */
2edfb0e
-
2edfb0e
 #define FT_PDU_V8_1_VERSION    2  /* version of AS packet */
2edfb0e
 #define FT_PDU_V8_2_VERSION    2  /* version of PROTO PORT packet */
2edfb0e
 #define FT_PDU_V8_3_VERSION    2  /* version of SRC PREFIX packet */
2edfb0e
@@ -3029,6 +3028,8 @@ #ifndef IN_CLASSD_SSM
2edfb0e
 #define IN_CLASSD_SSM(i) (((u_int32_t)(i) & 0xff000000) == 0xe8000000)
2edfb0e
 #endif /* IN_CLASSD_SSM */
2edfb0e
 
2edfb0e
+void *vpadd(const void* v, const int change);
2edfb0e
+
2edfb0e
 /* MACHINE DEPENDANT */
2edfb0e
 #define fmt_uint fmt_uint32
2edfb0e
 
2edfb0e
diff --git a/lib/fttlv.c b/lib/fttlv.c
2edfb0e
index 7035813..330a783 100644
2edfb0e
--- a/lib/fttlv.c
2edfb0e
+++ b/lib/fttlv.c
2edfb0e
@@ -68,10 +68,10 @@ int fttlv_enc_uint32(void *buf, int buf_
2edfb0e
   }
2edfb0e
 
2edfb0e
   bcopy(&t, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&len, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&v, buf, 4);
2edfb0e
 
2edfb0e
@@ -107,10 +107,10 @@ int fttlv_enc_uint16(void *buf, int buf_
2edfb0e
   }
2edfb0e
 
2edfb0e
   bcopy(&t, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&len, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&v, buf, 2);
2edfb0e
 
2edfb0e
@@ -145,10 +145,10 @@ int fttlv_enc_uint8(void *buf, int buf_s
2edfb0e
   }
2edfb0e
 
2edfb0e
   bcopy(&t, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&len, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&v, buf, 1);
2edfb0e
 
2edfb0e
@@ -183,10 +183,10 @@ int fttlv_enc_str(void *buf, int buf_siz
2edfb0e
   }
2edfb0e
 
2edfb0e
   bcopy(&t, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&len, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(v, buf, len);
2edfb0e
 
2edfb0e
@@ -230,16 +230,16 @@ int fttlv_enc_ifname(void *buf, int buf_
2edfb0e
     return -1;
2edfb0e
 
2edfb0e
   bcopy(&t, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&len, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&ip, buf, 4);
2edfb0e
-  (char*)buf += 4;
2edfb0e
+  buf = vpadd(buf, 4);
2edfb0e
 
2edfb0e
   bcopy(&ifIndex, buf, 2);
2edfb0e
-  (char*)buf += 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(name, buf, n);
2edfb0e
 
2edfb0e
@@ -287,19 +287,19 @@ int fttlv_enc_ifalias(void *buf, int buf
2edfb0e
   }
2edfb0e
 
2edfb0e
   bcopy(&t, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&len, buf, 2);
2edfb0e
-  (char*)buf+= 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(&ip, buf, 4);
2edfb0e
-  (char*)buf += 4;
2edfb0e
+  buf = vpadd(buf, 4);
2edfb0e
 
2edfb0e
   bcopy(&entries, buf, 2);
2edfb0e
-  (char*)buf += 2;
2edfb0e
+  buf = vpadd(buf, 2);
2edfb0e
 
2edfb0e
   bcopy(ifIndex_list, buf, esize);
2edfb0e
-  (char*)buf += esize;
2edfb0e
+  buf = vpadd(buf, esize);
2edfb0e
 
2edfb0e
   bcopy(name, buf, n);
2edfb0e
 
2edfb0e
diff --git a/lib/support.c b/lib/support.c
2edfb0e
index a32ffe7..2e1db9f 100644
2edfb0e
--- a/lib/support.c
2edfb0e
+++ b/lib/support.c
2edfb0e
@@ -736,3 +736,8 @@ int udp_cksum(struct ip *ip, struct udph
2edfb0e
   return sum;
2edfb0e
 } /* udp_cksum */
2edfb0e
 
2edfb0e
+// void pointer add
2edfb0e
+
2edfb0e
+void * vpadd(const void *v, const int change) {
2edfb0e
+  return (void *) (((char*) v) + change);
2edfb0e
+}
2edfb0e
-- 
2edfb0e
1.3.3
2edfb0e