1145 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			1145 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#include <stdio.h>
 | 
						|
#include <stdlib.h>
 | 
						|
#include <string.h>
 | 
						|
#include <time.h>
 | 
						|
#include <stdint.h>
 | 
						|
#include <sys/stat.h>
 | 
						|
#include <arpa/inet.h>
 | 
						|
#include "sha256.h"
 | 
						|
#include "iot_img_hdr.h"
 | 
						|
 | 
						|
char default_hash_iv[]={0x12,0x34,0x56,0x78,0x87,0x65,0x43,0x21,0x5A,0x5A,0x5A,0x5A,0x00,0x7E,0xC3,0x00};
 | 
						|
 | 
						|
#define NEW_LINE "\r\n"
 | 
						|
 | 
						|
#define OK        0
 | 
						|
#define ERROR    (-1)
 | 
						|
 | 
						|
#define FUNC_CONSTRUCT      "-c"
 | 
						|
#define FUNC_SHOWHEADER     "-s"
 | 
						|
 | 
						|
#define PK_NAME_KEY_WORD    "iot_flash"
 | 
						|
#define PK_SINGLE_FILE_SIZE 0x1000000 /* sigle file size keeped under 16MB */
 | 
						|
#define MAX_IMAGE_NUM       20
 | 
						|
#define imgHeaderSize       HEADER_TOLTAL_SIZE
 | 
						|
 | 
						|
char * global_buffer = NULL;
 | 
						|
 | 
						|
unsigned int CRC32_Update(unsigned int crc, char *buff, int len);
 | 
						|
 | 
						|
typedef unsigned short UINT16;
 | 
						|
typedef unsigned int UINT32;
 | 
						|
 | 
						|
typedef struct
 | 
						|
{
 | 
						|
    char *pName;
 | 
						|
    int ver;
 | 
						|
    int devType;
 | 
						|
    int imgType;
 | 
						|
}ftype;
 | 
						|
 | 
						|
enum{
 | 
						|
    RET_OK,
 | 
						|
    RET_ENV_FAILED,
 | 
						|
    RET_BAD_PARA,
 | 
						|
    RET_IMAGE_WRONG,
 | 
						|
};
 | 
						|
 | 
						|
#define GET_BYTE1(i) ((i)&0xFF)
 | 
						|
#define GET_BYTE2(i) (((i)>>8)&0xFF)
 | 
						|
#define GET_BYTE3(i) (((i)>>16)&0xFF)
 | 
						|
#define GET_BYTE4(i) (((i)>>24)&0xFF)
 | 
						|
 | 
						|
#define PATH_LENGTH 128
 | 
						|
#define KEYWRD_LENGTH (PATH_LENGTH - 12) /* "20170901.bin" -> 12 bytes */
 | 
						|
typedef struct ah_image_config_
 | 
						|
{
 | 
						|
    int image_type;
 | 
						|
    int version;
 | 
						|
    int offset;
 | 
						|
    int length;
 | 
						|
//    int pad_enable;
 | 
						|
//    int pad;
 | 
						|
    char path[PATH_LENGTH];
 | 
						|
    char fwpath[PATH_LENGTH];
 | 
						|
}ah_img_cfg;
 | 
						|
 | 
						|
typedef struct ah_device_config_
 | 
						|
{
 | 
						|
    int device_type;
 | 
						|
    int encrypt_mode;
 | 
						|
    int encrypt_pattern;
 | 
						|
    int image_num;
 | 
						|
    int version;
 | 
						|
    int top_header_enable;
 | 
						|
    int package_type;
 | 
						|
    int img_size;
 | 
						|
    int layout_index;
 | 
						|
    int lzma_type;
 | 
						|
    int fw2_load;
 | 
						|
    int img_type;
 | 
						|
    int vendor_id;
 | 
						|
    int magic_no;
 | 
						|
    int crc;
 | 
						|
    char key_word[PATH_LENGTH];
 | 
						|
    ah_img_cfg image[MAX_IMAGE_NUM];
 | 
						|
}ah_cfg;
 | 
						|
 | 
						|
 | 
						|
#define CH_SPC    0x20
 | 
						|
#define CH_TAB    0x09
 | 
						|
 | 
						|
int ah_funShowHeader(char argc, char *argv[]);
 | 
						|
 | 
						|
