Tillbaka till svenska Fidonet
English   Information   Debug  
FIDONEWS_OLD4   0/37224
FIDO_SYSOP   12852
FIDO_UTIL   0/180
FILEFIND   0/209
FILEGATE   0/212
FILM   0/18
FNEWS_PUBLISH   4436
FN_SYSOP   41706
FN_SYSOP_OLD1   71952
FTP_FIDO   0/2
FTSC_PUBLIC   0/13613
FUNNY   0/4886
GENEALOGY.EUR   0/71
GET_INFO   105
GOLDED   0/408
HAM   0/16074
HOLYSMOKE   0/6791
HOT_SITES   0/1
HTMLEDIT   0/71
HUB203   466
HUB_100   264
HUB_400   39
HUMOR   0/29
IC   0/2851
INTERNET   0/424
INTERUSER   0/3
IP_CONNECT   719
JAMNNTPD   0/233
JAMTLAND   0/47
KATTY_KORNER   0/41
LAN   0/16
LINUX-USER   0/19
LINUXHELP   0/1155
LINUX   0/22112
LINUX_BBS   0/957
mail   18.68
mail_fore_ok   249
MENSA   0/341
MODERATOR   0/102
MONTE   0/992
MOSCOW_OKLAHOMA   0/1245
MUFFIN   0/783
MUSIC   0/321
N203_STAT   930
N203_SYSCHAT   313
NET203   321
NET204   69
NET_DEV   0/10
NORD.ADMIN   0/101
NORD.CHAT   0/2572
NORD.FIDONET   189
NORD.HARDWARE   0/28
NORD.KULTUR   0/114
NORD.PROG   0/32
NORD.SOFTWARE   0/88
NORD.TEKNIK   0/58
NORD   0/453
OCCULT_CHAT   0/93
OS2BBS   0/787
OS2DOSBBS   0/580
OS2HW   0/42
OS2INET   0/37
OS2LAN   0/134
OS2PROG   0/36
OS2REXX   0/113
OS2USER-L   207
OS2   0/4786
OSDEBATE   0/18996
PASCAL   0/490
PERL   0/457
PHP   0/45
POINTS   0/405
POLITICS   0/29554
POL_INC   0/14731
PSION   103
R20_ADMIN   1123
R20_AMATORRADIO   0/2
R20_BEST_OF_FIDONET   13
R20_CHAT   0/893
R20_DEPP   0/3
R20_DEV   399
R20_ECHO2   1379
R20_ECHOPRES   0/35
R20_ESTAT   0/719
R20_FIDONETPROG...
...RAM.MYPOINT
  0/2
R20_FIDONETPROGRAM   0/22
R20_FIDONET   0/248
R20_FILEFIND   0/24
R20_FILEFOUND   0/22
R20_HIFI   0/3
R20_INFO2   3249
R20_INTERNET   0/12940
R20_INTRESSE   0/60
R20_INTR_KOM   0/99
R20_KANDIDAT.CHAT   42
R20_KANDIDAT   28
R20_KOM_DEV   112
R20_KONTROLL   0/13300
R20_KORSET   0/18
R20_LOKALTRAFIK   0/24
R20_MODERATOR   0/1852
R20_NC   76
R20_NET200   245
R20_NETWORK.OTH...
...ERNETS
  0/13
R20_OPERATIVSYS...
...TEM.LINUX
  0/44
