Delta DVP-ES2 Manuel d'utilisateur Page 611

  • Télécharger
  • Ajouter à mon manuel
  • Imprimer
  • Page
    / 702
  • Table des matières
  • MARQUE LIVRES
  • Noté. / 5. Basé sur avis des utilisateurs
Vue de la page 610
4. Communications
Field Name Example (Hex)
Data Lo (T24) 05
Data Hi (T25) 00
Data Lo (T25) 06
Data Hi (T26) 00
Data Lo (T26) 07
Data Hi (T27) 00
Data Lo (T27) 08
CRC CHK Low 72
CRC CHK High 98
END
No data input 10 ms
4.3.3 CRC CHK (check sum)
The CRC Check starts from “Slave Address” and ends in “The last data content.” Calculation of CRC:
Step 1: Set the 16-bit register (CRC register) = FFFFH.
Step 2: Operate XOR on the first 8-bit message (Address) and the lower 8 bits of CRC register. Store
the result in the CRC register
Step 3: Right shift CRC register for a bit and fill “0” into the highest bit.
Step 4: Check the lowest bit (bit 0) of the shifted value. If bit 0 is 0, fill in the new value obtained at step
3 to CRC register; if bit 0 is NOT 0, operate XOR on A001H and the shifted value and store the result in
the CRC register.
Step 5: Repeat step 3 – 4 to finish all operation on all the 8 bits.
Step 6: Repeat step 2 – 5 until the operation of all the messages are completed. The final value
obtained in the CRC register is the CRC checksum. Care should be taken when placing the LOW byte
and HIGH byte of the obtained CRC checksum.
Calculation example of the CRC Check using the C language:
unsigned char* data Å // index of the command message
unsigned char length Å // length of the command message
unsigned int crc_chk(unsigned char* data, unsigned char length)
{
int j;
unsigned int reg_crc=0Xffff;
while(length--)
4-9
Vue de la page 610
1 2 ... 606 607 608 609 610 611 612 613 614 615 616 ... 701 702

Commentaires sur ces manuels

Pas de commentaire