int ah_atoi(char * str)
 | 
						|
{
 | 
						|
    int value = 0;
 | 
						|
    int sign = 1;
 | 
						|
    int radix;
 | 
						|
 | 
						|
 | 
						|
    if(*str == '-')
 | 
						|
    {
 | 
						|
        sign = -1;
 | 
						|
        str++;
 | 
						|
    }
 | 
						|
    if(*str == '0' && (*(str+1) == 'x' || *(str+1) == 'X'))
 | 
						|
    {
 | 
						|
        radix = 16;
 | 
						|
        str += 2;
 | 
						|
    }
 | 
						|
    else if(*str == '0')
 | 
						|
    {
 | 
						|
        radix = 8;
 | 
						|
        str++;
 | 
						|
    }
 | 
						|
    else
 | 
						|
    {
 | 
						|
        radix = 10;
 | 
						|
    }
 | 
						|
    while(*str)
 | 
						|
    {
 | 
						|
        if(radix == 16)
 | 
						|
        {
 | 
						|
            if(*str >= '0' && *str <= '9')
 | 
						|
            {
 | 
						|
                value = value * radix + *str - '0';
 | 
						|
            }
 | 
						|
            else if(*str >= 'A' && *str <= 'F')
 | 
						|
            {
 | 
						|
                value = value * radix + *str - 'A' + 10;
 | 
						|
            }
 | 
						|
            else if(*str >= 'a' && *str <= 'f')
 | 
						|
            {
 | 
						|
                value = value * radix + *str - 'a' + 10;
 | 
						|
            }
 | 
						|
            else
 | 
						|
            {
 | 
						|
                break;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        else if(radix == 8)
 | 
						|
        {
 | 
						|
            if(*str >= '0' && *str <= '7')
 | 
						|
            {
 | 
						|
                value = value * radix + *str - '0';
 | 
						|
            }
 | 
						|
            else
 | 
						|
            {
 | 
						|
                break;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            if(*str >= '0' && *str <= '9')
 | 
						|
            {
 | 
						|
                value = value * radix + *str - '0';
 | 
						|
            }
 | 
						|
            else
 | 
						|
            {
 | 
						|
                break;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        str ++;
 | 
						|
    }
 | 
						|
    return sign*value;
 | 
						|
}
 | 
						|
 | 
						|
static int ah_isSpace(int c)
 | 
						|
{
 | 
						|
  switch (c) {
 | 
						|
  case 0x20:
 | 
						|
  case 0xD:
 | 
						|
  case 0xA:
 | 
						|
  case 0x9:
 | 
						|
    return 1;
 | 
						|
  }
 | 
						|
  return 0;
 | 
						|
}
 | 
						|
#define ISSPACE(c) ah_isSpace(c)
 | 
						|
 | 
						|
/* skip white space */
 | 
						|
char *ah_GetValidString(char *str)
 | 
						|
{
 | 
						|
    char *start, *end;
 | 
						|
    start = str;
 | 
						|
    end = str+strlen(str)-1;
 | 
						|
 | 
						|
    while((start<=end) && ISSPACE(*start)) start++;
 | 
						|
 | 
						|
    while((start<=end) && ISSPACE(*end)) end--;
 | 
						|
 | 
						|
    if(start > end)
 | 
						|
        return NULL;
 | 
						|
 | 
						|
    *(end+1) = 0x0;
 | 
						|
 | 
						|
    return start;
 | 
						|
}
 | 
						|
 | 
						|
char *ah_GetKeyString(FILE *fp, char *title, char *key)
 | 
						|
{
 | 
						|
#define LINE_LENGTH 1024
 | 
						|
    int  start=0;
 | 
						|
    char *pt;
 | 
						|
    static char sLine[LINE_LENGTH];
 | 
						|
 | 
						|
    fseek(fp, 0, SEEK_SET);
 | 
						|
 | 
						|
    while (NULL != fgets(sLine, LINE_LENGTH, fp)) {
 | 
						|
 | 
						|
        if (('#' ==sLine[0])
 | 
						|
            ||(';' ==sLine[0]))
 | 
						|
            continue;
 | 
						|
 | 
						|
        if('[' ==sLine[0])
 | 
						|
        {
 | 
						|
            start =0;
 | 
						|
        }
 | 
						|
 | 
						|
        if(start)
 | 
						|
        {
 | 
						|
            if((NULL != (pt = strchr(sLine, '=')))
 | 
						|
                &&(0 == strncmp(key, sLine, pt-sLine)))
 | 
						|
            {
 | 
						|
                sLine[LINE_LENGTH-1] = 0x0;
 | 
						|
                pt = ah_GetValidString(pt + 1);;
 | 
						|
                return pt;
 | 
						|
            }
 | 
						|
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            if(0 == strncmp(title, sLine, strlen(title)-1))
 | 
						|
            {
 | 
						|
                start =1;
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
    }
 | 
						|
    return NULL;
 | 
						|
}
 | 
						|
 | 
						|
void ah_help(void)
 | 
						|
{
 | 
						|
    printf(NEW_LINE"--Usage of ah:"NEW_LINE);
 | 
						|
    printf(NEW_LINE"ah -c config-file");
 | 
						|
    printf(NEW_LINE"    e.g. ah -c ./ah_config.cfg");
 | 
						|
    printf(NEW_LINE"ah -s file");
 | 
						|
    printf(NEW_LINE"    Show the header(s) of a package."NEW_LINE);
 | 
						|
    printf(NEW_LINE);
 | 
						|
 | 
						|
    return ;
 | 
						|
}
 | 
						|
 | 
						|
static void ah_Sha256(unsigned char* img, int len, unsigned char* sha256)
 | 
						|
{
 | 
						|
    sha256_context ctx;
 | 
						|
 | 
						|
    sha256_init( &ctx );
 | 
						|
    sha256_starts( &ctx );
 | 
						|
    sha256_update( &ctx, img, len );
 | 
						|
    sha256_update( &ctx, (unsigned char*)default_hash_iv, 16);
 | 
						|
    sha256_finish( &ctx, sha256 );
 | 
						|
    sha256_free( &ctx );
 | 
						|
}
 | 
						|
 | 
						|
#define DEVICE_STR              "[DEVICE]"
 | 
						|
#define DEVICE_STR_TYPE         "device_type"
 | 
						|
#define DEVICE_STR_IMGNUM       "image_num"
 | 
						|
#define DEVICE_STR_KEYWRD       "key_word"
 | 
						|
#define DEVICE_STR_TOPHDRENA    "top_header_enable"
 | 
						|
#define DEVICE_STR_TOPHDRENC    "encrypt_mode"
 | 
						|
#define DEVICE_STR_TOPHDRPTN    "encrypt_pattern"
 | 
						|
#define DEVICE_STR_TOPHDRVER    "version"
 | 
						|
#define DEVICE_STR_PACKAGE_TYPE "package_type"
 | 
						|
#define DEVICE_STR_MAGIC_NO     "magic_no"
 | 
						|
#define DEVICE_STR_IMAGE_SIZE   "img_size"
 | 
						|
#define DEVICE_STR_LAYOUT_INDEX "layout_index"
 | 
						|
#define DEVICE_STR_LZMA_TYPE    "lzma_type"
 | 
						|
#define DEVICE_STR_FW2_LOAD     "fw2_load"
 | 
						|
#define DEVICE_STR_IMAGE_TYPE   "img_type"
 | 
						|
#define DEVICE_STR_VENDOR_ID    "vendor_id"
 | 
						|
 | 
						|
#define IMAGE_STR               "[IMAGE_%02d]"
 | 
						|
//#define IMAGE_STR_PADENA       "pad_enable"
 | 
						|
//#define IMAGE_STR_PAD          "pad"
 | 
						|
#define IMAGE_STR_TYPE          "image_type"
 | 
						|
#define IMAGE_STR_VERSION       "version"
 | 
						|
#define IMAGE_STR_PATH          "path"
 | 
						|
#define IMAGE_STR_OFFSET        "offset"
 | 
						|
#define IMAGE_STR_LENGTH        "length"
 | 
						|
 | 
						|
int ah_GetConfig(char *pcfgName, ah_cfg *pcfg)
 | 
						|
{
 | 
						|
    FILE *fconfig;
 | 
						|
    char *pkey;
 | 
						|
    char imageName[64];
 | 
						|
    ah_cfg *cfg=pcfg;
 | 
						|
    int tmp0,tmp1,tmp2,tmp3,i;
 | 
						|
 | 
						|
    if(NULL == (fconfig=fopen(pcfgName, "r")))
 | 
						|
    {
 | 
						|
        printf("\r\n Can not open config: %s!\r\n", pcfgName);
 | 
						|
        return -1;
 | 
						|
    }
 | 
						|
 | 
						|
    if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_TYPE)))
 | 
						|
    {
 | 
						|
        cfg->device_type = ah_atoi(pkey);
 | 
						|
    }
 | 
						|
    else
 | 
						|
    {
 | 
						|
        printf("\r\n Can not find %s in %s !\r\n", DEVICE_STR_TYPE, DEVICE_STR);
 | 
						|
        return -1;
 | 
						|
    }
 | 
						|
 | 
						|
    if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_IMGNUM)))
 | 
						|
    {
 | 
						|
        cfg->image_num = ah_atoi(pkey);
 | 
						|
    }
 | 
						|
    else
 | 
						|
    {
 | 
						|
        printf("\r\n Can not find %s in %s !\r\n", DEVICE_STR_IMGNUM, DEVICE_STR);
 | 
						|
        return -1;
 | 
						|
    }
 | 
						|
 | 
						|
    if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_KEYWRD)))
 | 
						|
    {
 | 
						|
        if(strlen(pkey) <= KEYWRD_LENGTH)
 | 
						|
        {
 | 
						|
            strcpy(cfg->key_word, pkey);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Keywords over length: %s !\r\n", pkey);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
    }
 | 
						|
    else
 | 
						|
    {
 | 
						|
        printf("\r\n Can not find %s in %s !\r\n", DEVICE_STR_KEYWRD, DEVICE_STR);
 | 
						|
        return -1;
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_TOPHDRENA)))
 | 
						|
    {
 | 
						|
        cfg->top_header_enable = ah_atoi(pkey);
 | 
						|
    }
 | 
						|
    else
 | 
						|
    {
 | 
						|
        printf("\r\n Can not find %s in %s !\r\n", DEVICE_STR_TOPHDRENA, DEVICE_STR);
 | 
						|
        return -1;
 | 
						|
    }
 | 
						|
 | 
						|
    if(cfg->top_header_enable)
 | 
						|
    {
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_TOPHDRENC)))
 | 
						|
        {
 | 
						|
            cfg->encrypt_mode = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", DEVICE_STR_TOPHDRENC, DEVICE_STR);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_TOPHDRPTN)))
 | 
						|
        {
 | 
						|
            cfg->encrypt_pattern = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", DEVICE_STR_TOPHDRPTN, DEVICE_STR);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_TOPHDRVER)))
 | 
						|
        {
 | 
						|
            sscanf(pkey, "%d.%d.%d.%d", &tmp0, &tmp1, &tmp2, &tmp3);
 | 
						|
            cfg->version = ((tmp0&0x1F)<<27)|((tmp1&0x7F)<<20)|((tmp2&0xF)<<16)|(tmp3&0xFFFF);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", DEVICE_STR_TOPHDRVER, DEVICE_STR);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_IMAGE_SIZE)))
 | 
						|
        {
 | 
						|
            cfg->img_size = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_LAYOUT_INDEX)))
 | 
						|
        {
 | 
						|
            cfg->layout_index = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_PACKAGE_TYPE)))
 | 
						|
        {
 | 
						|
            cfg->package_type = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", DEVICE_STR_PACKAGE_TYPE, DEVICE_STR);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_MAGIC_NO)))
 | 
						|
        {
 | 
						|
            cfg->magic_no = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", DEVICE_STR_MAGIC_NO, DEVICE_STR);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_LZMA_TYPE)))
 | 
						|
        {
 | 
						|
            cfg->lzma_type = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        if (NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_FW2_LOAD)))
 | 
						|
        {
 | 
						|
            cfg->fw2_load = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        if (NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_IMAGE_TYPE)))
 | 
						|
        {
 | 
						|
            cfg->img_type = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, DEVICE_STR, DEVICE_STR_VENDOR_ID)))
 | 
						|
        {
 | 
						|
            cfg->vendor_id = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    for(i = 0; i < cfg->image_num; i++)
 | 
						|
    {
 | 
						|
        sprintf(imageName, IMAGE_STR, i+1);
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, imageName, IMAGE_STR_TYPE)))
 | 
						|
        {
 | 
						|
            cfg->image[i].image_type = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", IMAGE_STR_TYPE, imageName);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, imageName, IMAGE_STR_VERSION)))
 | 
						|
        {
 | 
						|
            sscanf(pkey, "%d.%d.%d", &tmp0, &tmp1, &tmp2);
 | 
						|
            cfg->image[i].version = ((tmp0&0xF)<<12)|((tmp1&0xF)<<8)|(tmp2&0xFF);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", IMAGE_STR_VERSION, imageName);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, imageName, IMAGE_STR_PATH)))
 | 
						|
        {
 | 
						|
            if(strlen(pkey) <= PATH_LENGTH)
 | 
						|
            {
 | 
						|
                strcpy(cfg->image[i].path, pkey);
 | 
						|
                strcpy(cfg->image[i].fwpath, pkey);
 | 
						|
                strcat(cfg->image[i].fwpath, ".fw");
 | 
						|
            }
 | 
						|
            else
 | 
						|
            {
 | 
						|
                printf("\r\n Path over length: %s !\r\n", pkey);
 | 
						|
                return -1;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", IMAGE_STR_PATH, imageName);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, imageName, IMAGE_STR_OFFSET)))
 | 
						|
        {
 | 
						|
            cfg->image[i].offset = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", IMAGE_STR_OFFSET, imageName);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, imageName, IMAGE_STR_LENGTH)))
 | 
						|
        {
 | 
						|
            cfg->image[i].length = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", IMAGE_STR_LENGTH, imageName);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
#if 0
 | 
						|
        if(NULL != (pkey = ah_GetKeyString(fconfig, imageName, IMAGE_STR_PADENA)))
 | 
						|
        {
 | 
						|
            cfg->image[i].pad_enable = ah_atoi(pkey);
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            printf("\r\n Can not find %s in %s !\r\n", IMAGE_STR_PADENA, DEVICE_STR);
 | 
						|
            return -1;
 | 
						|
        }
 | 
						|
 | 
						|
        if(cfg->image[i].pad_enable)
 | 
						|
        {
 | 
						|
            if(NULL != (pkey = ah_GetKeyString(fconfig, imageName, IMAGE_STR_PAD)))
 | 
						|
            {
 | 
						|
                cfg->image[i].pad = ah_atoi(pkey);
 | 
						|
            }
 | 
						|
            else
 | 
						|
            {
 | 
						|
                printf("\r\n Can not find %s in %s !\r\n", IMAGE_STR_PAD, DEVICE_STR);
 | 
						|
                return -1;
 | 
						|
            }
 | 
						|
        }
 | 
						|
#endif
 | 
						|
    }
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 | 
						|
 | 
						|
#define PACKAGE_HEADER_SIZE         96
 | 
						|
 | 
						|
int ah_funConstruct(char argc, char *argv[])
 | 
						|
{
 | 
						|
    FILE *fps = NULL, *fpd = NULL;
 | 
						|
    int cnt, _CRC, fileSize, crcSize, ret =RET_OK, i;
 | 
						|
    char pkName[256];
 | 
						|
    time_t rawtime;
 | 
						|
    struct tm *timeinfo;
 | 
						|
    ah_cfg cfg;
 | 
						|
    unsigned char sha[32];
 | 
						|
    struct stat st;
 | 
						|
    char *sh_argv[3];
 | 
						|
    char *p_buf = NULL;
 | 
						|
    char *p_saved_buf = NULL;
 | 
						|
    iot_pkg_hdr_t *hdr = NULL;
 | 
						|
    char *payload = NULL;
 | 
						|
    int pad_len = 0;
 | 
						|
    int len = 0;
 | 
						|
    int offset = 0;
 | 
						|
    int total_size = 0;
 | 
						|
    char *fw_buffer = NULL;
 | 
						|
    uint32_t fw_crc = 0;
 | 
						|
    uint32_t fw_size = 0;
 | 
						|
    char psram_size = sizeType_max;
 | 
						|
    char new_header_version = 0;
 | 
						|
    char *psram_str = NULL;
 | 
						|
 | 
						|
    if(argc < 3)
 | 
						|
    {
 | 
						|
        return RET_BAD_PARA;
 | 
						|
    }
 | 
						|
 | 
						|
    if (argc >= 4) {
 | 
						|
        psram_str = (char*)argv[3];
 | 
						|
        if ((psram_str[0] == 'p') || (psram_str[0] == 'P')) {
 | 
						|
            psram_size = atoi(++psram_str);
 | 
						|
        }
 | 
						|
        if ((psram_size == sizeType_0MB) || (psram_size == sizeType_2MB)
 | 
						|
        || (psram_size == sizeType_4MB) || (psram_size == sizeType_8MB)) {
 | 
						|
            new_header_version = 1;
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    memset(&cfg, 0x0, sizeof(ah_cfg));
 | 
						|
 | 
						|
    /* Get local time */
 | 
						|
    time ( &rawtime );
 | 
						|
    timeinfo = localtime ( &rawtime );
 | 
						|
 | 
						|
    /* Get information from input */
 | 
						|
    if(NULL == (global_buffer = (char*)malloc(PK_SINGLE_FILE_SIZE)))
 | 
						|
    {
 | 
						|
        ret = RET_ENV_FAILED;
 | 
						|
        goto ERROR_HANDLE;
 | 
						|
    }
 | 
						|
 | 
						|
    if(NULL == (fw_buffer = (char*)malloc(PK_SINGLE_FILE_SIZE)))
 | 
						|
    {
 | 
						|
        ret = RET_ENV_FAILED;
 | 
						|
        goto ERROR_HANDLE;
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    if(0 != ah_GetConfig(argv[2], &cfg))
 | 
						|
    {
 | 
						|
        ret = RET_ENV_FAILED;
 | 
						|
        goto ERROR_HANDLE;
 | 
						|
    }
 | 
						|
 | 
						|
    if(cfg.image_num>MAX_IMAGE_NUM || cfg.image_num<0)
 | 
						|
    {
 | 
						|
        printf(NEW_LINE"Invalid config file(%s)."NEW_LINE, argv[2]);
 | 
						|
        ret = RET_ENV_FAILED;
 | 
						|
        goto ERROR_HANDLE;
 | 
						|
    }
 | 
						|
 | 
						|
    /* make package name */
 | 
						|
    sprintf(pkName, "./%s%04d%02d%02d.bin", cfg.key_word,\
 | 
						|
            timeinfo->tm_year+1900, timeinfo->tm_mon+1, timeinfo->tm_mday);
 | 
						|
 | 
						|
    memset(global_buffer, 0x0, PK_SINGLE_FILE_SIZE);
 | 
						|
 | 
						|
    if(cfg.top_header_enable)
 | 
						|
    {
 | 
						|
        /*image header*/
 | 
						|
        hdr = (iot_pkg_hdr_t*)global_buffer;
 | 
						|
        hdr->enctype = cfg.encrypt_mode;
 | 
						|
        hdr->pattern = cfg.encrypt_pattern;
 | 
						|
        hdr->dev_type = htons(cfg.package_type);
 | 
						|
        hdr->magic_no = htonl(cfg.magic_no);
 | 
						|
        hdr->version = htonl(cfg.version);
 | 
						|
        hdr->vendor_id = htons(cfg.vendor_id);
 | 
						|
        hdr->img_flag = (cfg.img_size) << 4 | (cfg.lzma_type)<< 2 | (cfg.fw2_load)<< 3;
 | 
						|
        hdr->img_type = cfg.img_type;
 | 
						|
 | 
						|
        /*image payload*/
 | 
						|
        payload = global_buffer + sizeof(iot_pkg_hdr_t);
 | 
						|
    }
 | 
						|
    else
 | 
						|
    {
 | 
						|
        /*image payload*/
 | 
						|
        payload = global_buffer;
 | 
						|
    }
 | 
						|
 | 
						|
    p_buf = payload;
 | 
						|
 | 
						|
    /* 2400 aligned */
 | 
						|
    if((cfg.image_num > 0) &&
 | 
						|
            ((cfg.image[0].image_type == imgCFG)
 | 
						|
            ||(cfg.image[0].image_type == imgFRW)
 | 
						|
            ||(cfg.image[0].image_type == imgCFRW)
 | 
						|
            ||(cfg.image[0].image_type == imgCFRW1)
 | 
						|
            ||(cfg.image[0].image_type == imgCFRW4F)
 | 
						|
            ||(cfg.image[0].image_type == imgCFRW4P)))
 | 
						|
    {
 | 
						|
            len = p_buf - global_buffer;
 | 
						|
            if(len%2400)
 | 
						|
            {
 | 
						|
                len = 2400 - (len%2400);
 | 
						|
                for(i=0; i<len; i++)
 | 
						|
                {
 | 
						|
                    *p_buf = 0;
 | 
						|
                    p_buf++;
 | 
						|
                }
 | 
						|
                total_size += len;
 | 
						|
            }
 | 
						|
    }
 | 
						|
    //printf(NEW_LINE"pkName :%s"NEW_LINE, pkName);
 | 
						|
    for(cnt = 0; cnt < cfg.image_num; cnt++)
 | 
						|
    {
 | 
						|
        if((0 != stat(cfg.image[cnt].path, &st))
 | 
						|
            ||(NULL == (fps=fopen(cfg.image[cnt].path, "r"))))
 | 
						|
        {
 | 
						|
            printf(NEW_LINE"Cannot open image file(%s)."NEW_LINE, cfg.image[cnt].path);
 | 
						|
            ret = RET_ENV_FAILED;
 | 
						|
            goto ERROR_HANDLE;
 | 
						|
        }
 | 
						|
        fw_size = 0;
 | 
						|
 | 
						|
        /* Get file size */
 | 
						|
        fseek(fps, 0, SEEK_END);
 | 
						|
        fileSize = ftell(fps);
 | 
						|
        fseek(fps, 0, SEEK_SET);
 | 
						|
 | 
						|
        /* Read file into buffer */
 | 
						|
        fread(p_buf + imgHeaderSize, 1, fileSize, fps);
 | 
						|
        fclose(fps);
 | 
						|
        fps = NULL;
 | 
						|
 | 
						|
        memset(p_buf, 0x0, imgHeaderSize);
 | 
						|
        p_saved_buf = p_buf;
 | 
						|
 | 
						|
        if((cfg.image[cnt].image_type == imgSBL)
 | 
						|
            ||(cfg.image[cnt].image_type == imgOEM)
 | 
						|
            ||(cfg.image[cnt].image_type == imgCFG))
 | 
						|
        {
 | 
						|
            //printf(NEW_LINE"    add size :%d"NEW_LINE, fileSize);
 | 
						|
            if(cfg.image[cnt].length%IMAGE_ALIGNED_SIZE)
 | 
						|
            {
 | 
						|
                printf(NEW_LINE"Image space length invalid(0x%x)."NEW_LINE, cfg.image[cnt].length);
 | 
						|
            }
 | 
						|
            if(cfg.image[cnt].length - imgHeaderSize < fileSize)
 | 
						|
            {
 | 
						|
                printf(NEW_LINE"Image oversize(%s, size:%d, limited:%d)."NEW_LINE,
 | 
						|
                    cfg.image[cnt].path, fileSize, cfg.image[cnt].length - imgHeaderSize);
 | 
						|
                ret = RET_IMAGE_WRONG;
 | 
						|
                goto ERROR_HANDLE;
 | 
						|
            }
 | 
						|
            crcSize = cfg.image[cnt].length - imgHeaderSize;
 | 
						|
            pad_len = crcSize - fileSize;
 | 
						|
            memset(p_buf + fileSize + imgHeaderSize, 0x0, pad_len);
 | 
						|
            fileSize = crcSize;
 | 
						|
        }
 | 
						|
        else
 | 
						|
        {
 | 
						|
            pad_len = 0;
 | 
						|
            crcSize = IMAGE_LEN_FOR_CRC(fileSize);
 | 
						|
            /* Clear pad bytes to '0' */
 | 
						|
            memset(p_buf + imgHeaderSize + fileSize, 0x0, crcSize - fileSize);
 | 
						|
        }
 | 
						|
 | 
						|
        if((crcSize+imgHeaderSize)>cfg.image[cnt].length
 | 
						|
            || (crcSize+imgHeaderSize) > PK_SINGLE_FILE_SIZE)
 | 
						|
        {
 | 
						|
            printf(NEW_LINE"Image oversize(%s, size:%d, limited:%d)."NEW_LINE,
 | 
						|
                cfg.image[cnt].path, crcSize, cfg.image[cnt].length - imgHeaderSize);
 | 
						|
            ret = RET_IMAGE_WRONG;
 | 
						|
            goto ERROR_HANDLE;
 | 
						|
        }
 | 
						|
 | 
						|
        /* for CRC */
 | 
						|
        _CRC= 0xFFFFFFFF^CRC32_Update(0xFFFFFFFF, p_buf + imgHeaderSize, crcSize);
 | 
						|
 | 
						|
        ah_Sha256((unsigned char*)(p_buf + imgHeaderSize), fileSize, sha);
 | 
						|
 | 
						|
        if ((cfg.image[cnt].image_type == imgCFRW)
 | 
						|
               ||(cfg.image[cnt].image_type == imgCFRW1)
 | 
						|
               ||(cfg.image[cnt].image_type == imgCFRW4F)
 | 
						|
               ||(cfg.image[cnt].image_type == imgCFRW4P)){
 | 
						|
 | 
						|
            if((0 == stat(cfg.image[cnt].fwpath, &st))
 | 
						|
                &&(NULL != (fps=fopen(cfg.image[cnt].fwpath, "r")))){
 | 
						|
                /* Get file size */
 | 
						|
                fseek(fps, 0, SEEK_END);
 | 
						|
                fw_size = ftell(fps);
 | 
						|
                fseek(fps, 0, SEEK_SET);
 | 
						|
 | 
						|
                /* Read file into buffer */
 | 
						|
                fread(fw_buffer, 1, fw_size, fps);
 | 
						|
                fclose(fps);
 | 
						|
                fps = NULL;
 | 
						|
 | 
						|
                fw_crc = 0xFFFFFFFF^CRC32_Update(0xFFFFFFFF, fw_buffer, fw_size);
 | 
						|
            }
 | 
						|
 | 
						|
        }
 | 
						|
 | 
						|
        /* Fill header structure */
 | 
						|
        /* device type */
 | 
						|
        p_buf[0] = (char)GET_BYTE2(cfg.device_type);
 | 
						|
        p_buf[1] = (char)GET_BYTE1(cfg.device_type);
 | 
						|
        /* image type */
 | 
						|
        p_buf[2] = (char)GET_BYTE2(cfg.image[cnt].image_type);
 | 
						|
        p_buf[3] = (char)GET_BYTE1(cfg.image[cnt].image_type);
 | 
						|
        /* image size */
 | 
						|
        p_buf[4] = (char)GET_BYTE4(fileSize);
 | 
						|
        p_buf[5] = (char)GET_BYTE3(fileSize);
 | 
						|
        p_buf[6] = (char)GET_BYTE2(fileSize);
 | 
						|
        p_buf[7] = (char)GET_BYTE1(fileSize);
 | 
						|
        /* image version */
 | 
						|
        p_buf[8] = (char)GET_BYTE2(cfg.image[cnt].version);
 | 
						|
        p_buf[9] = (char)GET_BYTE1(cfg.image[cnt].version);
 | 
						|
 | 
						|
        if (new_header_version) {
 | 
						|
            /* psram size */
 | 
						|
            p_buf[10] = psram_size;
 | 
						|
            /* hdr version */
 | 
						|
            p_buf[11] = hdrVer_02;
 | 
						|
        } else {
 | 
						|
            /* psram size */
 | 
						|
            p_buf[10] = 0;
 | 
						|
            /* hdr version */
 | 
						|
            p_buf[11] = 0;
 | 
						|
        }
 | 
						|
 | 
						|
        /* FW SZIE */
 | 
						|
        p_buf[12] = (char)GET_BYTE4(fw_size);
 | 
						|
        p_buf[13] = (char)GET_BYTE3(fw_size);
 | 
						|
        p_buf[14] = (char)GET_BYTE2(fw_size);
 | 
						|
        p_buf[15] = (char)GET_BYTE1(fw_size);
 | 
						|
 | 
						|
        /* CRC */
 | 
						|
        p_buf[16] = (char)GET_BYTE4(_CRC);
 | 
						|
        p_buf[17] = (char)GET_BYTE3(_CRC);
 | 
						|
        p_buf[18] = (char)GET_BYTE2(_CRC);
 | 
						|
        p_buf[19] = (char)GET_BYTE1(_CRC);
 | 
						|
 | 
						|
        /* Guard */
 | 
						|
        p_buf[20] = (char)GET_BYTE4(IMAGE_GUARD);
 | 
						|
        p_buf[21] = (char)GET_BYTE3(IMAGE_GUARD);
 | 
						|
        p_buf[22] = (char)GET_BYTE2(IMAGE_GUARD);
 | 
						|
        p_buf[23] = (char)GET_BYTE1(IMAGE_GUARD);
 | 
						|
 | 
						|
        /* flash layout index */
 | 
						|
        p_buf[24] = cfg.layout_index;
 | 
						|
 | 
						|
        /* reserved, default 0 */
 | 
						|
        p_buf[25] = 0;
 | 
						|
        p_buf[26] = 0;
 | 
						|
        p_buf[27] = 0;
 | 
						|
 | 
						|
        p_buf[28] = (char)GET_BYTE4(fw_crc);
 | 
						|
        p_buf[29] = (char)GET_BYTE3(fw_crc);
 | 
						|
        p_buf[30] = (char)GET_BYTE2(fw_crc);
 | 
						|
        p_buf[31] = (char)GET_BYTE1(fw_crc);
 | 
						|
 | 
						|
        /* SHA256 */
 | 
						|
        for(i=32; i<64; i++)
 | 
						|
        {
 | 
						|
            p_buf[i] = sha[i-32];
 | 
						|
        }
 | 
						|
        /* write image */
 | 
						|
        len = crcSize + imgHeaderSize;
 | 
						|
 | 
						|
        /*update buffer pointer*/
 | 
						|
        p_buf += len;
 | 
						|
 | 
						|
        /*new bin file's size*/
 | 
						|
        len = p_buf - p_saved_buf;
 | 
						|
        total_size += len;
 | 
						|
 | 
						|
        if(cfg.top_header_enable)
 | 
						|
        {
 | 
						|
            /*update image header*/
 | 
						|
            offset = p_saved_buf - global_buffer;
 | 
						|
            if(cfg.image[cnt].image_type == imgSP)
 | 
						|
            {
 | 
						|
                hdr->sp_start = htonl(offset);
 | 
						|
                hdr->sp_len = htonl(crcSize+imgHeaderSize);
 | 
						|
            }
 | 
						|
            if(cfg.image[cnt].image_type == imgSBL)
 | 
						|
            {
 | 
						|
                hdr->sbl_start = htonl(offset);
 | 
						|
                hdr->sbl_len = htonl(crcSize+imgHeaderSize);
 | 
						|
            }
 | 
						|
            if(cfg.image[cnt].image_type == imgOEM)
 | 
						|
            {
 | 
						|
                hdr->oem_start = htonl(offset);
 | 
						|
                hdr->oem_len = htonl(crcSize+imgHeaderSize);
 | 
						|
            }
 | 
						|
            if(cfg.image[cnt].image_type == imgCFG)
 | 
						|
            {
 | 
						|
                hdr->pib_start = htonl(offset);
 | 
						|
                hdr->pib_len = htonl(crcSize+imgHeaderSize);
 | 
						|
            }
 | 
						|
 | 
						|
            if((cfg.image[cnt].image_type == imgFRW)
 | 
						|
               ||(cfg.image[cnt].image_type == imgCFRW)
 | 
						|
               ||(cfg.image[cnt].image_type == imgCFRW1)
 | 
						|
               ||(cfg.image[cnt].image_type == imgCFRW4F)
 | 
						|
               ||(cfg.image[cnt].image_type == imgCFRW4P))
 | 
						|
            {
 | 
						|
                static uint8_t fw_packed = 0;
 | 
						|
                if(!fw_packed){
 | 
						|
                    hdr->fw_start = htonl(offset);
 | 
						|
                    hdr->fw_len = htonl(crcSize+imgHeaderSize);
 | 
						|
                    fw_packed = 1;
 | 
						|
                }else {
 | 
						|
                    hdr->fw2_start = htonl(offset);
 | 
						|
                    hdr->fw2_len = htonl(crcSize+imgHeaderSize);
 | 
						|
               }
 | 
						|
            }
 | 
						|
 | 
						|
            if (cfg.image[cnt].image_type == imgFRW2) {
 | 
						|
                if (cfg.fw2_load) {
 | 
						|
                    // fw2 load enable
 | 
						|
                    hdr->fw2_start = htonl(offset);
 | 
						|
                    hdr->fw2_len = htonl(crcSize + imgHeaderSize);
 | 
						|
                }
 | 
						|
            }
 | 
						|
 | 
						|
            if(cfg.image[cnt].image_type == imgEFUSE)
 | 
						|
            {
 | 
						|
                hdr->efuse_start = htonl(offset);
 | 
						|
                hdr->efuse_len = htonl(crcSize+imgHeaderSize);
 | 
						|
            }
 | 
						|
            /* pack reference info */
 | 
						|
            if (cfg.image[cnt].image_type == imgREF)
 | 
						|
            {
 | 
						|
                hdr->ref_start = htonl(offset);
 | 
						|
                hdr->ref_len = htonl(crcSize+imgHeaderSize);
 | 
						|
            }
 | 
						|
            /* pack custom info */
 | 
						|
            if (cfg.image[cnt].image_type == imgCUS)
 | 
						|
            {
 | 
						|
                hdr->cus_start = htonl(offset);
 | 
						|
                hdr->cus_len = htonl(crcSize+imgHeaderSize);
 | 
						|
            }
 | 
						|
        }
 | 
						|
 | 
						|
         /* 2400 aligned */
 | 
						|
        if((cnt+1 < cfg.image_num)
 | 
						|
            &&((cfg.image[cnt+1].image_type == imgCFG)
 | 
						|
            ||(cfg.image[cnt+1].image_type == imgFRW)
 | 
						|
            ||(cfg.image[cnt+1].image_type == imgCFRW)
 | 
						|
            ||(cfg.image[cnt+1].image_type == imgCFRW1)
 | 
						|
            ||(cfg.image[cnt+1].image_type == imgCFRW4F)
 | 
						|
            ||(cfg.image[cnt+1].image_type == imgCFRW4P)))
 | 
						|
        {
 | 
						|
            len = p_buf - global_buffer;
 | 
						|
            if(len%2400)
 | 
						|
            {
 | 
						|
                len = 2400 - (len%2400);
 | 
						|
                for(i=0; i<len; i++)
 | 
						|
                {
 | 
						|
                    *p_buf = 0;
 | 
						|
                    p_buf++;
 | 
						|
                }
 | 
						|
                total_size += len;
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    if(cfg.top_header_enable)
 | 
						|
    {
 | 
						|
        char *st = NULL;
 | 
						|
        char *end = NULL;
 | 
						|
        uint8_t ptn  = 0;
 | 
						|
 | 
						|
        hdr->file_len = htonl(total_size);
 | 
						|
 | 
						|
        /*calculate payload's CRC*/
 | 
						|
        cfg.crc = 0xFFFFFFFF^CRC32_Update(0xFFFFFFFF, payload , total_size);
 | 
						|
        hdr->file_crc = htonl(cfg.crc);
 | 
						|
 | 
						|
        if(1 == cfg.encrypt_mode)
 | 
						|
        {
 | 
						|
            st = payload;
 | 
						|
            end = payload + total_size;
 | 
						|
            ptn = (cfg.encrypt_pattern&0xFF);
 | 
						|
            while(st <= end){
 | 
						|
                *(st) += ptn;
 | 
						|
                st++;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        else if(2 == cfg.encrypt_mode)
 | 
						|
        {
 | 
						|
            st = payload;
 | 
						|
            end = payload + total_size;
 | 
						|
            ptn = (cfg.encrypt_pattern&0xFF);
 | 
						|
            while(st <= end){
 | 
						|
                *(st) -= ptn;
 | 
						|
                st++;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        else if(3 == cfg.encrypt_mode)
 | 
						|
        {
 | 
						|
            st = global_buffer;
 | 
						|
            end = payload + total_size;
 | 
						|
            ptn = (cfg.encrypt_pattern&0xFF);
 | 
						|
            while(st <= end) {
 | 
						|
                *(st) ^= ptn;
 | 
						|
                st++;
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /*write buffer into file*/
 | 
						|
    if(NULL == (fpd=fopen(pkName, "w+")))
 | 
						|
    {
 | 
						|
        printf(NEW_LINE"Cannot open package file(%s)."NEW_LINE, pkName);
 | 
						|
        goto ERROR_HANDLE;
 | 
						|
    }
 | 
						|
    if(cfg.top_header_enable)
 | 
						|
    {
 | 
						|
        fwrite(global_buffer, 1, total_size + PACKAGE_HEADER_SIZE, fpd);
 | 
						|
    }
 | 
						|
    else
 | 
						|
    {
 | 
						|
        fwrite(global_buffer, 1, total_size, fpd);
 | 
						|
    }
 | 
						|
    fclose(fpd);
 | 
						|
    fpd = NULL;
 | 
						|
 | 
						|
    /* show info */
 | 
						|
    sh_argv[2] = pkName;
 | 
						|
    ah_funShowHeader(3, sh_argv);
 | 
						|
    printf(NEW_LINE"Package created - %s"NEW_LINE, pkName);
 | 
						|
    ret = RET_OK;
 | 
						|
 | 
						|
ERROR_HANDLE:
 | 
						|
 | 
						|
    if(global_buffer)
 | 
						|
    {
 | 
						|
        free(global_buffer);
 | 
						|
        global_buffer = NULL;
 | 
						|
    }
 | 
						|
    if(fpd)
 | 
						|
    {
 | 
						|
        fclose(fpd);
 | 
						|
        if(RET_OK != ret)
 | 
						|
            remove(pkName);
 | 
						|
        fpd = NULL;
 | 
						|
    }
 | 
						|
    if(fps)
 | 
						|
    {
 | 
						|
        fclose(fps);
 | 
						|
        fps = NULL;
 | 
						|
 | 
						|
    }
 | 
						|
    return ret;
 | 
						|
}
 | 
						|
 | 
						|
int ah_funShowHeader(char argc, char *argv[])
 | 
						|
{
 | 
						|
    FILE *fps = NULL;
 | 
						|
    char pbuf[imgHeaderSize];
 | 
						|
    int imgNo=0, tmp1, tmp2, tmp3, offset, start, device;
 | 
						|
 | 
						|
    if(argc < 3)
 | 
						|
    {
 | 
						|
        return RET_BAD_PARA;
 | 
						|
    }
 | 
						|
 | 
						|
    if(NULL == (fps=fopen(argv[2], "r")))
 | 
						|
    {
 | 
						|
        printf(NEW_LINE"Cannot open package file(%s)."NEW_LINE, argv[2]);
 | 
						|
        return RET_BAD_PARA;
 | 
						|
    }
 | 
						|
 | 
						|
    do
 | 
						|
    {
 | 
						|
        imgNo++;
 | 
						|
 | 
						|
        while(32 == (tmp1 = fread(pbuf, 1, 32, fps)))
 | 
						|
        {
 | 
						|
            if(1==imgNo)
 | 
						|
            {
 | 
						|
                tmp3 = IMGHDR_GET_GUARD(pbuf);
 | 
						|
                if(tmp3 == (((int)IMAGE_GUARD)&0xFFFFFFFF))
 | 
						|
                {
 | 
						|
                    device = IMGHDR_GET_DEVTYPE(pbuf);
 | 
						|
                    if((((int)devKunlun)&0xFFFF) == device)
 | 
						|
                    {
 | 
						|
                        break;
 | 
						|
                    }
 | 
						|
                }
 | 
						|
            }
 | 
						|
            else
 | 
						|
            {
 | 
						|
                tmp2 = IMGHDR_GET_DEVTYPE(pbuf);
 | 
						|
                tmp3 = IMGHDR_GET_GUARD(pbuf);
 | 
						|
 | 
						|
                if((tmp2 == device)
 | 
						|
                    &&(tmp3 == (((int)IMAGE_GUARD)&0xFFFFFFFF)))
 | 
						|
                    break;
 | 
						|
            }
 | 
						|
        }
 | 
						|
        if(32 != tmp1)
 | 
						|
        {
 | 
						|
            fclose(fps);
 | 
						|
            return RET_OK;
 | 
						|
        }
 | 
						|
        tmp1 = fread(pbuf+32, 1, 32, fps);
 | 
						|
        if(32 != tmp1)
 | 
						|
        {
 | 
						|
            fclose(fps);
 | 
						|
            printf(NEW_LINE"Maybe the package is damaged."NEW_LINE NEW_LINE);
 | 
						|
            return RET_OK;
 | 
						|
        }
 | 
						|
 | 
						|
        /* Print headers */
 | 
						|
        start = ftell(fps) - imgHeaderSize;
 | 
						|
        printf(NEW_LINE"Image NO.%02d @ 0x%08x:", imgNo, start);
 | 
						|
 | 
						|
        tmp1 = IMGHDR_GET_DEVTYPE(pbuf);
 | 
						|
        printf(NEW_LINE"    device:0x%04x", tmp1&0xFFFF);
 | 
						|
 | 
						|
        tmp1 = IMGHDR_GET_IMGTYPE(pbuf);
 | 
						|
        printf(NEW_LINE"    image:0x%04x", tmp1&0xFFFF);
 | 
						|
 | 
						|
        tmp1 =  IMGHDR_GET_IMGSIZE(pbuf);
 | 
						|
        offset =  IMAGE_LEN_FOR_CRC(tmp1);
 | 
						|
        printf(NEW_LINE"    size:%d Bytes", tmp1);
 | 
						|
 | 
						|
        tmp1 = IMGHDR_GET_IMGVER(pbuf);
 | 
						|
        printf(NEW_LINE"     version:%d.%d.%d", (tmp1>>12)&0xF,
 | 
						|
            (tmp1>>8)&0xF, tmp1&0xFF);
 | 
						|
 | 
						|
        tmp1 = IMGHDR_GET_PSRAMSIZE(pbuf);
 | 
						|
        printf(NEW_LINE"    psram size:%dM", tmp1);
 | 
						|
 | 
						|
        tmp1 = IMGHDR_GET_HDRVER(pbuf);
 | 
						|
        printf(NEW_LINE"    hdr version:0x%02X", tmp1&0xFF);
 | 
						|
 | 
						|
        tmp1 = IMGHDR_GET_FWSIZE(pbuf);
 | 
						|
        printf(NEW_LINE"    FW Size:0x%08x", tmp1);
 | 
						|
 | 
						|
        tmp1 = IMGHDR_GET_LAYOUTIDX(pbuf);
 | 
						|
        printf(NEW_LINE"    flash layout index:0x%02x", tmp1);
 | 
						|
 | 
						|
        tmp1 = IMGHDR_GET_CRC(pbuf);
 | 
						|
        printf(NEW_LINE"    CRC:0x%08x", tmp1);
 | 
						|
 | 
						|
        tmp1 = IMGHDR_GET_FWCRC(pbuf);
 | 
						|
        printf(NEW_LINE"    FW CRC:0x%08x", tmp1);
 | 
						|
 | 
						|
        printf(NEW_LINE"    SHA256:");
 | 
						|
        for(tmp1 = 32; tmp1 < 64; tmp1++)
 | 
						|
        {
 | 
						|
            tmp2 = ((int)pbuf[tmp1])&0xFF;
 | 
						|
            printf("%02x", tmp2);
 | 
						|
        }
 | 
						|
        printf(NEW_LINE);
 | 
						|
        /* skip size */
 | 
						|
        if(fseek(fps, offset, SEEK_CUR))
 | 
						|
        {
 | 
						|
            fclose(fps);
 | 
						|
            return RET_OK;
 | 
						|
        }
 | 
						|
 | 
						|
    }while(1);
 | 
						|
 | 
						|
    return RET_OK;
 | 
						|
}
 | 
						|
 | 
						|
int main(int argc, char *argv[])
 | 
						|
{
 | 
						|
    int ret = RET_BAD_PARA;
 | 
						|
 | 
						|
    if(argc <= 1)
 | 
						|
    {
 | 
						|
        ah_help();
 | 
						|
        goto err_out;
 | 
						|
    }
 | 
						|
 | 
						|
    if(0 == strcmp(FUNC_CONSTRUCT, argv[1]))
 | 
						|
    {
 | 
						|
        ret =ah_funConstruct(argc, argv);
 | 
						|
    }
 | 
						|
    else if(0 == strcmp(FUNC_SHOWHEADER, argv[1]))
 | 
						|
    {
 | 
						|
        ret =ah_funShowHeader(argc, argv);
 | 
						|
    }
 | 
						|
 | 
						|
    if(RET_OK == ret)
 | 
						|
    {
 | 
						|
        return 0;
 | 
						|
    }
 | 
						|
 | 
						|
err_out:
 | 
						|
    printf(NEW_LINE"Something wrong !"NEW_LINE NEW_LINE);
 | 
						|
    return ret;
 | 
						|
}
 |