zoukankan      html  css  js  c++  java
  • EWARM 6.40 STM32 CRC32

     1 uint32_t calcCrc32(uint8_t* data, uint32_t len)
     2 {
     3   uint32_t* pBuffer = (uint32_t*) data;
     4   uint32_t BufferLength = len/4;
     5   uint32_t index = 0;
     6   RCC_AHB1PeriphClockCmd( RCC_AHB1Periph_CRC, ENABLE );
     7   CRC ->CR = CRC_CR_RESET;
     8   for(index = 0; index < BufferLength; index++)
     9     CRC->DR = pBuffer[index];
    10   index = CRC->DR;
    11   RCC_AHB1PeriphClockCmd( RCC_AHB1Periph_CRC, DISABLE );
    12   return index;
    13 }
    1   extern unsigned int __checksum;
    2   if ( __checksum != calcCrc32( (unsigned char*)0x20000000 , 16 ) )
    3     for ( ;; )
    4       ;

    "--fill" "0xFF;0x20000000-0x2000000f" "--checksum"  "__checksum:4,crc=0x4c11db7:Li,0xffffffff;0x20000000-0x2000000f" "--verbose"  "$TARGET_PATH$" "$TARGET_PATH$"

    "--fill" "0xFF;0x20000000-0x2000000f" "--checksum" "__checksum:4,crc=0x4c11db7:ri,0xffffffff;0x20000000-0x2000000f" "--verbose" "$TARGET_PATH$" "$TARGET_PATH$"

    两种选项, 相同结果

    --checksum { symbol [+offset] | address }  :  size, algorithm[ : [1|2]  [m]  [L|W]  [r]  [i|p] ] [,start];  range   [;range...]

    symbol : The name of the symbol where the checksum value should be stored. Note that it must exist in the symbol table in the input ELF file

    offset : An offset to the symbol.

    address :  The absolute address where the checksum value should be stored.

    size : The number of bytes in the checksum: 1, 2, or 4; must not be larger than the size of the checksum symbol.

    algorithm : The checksum algorithm used, one of :

        sum           a byte-wise calculated arithmetic sum. The result is truncated to 8 bits.
        sum8wide  a byte-wise calculated arithmetic sum. The result is truncated to the size of the symbol.
        sum32       a word-wise (32 bits) calculated arithmetic sum
        crc16        CRC16 (generating polynomial 0x11021); used by default
        crc32        CRC32 (generating polynomial 0x104C11DB7)
        crc=n       CRC with a generating polynomial of n

    1|2 : If specified, can be one of: • 1 - Specifies one's complement.  • 2 - Specifies two's complement

    m : Reverses the order of the bits within each byte when calculating the checksum.

    L|W : Specifies the size of the unit for which a checksum should be calculated.
             Using these parameters does not add any additional error detection power to the checksum.
         Typically, this is useful to make the linker produce the same checksum as some hardware CRC implementations
             that calculate a checksum for more than 8 bits per iteration. Choose between: 

             L : calculates a checksum on 32 bits in every iteration
            W : calculates a checksum on 16 bits in every iteration.
            If you do not specify a unit size, 8 bits will be used by default.

    r : Reverses the byte order of the input data within each word of size "size".

    i|p : Use either i or p, if the start value is bigger than 0. If specified, can be one of:

           • i - Initializes the checksum value with the start value.
           • p - Prefixes the input data with a word of size "size" that contains the "start" value

    start :  By default, the initial value of the checksum is 0x00000000 .
               If necessary, use start to supply a different initial value. If not 0x00000000, then either i or p must be specified

    range :  The address range on which the checksum should be calculated. 
                 Hexadecimal and decimal notation is allowed (for example, 0x8002–0x8FFF).

     


  • 相关阅读:
    zookeeper基础笔记
    基于spring@aspect注解的aop实现
    Struts2中的开启AsyncContext的方法
    在执行gem install redis时 : ERROR: Error installing redis: redis requires Ruby version >= 2.2.2
    ConcurrentHashMap原理笔记
    Java并发Condition原理分析
    CountDownLatch实现原理
    ThreadPoolExecutor 线程池原理分析
    HashMap原理
    线程池的用法
  • 原文地址:https://www.cnblogs.com/shangdawei/p/2853751.html
Copyright © 2011-2022 走看看