blob: 1a49a535fcf255a91f5e976d5621cf32a25b6a09 [file] [log] [blame] [edit]
/*
* Copyright (C) 2017 Amlogic, Inc. All rights reserved.
* *
This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
* *
This program is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
* *
You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
* *
Description:
*/
#include "ini_config.h"
#define LOG_TAG "ini_platform"
#define LOG_NDEBUG 0
#include "ini_log.h"
#include "ini_handler.h"
#include "ini_platform.h"
#include <partition_table.h>
//c basic lib
char* plat_strtok_r(char *str, const char *delim, char **saveptr) {
#if (defined CC_COMPILE_IN_PC || defined CC_COMPILE_IN_ANDROID)
return strtok_r(str, delim, saveptr);
#elif (defined CC_COMPILE_IN_UBOOT)
return strtok(str, delim);
#endif
}
//File functions
#if (defined CC_COMPILE_IN_UBOOT)
static int splitFilePath(const char *file_path, char part_name[], char file_name[], const char *ext_name) {
int i = 0;
char *tmp_start_ptr = NULL;
char *tmp_end_ptr = NULL;
char *slot_name;
if (file_path == NULL) {
ALOGE("%s, file_path is NULL!!!\n", __FUNCTION__);
return -1;
}
tmp_start_ptr = strchr((char*)file_path,'/');
if (tmp_start_ptr != file_path) {
ALOGE("%s, we need one abstract file path!!! %s.\n", __FUNCTION__, file_path);
return -1;
}
tmp_end_ptr = strchr(tmp_start_ptr + 1,'/');
if (tmp_end_ptr == NULL) {
ALOGE("%s, there is only partition name in the path!!!\n", __FUNCTION__);
return -1;
}
strncpy(part_name, tmp_start_ptr + 1, tmp_end_ptr - tmp_start_ptr - 1);
part_name[tmp_end_ptr - tmp_start_ptr - 1] = '\0';
//ALOGD("%s, partition name is %s\n", __FUNCTION__, part_name);
if (has_boot_slot == 1) {
run_command("get_valid_slot", 0);
slot_name = getenv("slot-suffixes");
printf("slot-suffixes: %s\n", slot_name);
if (strcmp(slot_name, "0") == 0) {
strcat(part_name, "_a");
} else if (strcmp(slot_name, "1") == 0) {
strcat(part_name, "_b");
}
ALOGD("%s, partition name is %s\n", __FUNCTION__, part_name);
}
tmp_start_ptr = tmp_end_ptr;
i = 0;
while (*tmp_end_ptr && i < CC_MAX_INI_FILE_NAME_LEN) {
tmp_end_ptr++;
i++;
}
if (i >= CC_MAX_INI_FILE_NAME_LEN) {
ALOGE("%s, file path is too long (%d)!!!\n", __FUNCTION__, i);
return -1;
}
strncpy(file_name, tmp_start_ptr, i);
file_name[i] = '\0';
//ALOGD("%s, file name is %s\n", __FUNCTION__, file_name);
if (ext_name != NULL) {
if (strlen(ext_name) > 0) {
while (tmp_end_ptr != tmp_start_ptr && *tmp_end_ptr != '.') {
tmp_end_ptr--;
}
if (*tmp_end_ptr != '.') {
ALOGE("%s, the file path \"%s\" doesn't have ext name!!!\n", __FUNCTION__, file_path);
return -1;
} else {
if (strncmp(tmp_end_ptr + 1, ext_name, 128)) {
ALOGE("%s, the ext name of file path \"%s\" not equal to the special ext name \"%s\"!!!\n", __FUNCTION__, file_path, ext_name);
return -1;
}
}
}
}
return 0;
}
#define CS_BLCOK_DEV_INTERFACE "mmc"
#define CS_BLCOK_DEV_MARJOR_NUM "1"
static int setBlockDevice(const char *part_name) {
int part_no = 0;
char part_buf[128] = {0};
char tmp_buf[128] = {0};
part_no = get_partition_num_by_name((char *)part_name);
//ALOGD("%s, part_no is %d\n", __FUNCTION__, part_no);
if (part_no >= 0) {
strcpy(part_buf, CS_BLCOK_DEV_MARJOR_NUM);
strcat(part_buf, ":");
sprintf(tmp_buf, "%x", part_no);
strcat(part_buf, tmp_buf);
return fs_set_blk_dev(CS_BLCOK_DEV_INTERFACE, part_buf, FS_TYPE_EXT);
}
return -1;
}
#endif
int iniIsFileExist(const char *file_path) {
#if (defined CC_COMPILE_IN_PC || defined CC_COMPILE_IN_ANDROID)
if (access(file_path, 0) < 0) {
return 0;
}
return 1;
#elif (defined CC_COMPILE_IN_UBOOT)
char part_name[CC_MAX_INI_FILE_NAME_LEN];
char file_name[CC_MAX_INI_FILE_NAME_LEN];
memset((void *)part_name, 0, CC_MAX_INI_FILE_NAME_LEN);
memset((void *)file_name, 0, CC_MAX_INI_FILE_NAME_LEN);
if (splitFilePath(file_path, part_name, file_name, NULL) < 0) {
return 0;
}
if (setBlockDevice(part_name) < 0) {
return 0;
}
return fs_exists(file_name);
#endif
}
int iniGetFileSize(const char *file_path) {
#if (defined CC_COMPILE_IN_PC || defined CC_COMPILE_IN_ANDROID)
int file_size = 0;
int dev_fd = -1;
dev_fd = open(file_path, O_RDONLY);
if (dev_fd < 0) {
ALOGE("%s, open \"%s\" ERROR(%s)!!\n", __FUNCTION__,
file_path, strerror(errno));
return 0;
}
file_size = lseek(dev_fd, 0L, SEEK_END);
lseek(dev_fd, 0L, SEEK_SET);
return file_size;
#elif (defined CC_COMPILE_IN_UBOOT)
loff_t file_size = 0;
char part_name[CC_MAX_INI_FILE_NAME_LEN];
char file_name[CC_MAX_INI_FILE_NAME_LEN];
memset((void *)part_name, 0, CC_MAX_INI_FILE_NAME_LEN);
memset((void *)file_name, 0, CC_MAX_INI_FILE_NAME_LEN);
if (splitFilePath(file_path, part_name, file_name, NULL) < 0) {
return -1;
}
if (setBlockDevice(part_name) < 0) {
return -1;
}
if (fs_size(file_name, &file_size)) {
return -1;
}
return file_size;
#endif
}
int iniReadFileToBuffer(const char *file_path, int offset, int rd_size, unsigned char data_buf[]) {
#if (defined CC_COMPILE_IN_PC || defined CC_COMPILE_IN_ANDROID)
int rd_cnt = 0, file_size = 0;
int dev_fd = -1;
dev_fd = open(file_path, O_RDONLY);
if (dev_fd < 0) {
ALOGE("%s, open \"%s\" ERROR(%s)!!\n", __FUNCTION__,
file_path, strerror(errno));
return -1;
}
lseek(dev_fd, offset, SEEK_SET);
rd_cnt = read(dev_fd, data_buf, rd_size);
close(dev_fd);
dev_fd = -1;
if (rd_cnt != rd_size) {
ALOGE("%s, read file \"%s\" ERROR(%d, %d)!!!!\n", __FUNCTION__,
file_path, rd_cnt, file_size);
return -1;
}
return rd_cnt;
#elif (defined CC_COMPILE_IN_UBOOT)
int tmp_ret = -1;
loff_t rd_cnt = 0;
char part_name[CC_MAX_INI_FILE_NAME_LEN];
char file_name[CC_MAX_INI_FILE_NAME_LEN];
memset((void *)part_name, 0, CC_MAX_INI_FILE_NAME_LEN);
memset((void *)file_name, 0, CC_MAX_INI_FILE_NAME_LEN);
if (splitFilePath(file_path, part_name, file_name, NULL) < 0) {
return -1;
}
if (setBlockDevice(part_name) < 0) {
return -1;
}
tmp_ret = fs_read(file_name, (unsigned long)data_buf, 0, 0, &rd_cnt);
if (tmp_ret < 0) {
return -1;
}
flush_dcache_range((unsigned long )data_buf, (unsigned long )data_buf + rd_cnt);
return rd_cnt;
#endif
}