TERES/SOFTWARE/A64-TERES/sunxi-pack-tools/update_boot0/script.c
2017-11-06 19:58:26 +02:00

392 lines
10 KiB
C
Executable File
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
**********************************************************************************************************************
* eGon
* the Embedded System
* script parser sub-system
*
* Copyright(C), 2006-2010, SoftWinners Microelectronic Co., Ltd.
* All Rights Reserved
*
* File : script.c
*
* By : Jerry
*
* Version : V2.00
*
* Date :
*
* Descript:
**********************************************************************************************************************
*/
#include "script.h"
#include "string.h"
__asm__(".symver memcpy ,memcpy@GLIBC_2.2.5");
static char *script_mod_buf = NULL; //指向第一个主键
static int script_main_key_count = 0; //保存主键的个数
static int _test_str_length(char *str)
{
int length = 0;
while(str[length++])
{
if(length > 32)
{
length = 32;
break;
}
}
return length;
}
/*
************************************************************************************************************
*
* script_parser_init
*
* 函数名称:
*
* 参数列表script_buf: 脚本数据池
*
* 返回值
*
* 说明
*
*
************************************************************************************************************
*/
int script_parser_init(char *script_buf)
{
script_head_t *script_head;
if(script_buf)
{
script_mod_buf = script_buf;
script_head = (script_head_t *)script_mod_buf;
script_main_key_count = script_head->main_key_count;
return SCRIPT_PARSER_OK;
}
else
{
return SCRIPT_PARSER_EMPTY_BUFFER;
}
}
/*
************************************************************************************************************
*
* script_parser_exit
*
* 函数名称:
*
* 参数列表NULL
*
* 返回值
*
* 说明
*
*
************************************************************************************************************
*/
int script_parser_exit(void)
{
script_mod_buf = NULL;
script_main_key_count = 0;
return SCRIPT_PARSER_OK;
}
/*
************************************************************************************************************
*
* script_parser_fetch
*
* 函数名称:
*
* 参数列表:
*
* 返回值
*
* 说明 :根据传进的主键,子键,取得对应的数值
*
*
************************************************************************************************************
*/
int script_parser_sunkey_all(char *main_name, void *buffer)
{
char main_char[32], sub_char[32];
script_main_key_t *main_key;
script_sub_key_t *sub_key;
int i, j;
int pattern, word_count;
script_gpio_set_t *user_gpio_cfg;
unsigned int *data;
//检查脚本buffer是否存在
if(!script_mod_buf)
{
return SCRIPT_PARSER_EMPTY_BUFFER;
}
//检查主键名称和子键名称是否为空
if(main_name == NULL)
{
return SCRIPT_PARSER_KEYNAME_NULL;
}
//检查数据buffer是否为空
if(buffer == NULL)
{
return SCRIPT_PARSER_DATA_VALUE_NULL;
}
//保存主键名称和子键名称如果超过16字节则截取16字节
memset(main_char, 0, sizeof(main_char));
memset(sub_char, 0, sizeof(sub_char));
if(_test_str_length(main_name) <= 32)
{
strcpy(main_char, main_name);
}
else
{
strncpy(main_char, main_name, 31);
}
data = (unsigned int *)buffer;
for(i=0;i<script_main_key_count;i++)
{
main_key = (script_main_key_t *)(script_mod_buf + (sizeof(script_head_t)) + i * sizeof(script_main_key_t));
if(strcmp(main_key->main_name, main_char)) //如果主键不匹配,寻找下一个主键
{
continue;
}
//printf("find main key named %s\n", main_char);
//主键匹配,寻找子键名称匹配
for(j=0;j<main_key->lenth;j++)
{
sub_key = (script_sub_key_t *)(script_mod_buf + (main_key->offset<<2) + (j * sizeof(script_sub_key_t)));
// if(strcmp(sub_key->sub_name, sub_char)) //如果主键不匹配,寻找下一个主键
// {
// continue;
// }
//printf("index %d name : %s value = ", j, sub_key->sub_name);
pattern = (sub_key->pattern>>16) & 0xffff; //获取数据的类型
word_count = (sub_key->pattern>> 0) & 0xffff; //获取所占用的word个数
//取出数据
switch(pattern)
{
case DATA_TYPE_SINGLE_WORD: //单word数据类型
*data = *(int *)(script_mod_buf + (sub_key->offset<<2));
//printf("%d\n", *data);
data ++;
continue;
case DATA_TYPE_STRING: //字符串数据类型
memcpy((char *)data, script_mod_buf + (sub_key->offset<<2), word_count << 2);
data += word_count;
continue;
case DATA_TYPE_GPIO_WORD: //多word数据类型
user_gpio_cfg = (script_gpio_set_t *)data;
//发现是GPIO类型检查是否足够存放用户数据
strcpy( user_gpio_cfg->gpio_name, sub_char);
memcpy(&user_gpio_cfg->port, script_mod_buf + (sub_key->offset<<2), sizeof(script_gpio_set_t) - 32);
data += (sizeof(script_gpio_set_t) - 32)/4;
continue;
}
}
return SCRIPT_PARSER_OK;
}
return SCRIPT_PARSER_KEY_NOT_FIND;
}
/*
************************************************************************************************************
*
* script_parser_fetch
*
* 函数名称:
*
* 参数列表:
*
* 返回值
*
* 说明 :根据传进的主键,子键,取得对应的数值
*
*
************************************************************************************************************
*/
int script_parser_fetch(char *main_name, char *sub_name, int value[])
{
char main_char[32], sub_char[32];
script_main_key_t *main_key;
script_sub_key_t *sub_key;
int i, j;
int pattern, word_count;
script_gpio_set_t *user_gpio_cfg;
//检查脚本buffer是否存在
if(!script_mod_buf)
{
return SCRIPT_PARSER_EMPTY_BUFFER;
}
//检查主键名称和子键名称是否为空
if((main_name == NULL) || (sub_name == NULL))
{
return SCRIPT_PARSER_KEYNAME_NULL;
}
//检查数据buffer是否为空
if(value == NULL)
{
return SCRIPT_PARSER_DATA_VALUE_NULL;
}
//保存主键名称和子键名称如果超过16字节则截取16字节
memset(main_char, 0, sizeof(main_char));
memset(sub_char, 0, sizeof(sub_char));
if(_test_str_length(main_name) <= 32)
{
strcpy(main_char, main_name);
}
else
{
strncpy(main_char, main_name, 31);
}
if(_test_str_length(sub_name) <= 32)
{
strcpy(sub_char, sub_name);
}
else
{
strncpy(sub_char, sub_name, 31);
}
for(i=0;i<script_main_key_count;i++)
{
main_key = (script_main_key_t *)(script_mod_buf + (sizeof(script_head_t)) + i * sizeof(script_main_key_t));
if(strcmp(main_key->main_name, main_char)) //如果主键不匹配,寻找下一个主键
{
continue;
}
//主键匹配,寻找子键名称匹配
for(j=0;j<main_key->lenth;j++)
{
sub_key = (script_sub_key_t *)(script_mod_buf + (main_key->offset<<2) + (j * sizeof(script_sub_key_t)));
if(strcmp(sub_key->sub_name, sub_char)) //如果主键不匹配,寻找下一个主键
{
continue;
}
pattern = (sub_key->pattern>>16) & 0xffff; //获取数据的类型
word_count = (sub_key->pattern>> 0) & 0xffff; //获取所占用的word个数
//取出数据
switch(pattern)
{
case DATA_TYPE_SINGLE_WORD: //单word数据类型
value[0] = *(int *)(script_mod_buf + (sub_key->offset<<2));
break;
case DATA_TYPE_STRING: //字符串数据类型
memcpy((char *)value, script_mod_buf + (sub_key->offset<<2), word_count << 2);
break;
case DATA_TYPE_GPIO_WORD: //多word数据类型
user_gpio_cfg = (script_gpio_set_t *)value;
//发现是GPIO类型检查是否足够存放用户数据
strcpy( user_gpio_cfg->gpio_name, sub_char);
memcpy(&user_gpio_cfg->port, script_mod_buf + (sub_key->offset<<2), sizeof(script_gpio_set_t) - 32);
break;
}
return SCRIPT_PARSER_OK;
}
}
return SCRIPT_PARSER_KEY_NOT_FIND;
}
/*
************************************************************************************************************
*
* script_parser_mainkey_get_gpio_cfg
*
* 函数名称:
*
* 参数列表:
*
* 返回值
*
* 说明 根据传进的主键取得主键下GPIO的配置信息
*
*
************************************************************************************************************
*/
int script_parser_mainkey_get_gpio_cfg(char *main_name, void *gpio_cfg, int gpio_count)
{
char main_bkname[32];
char *main_char;
script_main_key_t *main_key = NULL;
script_sub_key_t *sub_key = NULL;
script_gpio_set_t *user_gpio_cfg = (script_gpio_set_t *)gpio_cfg;
int i, j;
int pattern, user_index;
//检查脚本buffer是否存在
if(!script_mod_buf)
{
return SCRIPT_PARSER_EMPTY_BUFFER;
}
//检查主键名称和子键名称是否为空
if(main_name == NULL)
{
return SCRIPT_PARSER_KEYNAME_NULL;
}
//首先清空用户buffer
memset(user_gpio_cfg, 0, sizeof(script_gpio_set_t) * gpio_count);
//保存主键名称和子键名称如果超过31字节则截取31字节
main_char = main_name;
if(_test_str_length(main_name) > 31)
{
memset(main_bkname, 0, 32);
strncpy(main_bkname, main_name, 31);
main_char = main_bkname;
}
for(i=0;i<script_main_key_count;i++)
{
main_key = (script_main_key_t *)(script_mod_buf + (sizeof(script_head_t)) + i * sizeof(script_main_key_t));
if(strcmp(main_key->main_name, main_char)) //如果主键不匹配,寻找下一个主键
{
continue;
}
//主键匹配,寻找子键名称匹配
user_index = 0;
for(j=0;j<main_key->lenth;j++)
{
sub_key = (script_sub_key_t *)(script_mod_buf + (main_key->offset<<2) + (j * sizeof(script_sub_key_t)));
pattern = (sub_key->pattern>>16) & 0xffff; //获取数据的类型
//取出数据
if(DATA_TYPE_GPIO_WORD == pattern)
{
strcpy( user_gpio_cfg[user_index].gpio_name, sub_key->sub_name);
memcpy(&user_gpio_cfg[user_index].port, script_mod_buf + (sub_key->offset<<2), sizeof(script_gpio_set_t) - 32);
user_index++;
if(user_index >= gpio_count)
{
break;
}
}
}
return SCRIPT_PARSER_OK;
}
return SCRIPT_PARSER_KEY_NOT_FIND;
}