CRC16Stream.st
author Claus Gittinger <cg@exept.de>
Sun, 17 Mar 2019 01:12:25 +0100
changeset 4862 461bb4a4a396
parent 4861 7a69e6afd632
child 4865 93698664b4aa
permissions -rw-r--r--
#REFACTORING by cg class: CRC16Stream class changed: #newCCITT
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
4858
8ba5358392d2 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4848
diff changeset
     1
"{ Encoding: utf8 }"
8ba5358392d2 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4848
diff changeset
     2
4848
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
 COPYRIGHT (c) 2003 by eXept Software AG
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
	      All Rights Reserved
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
 This software is furnished under a license and may be used
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
 only in accordance with the terms of that license and with the
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
 inclusion of the above copyright notice.   This software may not
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
 be provided or otherwise made available to, or used by, any
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
 other person.  No title to or ownership of the software is
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
 hereby transferred.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
"{ Package: 'stx:libbasic2' }"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
"{ NameSpace: Smalltalk }"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
CRCStream subclass:#CRC16Stream
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
	instanceVariableNames:''
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
	classVariableNames:''
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
	poolDictionaries:''
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
	category:'System-Crypt-Hashing'
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
!CRC16Stream class methodsFor:'documentation'!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
copyright
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
 COPYRIGHT (c) 2003 by eXept Software AG
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
	      All Rights Reserved
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
 This software is furnished under a license and may be used
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
 only in accordance with the terms of that license and with the
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
 inclusion of the above copyright notice.   This software may not
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
 be provided or otherwise made available to, or used by, any
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
 other person.  No title to or ownership of the software is
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
 hereby transferred.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
documentation
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
    newCRC_CCITT:
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
      Standard CRC method as defined by CCITT 
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
      (ITU-T-T30, ITU-T V42, ITU-T X25, RFC1331, RFC1662, ISO/IEC FCD14443-3).
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
      This is used in data link protocols such as HDLC, SS7, and ISDN.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
      The default polynomial is
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
        x^16 + x^12 + x^5 + 1
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
    newCRC_DNP:
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
      Standard CRC method as defined by DNP.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
      This is used in data link protocols such as HDLC, SS7, and ISDN.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
      The default polynomial is 0x3d65
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
    Only use CRC to protect against communication errors;
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
    do NOT use CRC for cryptography - use SHA1Stream or MD5Stream instead.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
    [author:]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
        Claus Gittinger
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
    [instance variables:]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
    [class variables:]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
    [see also:]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
        SHA1Stream
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
        MD5Stream
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
examples
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
  expect xxx:
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
                                                                [exBegin]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
    self information:(CRC16Stream hashValueOf:'resume') hexPrintString
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
                                                                [exEnd]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
  expect xxx:
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
                                                                [exBegin]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
    self information:(CRC16Stream new
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
                            nextPut:$r;
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
                            nextPut:$e;
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
                            nextPut:$s;
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
                            nextPut:$u;
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
                            nextPut:$m;
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
                            nextPut:$e;
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
                            hashValue) hexPrintString
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
                                                                [exEnd]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
  expect xxx:
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
                                                                [exBegin]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
    self information:(CRC16Stream hashValueOf:#[1 2 3 4 5 6 7]) hexPrintString
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
                                                                [exEnd]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
  expect xxx:
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
                                                                [exBegin]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
    self information:((CRC16Stream hashValueOf:#[16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
             16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
             16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
             16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF 16rFF]) hexPrintString)
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
                                                                [exEnd]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
  expect xxx:
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
  timing throughput:
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
                                                                [exBegin]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
    |hashStream n t|
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
    hashStream := CRC16Stream new.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
    n := 1000000.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
    t := Time millisecondsToRun:[
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
            n timesRepeat:[
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
                hashStream nextPutAll:'12345678901234567890123456789012345678901234567890'.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
            ].
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
         ].
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
    t := (t / 1000) asFloat.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
    Transcript show:'crc16:'; showCR: hashStream hashValue hexPrintString.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
    Transcript show:t; show:' seconds for '; show:(50*n/1024) asFloat; showCR:' Kb'.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
    Transcript show:(n*50/1024 / t); showCR:' Kb/s'
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
                                                                [exEnd]
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
! !
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
!CRC16Stream class methodsFor:'instance creation'!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
generatorPolynomMSB:anInteger
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
    "notice, in literature, the generator polynom is usually specified as an MSB number"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
    ^ self generatorPolynom:(anInteger bitReversed16)
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
    "Created: / 16-03-2019 / 20:58:49 / Claus Gittinger"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