R20_PROGRAMVAROR   0/1
R20_REC2NEC   534
R20_SFOSM   0/341
R20_SF   0/108
R20_SPRAK.ENGLISH   0/1
R20_SQUISH   107
R20_TEST   2
R20_WORST_OF_FIDONET   12
RAR   0/9
RA_MULTI   106
RA_UTIL   0/162
REGCON.EUR   0/2056
REGCON   0/13
SCIENCE   0/1206
SF   0/239
SHAREWARE_SUPPORT   0/5146
SHAREWRE   0/14
SIMPSONS   0/169
STATS_OLD1   0/2539.065
STATS_OLD2   0/2530
STATS_OLD3   0/2395.095
STATS_OLD4   0/1692.25
SURVIVOR   0/495
SYSOPS_CORNER   0/3
SYSOP   0/84
TAGLINES   0/112
TEAMOS2   0/4530
TECH   0/2617
TEST.444   0/105
TRAPDOOR   0/19
TREK   0/755
TUB   0/290
UFO   0/40
UNIX   0/1316
USA_EURLINK   0/102
USR_MODEMS   0/1
VATICAN   0/2740
VIETNAM_VETS   0/14
VIRUS   0/378
VIRUS_INFO   0/201
VISUAL_BASIC   0/473
WHITEHOUSE   0/5187
WIN2000   0/101
WIN32   0/30
WIN95   0/4289
WIN95_OLD1   0/70272
WINDOWS   0/1517
WWB_SYSOP   0/419
WWB_TECH   0/810
ZCC-PUBLIC   0/1
ZEC   4

 
4DOS   0/134
ABORTION   0/7
ALASKA_CHAT   0/506
ALLFIX_FILE   0/1313
ALLFIX_FILE_OLD1   0/7997
ALT_DOS   0/152
AMATEUR_RADIO   0/1039
AMIGASALE   0/14
AMIGA   0/331
AMIGA_INT   0/1
AMIGA_PROG   0/20
AMIGA_SYSOP   0/26
ANIME   0/15
ARGUS   0/924
ASCII_ART   0/340
ASIAN_LINK   0/651
ASTRONOMY   0/417
AUDIO   0/92
AUTOMOBILE_RACING   0/105
BABYLON5   0/17862
BAG   135
BATPOWER   0/361
BBBS.ENGLISH   0/382
BBSLAW   0/109
BBS_ADS   0/5290
BBS_INTERNET   0/507
BIBLE   0/3563
BINKD   0/1119
BINKLEY   0/215
BLUEWAVE   0/2173
CABLE_MODEMS   0/25
CBM   0/46
CDRECORD   0/66
CDROM   0/20
CLASSIC_COMPUTER   0/378
COMICS   0/15
CONSPRCY   0/899
COOKING   33421
COOKING_OLD1   0/24719
COOKING_OLD2   0/40862
COOKING_OLD3   0/37489
COOKING_OLD4   0/35496
COOKING_OLD5   9370
C_ECHO   0/189
C_PLUSPLUS   0/31
DIRTY_DOZEN   0/201
DOORGAMES   0/2065
DOS_INTERNET   0/196
duplikat   6002
ECHOLIST   0/18295
EC_SUPPORT   0/318
ELECTRONICS   0/359
ELEKTRONIK.GER   1534
ENET.LINGUISTIC   0/13
ENET.POLITICS   0/4
ENET.SOFT   0/11701
ENET.SYSOP   33945
ENET.TALKS   0/32
ENGLISH_TUTOR   0/2000
EVOLUTION   0/1335
FDECHO   0/217
FDN_ANNOUNCE   0/7068
FIDONEWS   24159
FIDONEWS_OLD1   0/49742
FIDONEWS_OLD2   0/35949
FIDONEWS_OLD3   0/30874
Möte FTSC_PUBLIC, 13613 texter
 lista första sista föregående nästa
Text 350, 251 rader
Skriven 2005-05-30 21:42:52 av Michiel Broek (2:280/2802)
Ärende: FSP-1020 Binkp optional protocol extension CRC Checksum
===============================================================
Hello,

the final draft for FSP-1020:

 
**********************************************************************
FTSC                             FIDONET TECHNICAL STANDARDS COMMITTEE
**********************************************************************

Publication:    FSP-1020
Revision:       final draft.
Title:          Binkp optional protocol extension CRC Checksum.
Authors:        Tobias Ernst (publisher of this protocol),
                Michiel Broek (documentation for FTSC).
