Posted to tcl by kbk at Thu Oct 22 16:00:48 GMT 2009view raw

  1. proc inet_cksum8_kbk {data} {
  2. set sum 0
  3. binary scan $data cu* x
  4. if {[llength $x] & 1} {
  5. lappend x 0
  6. }
  7. foreach {v w} $x {
  8. set sum [expr {$sum + ($v << 8) + $w}]
  9. set sum [expr {($sum & 0xffff) | ($sum >> 16)}]
  10. }
  11. return $sum
  12. }