summaryrefslogtreecommitdiffstats
path: root/isisd/iso_checksum.c
diff options
context:
space:
mode:
authorQuentin Young <qlyoung@cumulusnetworks.com>2017-05-22 17:52:30 +0200
committerQuentin Young <qlyoung@cumulusnetworks.com>2017-05-26 17:22:23 +0200
commitc5f119c06dbf56887709912cf247cc7679ffc411 (patch)
treeacf0cf6d58a18de2a2f1c34fe7aabdd3e8b320c4 /isisd/iso_checksum.c
parentMerge pull request #610 from donaldsharp/rpprefixlen (diff)
downloadfrr-c5f119c06dbf56887709912cf247cc7679ffc411.tar.xz
frr-c5f119c06dbf56887709912cf247cc7679ffc411.zip
*: do not take address of packed member
May result in alignment errors on certain platforms Signed-off-by: Quentin Young <qlyoung@cumulusnetworks.com>
Diffstat (limited to 'isisd/iso_checksum.c')
-rw-r--r--isisd/iso_checksum.c11
1 files changed, 4 insertions, 7 deletions
diff --git a/isisd/iso_checksum.c b/isisd/iso_checksum.c
index d036c0ba7..70b6b91ed 100644
--- a/isisd/iso_checksum.c
+++ b/isisd/iso_checksum.c
@@ -46,14 +46,14 @@
*/
int
-iso_csum_verify (u_char * buffer, int len, uint16_t * csum)
+iso_csum_verify (u_char * buffer, int len, uint16_t csum, int offset)
{
u_int16_t checksum;
u_int32_t c0;
u_int32_t c1;
- c0 = *csum & 0xff00;
- c1 = *csum & 0x00ff;
+ c0 = csum & 0xff00;
+ c1 = csum & 0x00ff;
/*
* If both are zero return correct
@@ -67,11 +67,8 @@ iso_csum_verify (u_char * buffer, int len, uint16_t * csum)
if (c0 == 0 || c1 == 0)
return 1;
- /* Offset of checksum from the start of the buffer */
- int offset = (u_char *) csum - buffer;
-
checksum = fletcher_checksum(buffer, len, offset);
- if (checksum == *csum)
+ if (checksum == csum)
return 0;
return 1;
}