2017-10-04 22 views
0

TI cc26xx 센서 태그에 SHA256을 구현하려고합니다. 여기 제공된 TI_SHA_256 API를 사용하고 있습니다 : http://www.ti.com/tool/crypto. 내 주요 테스트 코드는 다음과 같다 : 각종 온라인 SHA256 계산기 (http://www.fileformat.info/tool/hash.htm)에 따르면잘못된 값을 반환하는 cc26xx에 대한 TI sha256

... 
/* Crypto APIs Header */ 
#include "lib/TI_SHA_256.h" 
#include <stdio.h> 

uint32_t M[32] = { 0xe8 , 0x9d , 0xa1 , 0xd1 , 0xc7 , 0x4d , 0xee , 0x16 , 0x75 , 0x30 , 0x07 , 0x9a , 0x19 , 0xd1 , 0x5d , 0x76, 
        0x12 , 0x97 , 0xe4 , 0xb6 , 0xc8 , 0x03 , 0x38 , 0x1a , 0x41 , 0x6d , 0xac , 0x92 , 0xbf , 0x63 , 0x51 , 0x7a }; 
uint32_t Ha[8]; 
uint32_t *H_Array; 
volatile uint64_t L = 0x800; 

void uint32_print(char name[], uint32_t *data, int c) 
{ 
    uint32_t i; 
    if (c == 1){ 
     printf(name); 
     for(i = 0; i < 32; i++) { 
     printf("%x", data[i]); 
     } 
     printf("\r\n"); 
    } 
    else { 
     printf(name); 
     for(i = 0; i < 8; i++) { 
     printf("%x ", data[i]); 
     } 
     printf("\r\n"); 
    } 
} 

/*---------------------------------------------------------------------------*/ 
PROCESS(test_process, "Test process"); 
/*---------------------------------------------------------------------------*/ 
PROCESS_THREAD(test_process, ev, data) 
{ 
    PROCESS_BEGIN(); 

    printf("\r\n ---------------- TEST OF SHA API ------------------------ \r\n"); 
    uint32_print("Original text:", M, 1); 
    L= 0x200; 
    SHA_256(M, L, Ha, 1); 
    uint32_print("text:", M, 1); 
    uint32_print("Hashed text: ", Ha, 2); 
    printf("\r\n ---------------- \r\n"); 

    PROCESS_END(); 
} 
AUTOSTART_PROCESSES(&test_process); 

, 체크섬이 있어야하는데 : 내 코드로 다음과 같은 인쇄 73411b58707db59d6bc3cd854850eca62058d0d9f74a1ea8260d5ccdd9ac5f87

:

---------------- TEST OF SHA API ------------------------ 
text:e89da1d1c74dee16753079a19d15d761297e4b6c83381a416dac92bf63517a 
text:e89da1d1c74dee16753079a19d15d768000000000000000000000200 
Hashed text: 91da5dd5 6cbfcca9 85fcf373 90ae73e0 9e27a4d9 c42b100c 6e746091 eda68da7 
---------------- 

제 질문은 다음과 같습니다. 내 코드가 잘못된 해시 합을 반환하는 이유는 무엇입니까?

답변

0

코드는 배열 M의 첫 번째 절반 (0x200=512 비트 또는 64 바이트)의 SHA-256 해시를 0xe8 , 0x9d , ... , 0x76으로 초기화합니다.

그러나, 배열 M가 메모리에이 (가정 빅 엔디안 아키텍처)처럼 보이는 것을 의미 유형 uint32_t의 요소가 있습니다

000000e80000009d000000a1000000d1000000c70000004d000000ee000000160000007500000030000000070000009a00000019000000d10000005d00000076 

하나는 온라인 계산기에서 확인할 수 있듯이을, 해시 이건 91da5dd56cbfcca985fcf37390ae73e09e27a4d9c42b100c6e746091eda68da7입니다. 코드에서 SHA_256() 함수에 의해 계산 된 올바른 값입니다.

+0

감사합니다. 정말로 감사드립니다. – kogito