Issue Date:     30 May 2005
Review Date:    30 May 2007
----------------------------------------------------------------------
Contents:
                1. Definitions
                2. Binkp CRC Checksum Mode
                   2.1 Introduction
                   2.2 Protocol specification
                   2.3 Further thoughts
                   2.4 CRC-32 Algorithm
                3. Compatibility issues
                A. References
                B. History
----------------------------------------------------------------------

Status of this document
-----------------------

   This document is a Fidonet Standard Proposal (FSP), issued by the
   FTSC for the benefit of the Fidonet community.

   This document specifies an optional Fidonet standard protocol for
   the Fidonet community, and requests discussion and suggestions for
   improvements.

   This document is released to the public domain, and may be used,
   copied or modified for any purpose whatever.

   This document describes the binkp CRC option published by Tobias
   Ernst on 12 januari 2000 (Paragraph 2). This paragraph has some
   changes for use in ftsc documentation. 
   The original document can be found at:
   http://www.physcip.uni-stuttgart.de/tobi/binkd/BINKP_CRC_PROPOSAL


1. Definitions
--------------

   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
   NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL"
   in this document are to be interpreted as described in [FTA-1006].


2. Binkp CRC Checksum Mode
--------------------------

2.1 Introduction
----------------

   Binkp originally was designed to work on top of a reliable
   transmission layer, i.E. a transmission layer that has its own
   checksums, like TCP. Therefore, the Binkp specification does not
   provide a way for controlling correct data transfer, because
   it is assumed that the underlying TCP transport layer does the
   necessary data integrity checks.

   However, I have seen TCP connections trashing data at random, and
   actually have suffered from mail loss because a file received by
   binkd was not identical with the file that the sender has
   transmitted.

   Therefore, this document specifies an extension to the Binkp
   protocol which allows data integrity checks by means of CRC32
   checksums. It is intended as an *optional* feature in Binkp for
   those nodes that live in places with an unreliable TCP routing
   structure (like I seem to do), and it is fully backwards
   compatible.


2.2 Protocol specification
--------------------------

   During session handshake, a mailer that knows the CRC protocol
   extension MAY send an "M_NUL OPT CRC" message. This indicates
   that the mailer is able to process the CRC-extended "M_FILE"
   messages described below, nothing more.

   The other end which receives the OPT CRC message will switch to
   CRC-secure mode (probably only if CRC-secure mode has been
   allowed by the sysop for the particluar other end). Note that
   even if this end previously has sent a M_NUL OPT CRC on its own,
   it is not forced to switch to CRC mode, it is just an option.

   In the following, the "sending end" is the Binkp mailer which is
   transmitting a file, and the "receiving end" is the mailer which
   is receiving it. Of course, in a Binkp session, both sides can
   become both sending and the receiving ends.

   When the sending end is in CRC-secure mode, it will send an
   extended M_FILE message with an additional fifth argument,
   specifying a CCITT CRC32 checksum for the file that is following.
   This means that the mailer has to calculate the checksum before
   transmitting the file.

   The checksum is pre-conditioned and postconditioned. This means
   that the initial CRC-value is 0xFFFFFFFF (preconditioning), and
   after the final value has been computed, all bits must be in-
   verted (postconditioning).

   The format of the fifth M_FILE argument is a sequence of up to
   eight hexadecimal digits in ASCII. Leading digits may be omitted,
   trailing digits must not be omitted.

   The receiving end, if it has sent an "M_NUL OPT CRC", MUST be
   able to process M_FILE messages with either four or five
   arguments. If it receives a M_FILE message with five arguments,
   it will treat the fifth argument as a checksum and, after
   receiving the file, will compare this checksum with the checksum
   it has computed from the data that has been received.

   If the checksums disagree, the receiving end has two options. It
   can either send a M_SKIP for this file. This will cause a
   non-destructive reject of the file, so that the session goes on,
   but the remote site will mark the file as not sent successfully
   and retransmit it in the next session. Or it can send a M_ERR,
   indicating a fatail failure, which will terminate the session,
   and also cause a non-destructive reject of this and all following
   files. It is suggested that on the first CRC failure, a M_SKIP
   is sent, but if the next file also has an error, indicating that
   the session is completely faulty, a M_ERR  could be transmitted
   instead.


