123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198 |
- #include "sha256.h"
- #include "flash.h"
- #include <string.h>
- #include <stdio.h>
- #include <stdlib.h>
- #include "ali_genie_profile.h"
- #define ALI_GENIE_PID_LEN 4
- #define ALI_GENIE_SEC_LEN 16
- #define VENDOR_PRODUCT_ID_ADDR 0x4030
- #define VENDOR_PRODUCT_SECRERT_ADDR 0x4010
- #define VENDOR_PRODUCT_MAC_ADDR 0x4000
- unsigned char ali_genie_pid[4] ={0x00};
- unsigned char ali_genie_mac[6] ={0x00};
- unsigned char ali_genie_macStr[12];
- unsigned char ali_genie_sec[16] ={0x00};
- unsigned char ali_genie_auth[16]={0x00};
- void hex2Str( unsigned char* pIn,unsigned char*pOut ,int len ,int reverse)
- {
- int i;
- unsigned char hex[] = "0123456789abcdef";
-
- if(reverse)
- {
- pIn += len;
- for ( i = len; i > 0; i-- )
- {
- *pOut++ = hex[*--pIn >> 4];
- *pOut++ = hex[*pIn & 0x0F];
- }
- }
- else
- {
- for ( i = 0; i <len; i++ )
- {
- *pOut++ = hex[*pIn >> 4];
- *pOut++ = hex[*pIn++ & 0x0F];
-
- }
- }
-
- }
- int gen_aligenie_auth_val(void)
- {
- int i, buflen, ret = 0;
-
- unsigned char buf[54];
- unsigned char sha256sum[32];
- mbedtls_sha256_context ctx;
-
- for(i=0;i<4;i++)
- ali_genie_pid[i]=(uint8_t)ReadFlash(VENDOR_PRODUCT_ID_ADDR+i);
- hex2Str(ali_genie_pid,buf,4,0);
- printf("\n === PID === \n");
- for(i=0;i<4;i++)
- printf("%02X ",ali_genie_pid[i]);
- printf("\n");
- buf[8]=0x2c;
-
- uint32 address = VENDOR_PRODUCT_MAC_ADDR;
-
- ali_genie_mac[3] = (uint8_t)ReadFlash(address ++);
- ali_genie_mac[2] = (uint8_t)ReadFlash(address ++);
- ali_genie_mac[1] = (uint8_t)ReadFlash(address ++);
- ali_genie_mac[0] = (uint8_t)ReadFlash(address ++);
-
- ali_genie_mac[5] = (uint8_t)ReadFlash(address ++);
- ali_genie_mac[4] = (uint8_t)ReadFlash(address);
- printf("\n === MAC === \n");
- for(i=0;i<6;i++)
- printf("%02X ",ali_genie_mac[5-i]);
- printf("\n");
-
-
- hex2Str(ali_genie_mac,ali_genie_macStr,6,1);
- for(i=0;i<12;i++)
- buf[9+i]=ali_genie_macStr[i];
-
- buf[21]=0x2c;
-
- for(i=0;i<16;i++)
- ali_genie_sec[i]=(uint8_t)ReadFlash(VENDOR_PRODUCT_SECRERT_ADDR+i);
- hex2Str(ali_genie_sec,buf+22,16,0);
- mbedtls_sha256_init( &ctx );
-
- if( ( ret = mbedtls_sha256_starts_ret( &ctx, 0 ) ) != 0 )
- goto fail;
-
- buflen = 54;
- if( (ret = mbedtls_sha256_update_ret( &ctx, buf, buflen )) != 0 )
- goto fail;
-
- if( ( ret = mbedtls_sha256_finish_ret( &ctx, sha256sum ) ) != 0 )
- goto fail;
- goto exit;
- fail:
- printf( "failed\n" );
- exit:
-
- for(i=0;i<16;i++)
- {
- ali_genie_auth[i]=sha256sum[i];
- }
- return( ret );
- }
|