mirror of
https://github.com/nyanmisaka/mpp.git
synced 2025-10-05 17:16:50 +08:00
[rk_env]: add default value to env_get function
git-svn-id: https://10.10.10.66:8443/svn/MediaProcessPlatform/trunk/mpp@35 6e48237b-75ef-9749-8fc9-41990f28c85a
This commit is contained in:
@@ -25,49 +25,52 @@
|
||||
* So the library should compiled on latest ndk
|
||||
*/
|
||||
|
||||
RK_S32 os_get_env_u32(const char *name, RK_U32 *val)
|
||||
RK_S32 os_get_env_u32(const char *name, RK_U32 *value, RK_U32 default_value)
|
||||
{
|
||||
RK_S32 ret = -1;
|
||||
char value[PROP_VALUE_MAX+1];
|
||||
int len = __system_property_get(name, value);
|
||||
*val = 0;
|
||||
char prop[PROP_VALUE_MAX+1];
|
||||
int len = __system_property_get(name, prop);
|
||||
if (len > 0) {
|
||||
char *endptr;
|
||||
int base = (value[0] == '0' && value[1] == 'x')?(16):(10);
|
||||
int base = (prop[0] == '0' && prop[1] == 'x')?(16):(10);
|
||||
errno = 0;
|
||||
*val = strtoul(value, &endptr, base);
|
||||
if (errno || (value == endptr)) {
|
||||
*value = strtoul(prop, &endptr, base);
|
||||
if (errno || (prop == endptr)) {
|
||||
errno = 0;
|
||||
*value = default_value;
|
||||
}
|
||||
} else {
|
||||
ret = 0;
|
||||
*value = default_value;
|
||||
}
|
||||
}
|
||||
return ret;
|
||||
return 0;
|
||||
}
|
||||
|
||||
RK_S32 os_get_env_str(const char *name, char **val)
|
||||
RK_S32 os_get_env_str(const char *name, char **value, char *default_value)
|
||||
{
|
||||
// use unsigned char to avoid warnning
|
||||
static unsigned char env_str[2][PROP_VALUE_MAX+1];
|
||||
static RK_U32 env_idx = 0;
|
||||
char *value = (char *)env_str[env_idx];
|
||||
int len = __system_property_get(name, value);
|
||||
*val = (len)?(value):(NULL);
|
||||
env_idx = (len)?(!env_idx):(env_idx);
|
||||
return (len)?(0):(-1);
|
||||
char *prop = (char *)env_str[env_idx];
|
||||
int len = __system_property_get(name, prop);
|
||||
if (len > 0) {
|
||||
*value = prop;
|
||||
env_idx = !env_idx;
|
||||
} else {
|
||||
*value = default_value;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
RK_S32 os_set_env_u32(const char *name, RK_U32 val)
|
||||
RK_S32 os_set_env_u32(const char *name, RK_U32 value)
|
||||
{
|
||||
char buf[PROP_VALUE_MAX+1+2];
|
||||
snprintf(buf, sizeof(buf), "0x%x", val);
|
||||
snprintf(buf, sizeof(buf), "0x%x", value);
|
||||
int len = __system_property_set(name, buf);
|
||||
return (len)?(0):(-1);
|
||||
}
|
||||
|
||||
RK_S32 os_set_env_str(const char *name, char *val)
|
||||
RK_S32 os_set_env_str(const char *name, char *value)
|
||||
{
|
||||
int len = __system_property_set(name, val);
|
||||
int len = __system_property_set(name, value);
|
||||
return (len)?(0):(-1);
|
||||
}
|
||||
|
||||
|
@@ -23,11 +23,11 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
RK_S32 rk_get_env_u32(const char *name, RK_U32 *val);
|
||||
RK_S32 rk_get_env_str(const char *name, char **val);
|
||||
RK_S32 rk_get_env_u32(const char *name, RK_U32 *value, RK_U32 default_value);
|
||||
RK_S32 rk_get_env_str(const char *name, char **value, char *default_value);
|
||||
|
||||
RK_S32 rk_set_env_u32(const char *name, RK_U32 val);
|
||||
RK_S32 rk_set_env_str(const char *name, char *val);
|
||||
RK_S32 rk_set_env_u32(const char *name, RK_U32 value);
|
||||
RK_S32 rk_set_env_str(const char *name, char *value);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
@@ -26,7 +26,8 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
void rk_mpp_set_memalign(size_t size);
|
||||
void rk_mpp_set_mem_align(size_t size);
|
||||
void rk_mpp_show_mem_status();
|
||||
void *rk_mpp_malloc(size_t size);
|
||||
void rk_mpp_free(void *ptr);
|
||||
|
||||
|
@@ -16,33 +16,48 @@
|
||||
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <errno.h>
|
||||
#include "os_env.h"
|
||||
|
||||
#define ENV_BUF_SIZE_LINUX 1024
|
||||
|
||||
RK_S32 os_get_env_u32(const char *name, RK_U32 *val)
|
||||
RK_S32 os_get_env_u32(const char *name, RK_U32 *value, RK_U32 default_value)
|
||||
{
|
||||
char *ptr = getenv(name);
|
||||
*val = (RK_U32)atoi(ptr);
|
||||
if (NULL == ptr) {
|
||||
*value = default_value;
|
||||
} else {
|
||||
char *endptr;
|
||||
int base = (ptr[0] == '0' && ptr[1] == 'x')?(16):(10);
|
||||
errno = 0;
|
||||
*value = strtoul(ptr, &endptr, base);
|
||||
if (errno || (ptr == endptr)) {
|
||||
errno = 0;
|
||||
*value = default_value;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
RK_S32 os_get_env_str(const char *name, char **val)
|
||||
RK_S32 os_get_env_str(const char *name, char **value, char *default_value)
|
||||
{
|
||||
*val = getenv(name);
|
||||
return (*val)?(0):(-1);
|
||||
*value = getenv(name);
|
||||
if (NULL == *value) {
|
||||
*value = default_value;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
RK_S32 os_set_env_u32(const char *name, RK_U32 val)
|
||||
RK_S32 os_set_env_u32(const char *name, RK_U32 value)
|
||||
{
|
||||
char buf[ENV_BUF_SIZE_LINUX];
|
||||
snprintf(buf, sizeof(buf), "%u", val);
|
||||
snprintf(buf, sizeof(buf), "%u", value);
|
||||
return setenv(name, buf, 1);
|
||||
}
|
||||
|
||||
RK_S32 os_set_env_str(const char *name, char *val)
|
||||
RK_S32 os_set_env_str(const char *name, char *value)
|
||||
{
|
||||
return setenv(name, val, 1);
|
||||
return setenv(name, value, 1);
|
||||
}
|
||||
|
||||
|
||||
|
@@ -23,11 +23,11 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
RK_S32 os_get_env_u32(const char *name, RK_U32 *val);
|
||||
RK_S32 os_get_env_str(const char *name, char **val);
|
||||
RK_S32 os_get_env_u32(const char *name, RK_U32 *value, RK_U32 default_value);
|
||||
RK_S32 os_get_env_str(const char *name, char **value, char *default_value);
|
||||
|
||||
RK_S32 os_set_env_u32(const char *name, RK_U32 val);
|
||||
RK_S32 os_set_env_str(const char *name, char *val);
|
||||
RK_S32 os_set_env_u32(const char *name, RK_U32 value);
|
||||
RK_S32 os_set_env_str(const char *name, char *value);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
@@ -17,24 +17,24 @@
|
||||
#include "rk_env.h"
|
||||
#include "os_env.h"
|
||||
|
||||
RK_S32 rk_get_env_u32(const char *name, RK_U32 *val)
|
||||
RK_S32 rk_get_env_u32(const char *name, RK_U32 *value, RK_U32 default_value)
|
||||
{
|
||||
return os_get_env_u32(name, val);
|
||||
return os_get_env_u32(name, value, default_value);
|
||||
}
|
||||
|
||||
RK_S32 rk_get_env_str(const char *name, char **val)
|
||||
RK_S32 rk_get_env_str(const char *name, char **value, char *default_value)
|
||||
{
|
||||
return os_get_env_str(name, val);
|
||||
return os_get_env_str(name, value, default_value);
|
||||
}
|
||||
|
||||
RK_S32 rk_set_env_u32(const char *name, RK_U32 val)
|
||||
RK_S32 rk_set_env_u32(const char *name, RK_U32 value)
|
||||
{
|
||||
return os_set_env_u32(name, val);
|
||||
return os_set_env_u32(name, value);
|
||||
}
|
||||
|
||||
RK_S32 rk_set_env_str(const char *name, char *val)
|
||||
RK_S32 rk_set_env_str(const char *name, char *value)
|
||||
{
|
||||
return os_set_env_str(name, val);
|
||||
return os_set_env_str(name, value);
|
||||
}
|
||||
|
||||
|
||||
|
@@ -56,7 +56,6 @@ RK_U32 rk_get_log_flag()
|
||||
return mpp_log_flag;
|
||||
}
|
||||
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
@@ -17,18 +17,28 @@
|
||||
#define LOG_TAG "rk_malloc"
|
||||
#include "rk_type.h"
|
||||
#include "rk_log.h"
|
||||
#include "rk_env.h"
|
||||
#include "rk_malloc.h"
|
||||
|
||||
#include "os_malloc.h"
|
||||
|
||||
// default memory align size is set to 64
|
||||
static size_t rk_mpp_memalign = 64;
|
||||
static size_t rk_mpp_mem_align = 64;
|
||||
static RK_S32 mem_protect_flag = -1;
|
||||
|
||||
void rk_mpp_set_memalign(size_t size)
|
||||
static inline RK_S32 mpp_get_mem_proctect_flag()
|
||||
{
|
||||
if (mem_protect_flag < 0) {
|
||||
rk_get_env_u32("mpp_protect", (RK_U32 *)&mem_protect_flag, 0);
|
||||
}
|
||||
return mem_protect_flag;
|
||||
}
|
||||
|
||||
void rk_mpp_set_mem_align(size_t size)
|
||||
{
|
||||
/* determine align size is power of 2 */
|
||||
if (size && !(size & (size - 1)))
|
||||
rk_mpp_memalign = size;
|
||||
rk_mpp_mem_align = size;
|
||||
else
|
||||
rk_log("set memalign to %d failed\n", size);
|
||||
}
|
||||
@@ -36,7 +46,7 @@ void rk_mpp_set_memalign(size_t size)
|
||||
void *rk_mpp_malloc(size_t size)
|
||||
{
|
||||
void *ptr;
|
||||
if (0 == os_malloc(&ptr, rk_mpp_memalign, size))
|
||||
if (0 == os_malloc(&ptr, rk_mpp_mem_align, size))
|
||||
return ptr;
|
||||
else
|
||||
return NULL;
|
||||
|
@@ -36,8 +36,8 @@ int main()
|
||||
env_string_str = NULL;
|
||||
rk_log("clear local value to zero\n");
|
||||
|
||||
rk_get_env_u32(env_debug, &env_debug_u32);
|
||||
rk_get_env_str(env_string, &env_string_str);
|
||||
rk_get_env_u32(env_debug, &env_debug_u32, 0);
|
||||
rk_get_env_str(env_string, &env_string_str, NULL);
|
||||
|
||||
rk_log("get env: %s is %u\n", env_debug, env_debug_u32);
|
||||
rk_log("get env: %s is %s\n", env_string, env_string_str);
|
||||
|
@@ -23,7 +23,7 @@ int main()
|
||||
void *tmp = NULL;
|
||||
|
||||
rk_log("try memalign of 512\n");
|
||||
rk_mpp_set_memalign(512);
|
||||
rk_mpp_set_mem_align(512);
|
||||
|
||||
tmp = rk_malloc(int, 100);
|
||||
if (tmp) {
|
||||
|
@@ -20,30 +20,44 @@
|
||||
|
||||
#define ENV_BUF_SIZE_WIN 1024
|
||||
|
||||
RK_S32 os_get_env_u32(const char *name, RK_U32 *val)
|
||||
RK_S32 os_get_env_u32(const char *name, RK_U32 *value, RK_U32 default_value)
|
||||
{
|
||||
char *ptr = getenv(name);
|
||||
*val = (RK_U32)atoi(ptr);
|
||||
if (NULL == ptr) {
|
||||
*value = default_value;
|
||||
} else {
|
||||
char *endptr;
|
||||
int base = (ptr[0] == '0' && ptr[1] == 'x')?(16):(10);
|
||||
errno = 0;
|
||||
*value = strtoul(ptr, &endptr, base);
|
||||
if (errno || (ptr == endptr)) {
|
||||
errno = 0;
|
||||
*value = default_value;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
RK_S32 os_get_env_str(const char *name, char **val)
|
||||
RK_S32 os_get_env_str(const char *name, char **value, char *default_value)
|
||||
{
|
||||
*val = getenv(name);
|
||||
return (*val)?(0):(-1);
|
||||
*value = getenv(name);
|
||||
if (NULL == *value) {
|
||||
*value = default_value;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
RK_S32 os_set_env_u32(const char *name, RK_U32 val)
|
||||
RK_S32 os_set_env_u32(const char *name, RK_U32 value)
|
||||
{
|
||||
char buf[ENV_BUF_SIZE_WIN];
|
||||
_snprintf(buf, sizeof(buf), "%s=%lu", name, val);
|
||||
_snprintf(buf, sizeof(buf), "%s=%lu", name, value);
|
||||
return _putenv(buf);
|
||||
}
|
||||
|
||||
RK_S32 os_set_env_str(const char *name, char *val)
|
||||
RK_S32 os_set_env_str(const char *name, char *value)
|
||||
{
|
||||
char buf[ENV_BUF_SIZE_WIN];
|
||||
_snprintf(buf, sizeof(buf), "%s=%s", name, val);
|
||||
_snprintf(buf, sizeof(buf), "%s=%s", name, value);
|
||||
return _putenv(buf);
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user