Size: 1627
Comment:
|
Size: 1638
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 13: | Line 13: |
{{{ | {{{#!cplusplus |
Back to ComputerTerms
IP Checksum
Process
The IpCheckSum uses the OnesComplement representation of positive and negative numbers.
Given a buffer that is a multiple of 16 bits such as an IP packet header, create a OnesComplement sum of each of the 16 bit words. After you have added all the 16 bit words of the buffer, make sure the result is only 16 bits and return its complement. This is the value added to the checksum field. Now when you add all the pieces, you should get -0 in 1s complement parlance.
The Algorithm
Toggle line numbers
1 cksum(u_short *buf, int count) {
2 register u_long sum = 0;
3
4 while(count--) {
5 sum += *buf++ /* this adds the 16 bit value of *buf and then increments the pointer */
6 if (sum & 0xFFFF0000) { /* if we carried a bit over the 16 bit limit */
7 sum &= 0xFFFF;
8 sum++;
9 }
10 }
11 return ~(sum & 0xFFFF);
Example
\begin{tabular}{rrrrrr} & & $0001$ & $0001$ & & $(17)$ \\ $+$ & & $1111$ & $0111$ & & $(-8)$ \\ \cline{1-4}\cline{6-6} & $1$ & $0000$ & $1000$ & & \\ & & \multicolumn{1}{l}{$\hookrightarrow $} & $+1$ & & \\ \cline{3-4} & & $0000$ & $1001$ & $=$ & $(9)$ \\ \multicolumn{6}{l}{Hence the checksum is:} \\ & & $1111$ & $0110$ & & \end{tabular} \bigskip If we sum up the original two numbers with the checksum we get: \begin{tabular}{rrrr} & & $0001$ & $0001$ \\ & & $1111$ & $0111$ \\ $+$ & & $1111$ & $0110$ \\ \cline{1-4} & & $11111$ & $1110$% \end{tabular} Of couse with the carry over we have:\ $1111~1111$ which is $-0.$
Back to ComputerTerms