generatorPolynomMSB:anInteger initValue:initValue
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
    "notice, in literature, the generator polynom is usually specified as an MSB number"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
    ^ self generatorPolynom:(anInteger bitReversed16) initValue:initValue
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
    "Created: / 16-03-2019 / 21:12:24 / Claus Gittinger"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
generatorPolynomMSB:anInteger initValue:initValueArg xorOut:xorOut
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
    "notice, in literature, the generator polynom is usually specified as an MSB number"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
    ^ self generatorPolynom:(anInteger bitReversed16) initValue:initValueArg xorOut:xorOut
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
    "Created: / 16-03-2019 / 21:29:04 / Claus Gittinger"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
new
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
    "return an instance of the CCITT CRC-16"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
    ^ self newCCITT
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
    "Created: / 16-03-2019 / 21:33:36 / Claus Gittinger"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
newCCITT
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
    "return an instance of the CCITT CRC-16
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
        2r11110101100101
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
        x16 + x13 + x12 + x11 + x10 + x8 + x6 + x5 + x2 + 1 "
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
4858
8ba5358392d2 #DOCUMENTATION by cg
Claus Gittinger <cg@exept.de>
parents: 4848
diff changeset
   167
    "/ 16r1021 bitReversed16 => 16r8408
4862
461bb4a4a396 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4861
diff changeset
   168
    ^ self generatorPolynomMSB:16r1021 initValue:16rffff xorOut:16rFFFF
4848
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
    "Created: / 16-03-2019 / 21:13:11 / Claus Gittinger"
4862
461bb4a4a396 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4861
diff changeset
   171
    "Modified: / 17-03-2019 / 00:37:40 / Claus Gittinger"
4848
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
newDNP
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
    "return an instance of the DNP CRC-16
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
        2r11110101100101
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
        x16 + x13 + x12 + x11 + x10 + x8 + x6 + x5 + x2 + 1 "
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
    ^ self generatorPolynomMSB:16r3d65 initValue:0 xorOut:16rFFFF
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
    "Created: / 16-03-2019 / 20:50:03 / Claus Gittinger"
4861
7a69e6afd632 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4858
diff changeset
   182
    "Modified (comment): / 17-03-2019 / 00:00:18 / Claus Gittinger"
4848
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
newModbus
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
    "return an instance of the Modbus CRC-16
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
        2r11110101100101
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
        x16 + x13 + x12 + x11 + x10 + x8 + x6 + x5 + x2 + 1 "
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
    ^ self generatorPolynomMSB:16r8005 initValue:16rFFFF xorOut:0
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
    "Created: / 16-03-2019 / 21:15:26 / Claus Gittinger"
4861
7a69e6afd632 #REFACTORING by cg
Claus Gittinger <cg@exept.de>
parents: 4858
diff changeset
   193
    "Modified (comment): / 17-03-2019 / 00:00:23 / Claus Gittinger"
4848
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
! !
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
!CRC16Stream methodsFor:'initialization'!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
generatorPolynom:anInteger
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
    "set the generator polynom for this instance.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
     Note: you have to set the bit-reversed value, so the LSB must be first"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
    self generatorPolynom:anInteger initValue:16rFFFF xorOut:16rFFFF.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   204
    "Modified: / 16-03-2019 / 21:24:35 / Claus Gittinger"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
generatorPolynom:anInteger initValue:initValueArg
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
    "set the generator polynom for this instance.
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
     Note: you have to set the bit-reversed value, so the LSB must be first"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
    self generatorPolynom:anInteger initValue:initValueArg xorOut:16rFFFF
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
    "Created: / 16-03-2019 / 21:24:03 / Claus Gittinger"
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
! !
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
!CRC16Stream class methodsFor:'documentation'!
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   217
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
version_CVS
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
    ^ '$Header$'
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
! !
320b11a3048f initial checkin
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221