2.3 Further thoughts
--------------------

   There are some disadvantages of this way of implementing CRC:

   1. The CRC checksum must be computed before the file
      transmission STARTS, instead of during the transmission.

   2. The protocol will fail if errors don't occur spontaneous, but
      regularly with an error rate  greater than 1 error per file. 
      In this case, transmission will be impossible because all 
      files will always be rejected.

   Why then implement it this way? It is the easiest way to
   implement CRC fully backwards compatible, and it is the way that
   requries the least amount of changes in the code of existing
   binkp mailers. Even given the mentioned disadvantages, the
   extension is good enough for detecting spontaneous transmission
   errors, so that sysops will not loose valuable data, and so that
   they can see that there is a problem in the network infrastructure
   and fix it. That is, this extension is intended as a safeguard 
   against rare error conditions on a transport layer that still, 
   basically, is reliable.

   This extension, however, is not suitable for transmission over a
   transport layer which is unreliable by definition, as a standard
   modem connection. But that was not the goal of binkp from the
   beginning.

   In the future, it might be worth considering an extension to the
   binkp protocol which goes furhter. For example, one CRC32
   checksum could be transmitted at the end of each frame, and a
   mechanism for directly resending frames


2.4 CRC-32 Algorithm
--------------------

   The checksum algorithm that is used is CRC-32 following CCITT's
   specifications. For further information refer to the literature
   list given below. The following pseudocode shows how to
   calculate such a checksum for a file of N bytes indexed from 0 to
   N-1 and stored in BUFFER. The XOR, AND and NOT logical
   operations are to be executed bit-wise. In C, for instance, XOR
   equals ^, AND equals &, and NOT equals ~.

   // CRC, I, J, K are unsigned integers of at least 32 bits.
   UNSIGNED LONG CRC, I, J, K

   // Preconditioning
   CRC = FFFFFFFF

   // Loop through all bytes in the file
   FOR J = 0 TO N-1
      K = (CRC XOR BYTE#J) & 000000FF  // (*)
      FOR I = 8 DOWNTO 1
         IF K AND 1 <> 0
           THEN K = (K SHR 1) XOR EDB88320
         ELSE
           K = K SHR 1
         ENDIF
      END FOR                          // (**)
      CRC = ((CRC SHR 8) AND 00FFFFFF) XOR K
   END FOR

   // Postconditioning: Flip all bits
   CRC = NOT CRC;

   Note that as in the line marked as (*), K can initially only get
   values in the range from 0 to 255. Therefore it is a good idea
   to replace the inner loop over I with a lookup table routine,
   i.E. generate a lookup table for the outcomes of K after the loop
   with initial values of K from 0 to 255, and then replace lines
   (*) up to and including (**) with something like

    K = LOOKUPTABLE [ (CRC XOR BYTE#J) XOR 000000FF ]

 Author: Tobias Ernst


3. Compatibility issues
-----------------------

   The CRC option cannot be used together with some other options
   which also use extra parameters with the M_FILE messages.


A. References
-------------

   [FSP-1018]
           Binkp 1.0 Protocol specification.

   [FTA-1006]
           Key words to indicate requirement levels, Fidonet Technical
           Standards Committee administrative. FTA-1006.

B. History
----------
   Rev.1, 20050530:
          First release, protocol extension published by Tobias Ernst
          on 12 januari 2000 imported.



    Greetings, Michiel Broek

Email:   mbse@mbse.dds.nl
Fidonet: Michiel Broek at 2:280/2802

... We're making progress.  Things are getting worse at a slower rate.

--- MBSE BBS v0.71.2 (GNU/Linux-i386)
 * Origin: MBSE Linux BBS. Made in the Netherlands (2:280/2802)