Commit d847f7af authored by reimar's avatar reimar

Add FF_OPT_TYPE_BINARY and use it to add a cryptokey option


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@11250 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 39e4c0bc
...@@ -108,6 +108,13 @@ static const char *const_names[]={ ...@@ -108,6 +108,13 @@ static const char *const_names[]={
0 0
}; };
static int hexchar2int(char c) {
if (c >= '0' && c <= '9') return c - '0';
if (c >= 'a' && c <= 'f') return c - 'a' + 10;
if (c >= 'A' && c <= 'F') return c - 'A' + 10;
return -1;
}
const AVOption *av_set_string(void *obj, const char *name, const char *val){ const AVOption *av_set_string(void *obj, const char *name, const char *val){
const AVOption *o= av_find_opt(obj, name, NULL, 0, 0); const AVOption *o= av_find_opt(obj, name, NULL, 0, 0);
if(o && o->offset==0 && o->type == FF_OPT_TYPE_CONST && o->unit){ if(o && o->offset==0 && o->type == FF_OPT_TYPE_CONST && o->unit){
...@@ -115,6 +122,29 @@ const AVOption *av_set_string(void *obj, const char *name, const char *val){ ...@@ -115,6 +122,29 @@ const AVOption *av_set_string(void *obj, const char *name, const char *val){
} }
if(!o || !val || o->offset<=0) if(!o || !val || o->offset<=0)
return NULL; return NULL;
if(o->type == FF_OPT_TYPE_BINARY){
uint8_t **dst = (uint8_t **)(((uint8_t*)obj) + o->offset);
int *lendst = (int *)(dst + 1);
uint8_t *bin, *ptr;
int len = strlen(val);
av_freep(dst);
*lendst = 0;
if (len & 1) return NULL;
len /= 2;
ptr = bin = av_malloc(len);
while (*val) {
int a = hexchar2int(*val++);
int b = hexchar2int(*val++);
if (a < 0 || b < 0) {
av_free(bin);
return NULL;
}
*ptr++ = (a << 4) | b;
}
*dst = bin;
*lendst = len;
return o;
}
if(o->type != FF_OPT_TYPE_STRING){ if(o->type != FF_OPT_TYPE_STRING){
for(;;){ for(;;){
int i; int i;
...@@ -184,6 +214,8 @@ const AVOption *av_set_int(void *obj, const char *name, int64_t n){ ...@@ -184,6 +214,8 @@ const AVOption *av_set_int(void *obj, const char *name, int64_t n){
const char *av_get_string(void *obj, const char *name, const AVOption **o_out, char *buf, int buf_len){ const char *av_get_string(void *obj, const char *name, const AVOption **o_out, char *buf, int buf_len){
const AVOption *o= av_find_opt(obj, name, NULL, 0, 0); const AVOption *o= av_find_opt(obj, name, NULL, 0, 0);
void *dst; void *dst;
uint8_t *bin;
int len, i;
if(!o || o->offset<=0) if(!o || o->offset<=0)
return NULL; return NULL;
if(o->type != FF_OPT_TYPE_STRING && (!buf || !buf_len)) if(o->type != FF_OPT_TYPE_STRING && (!buf || !buf_len))
...@@ -200,6 +232,12 @@ const char *av_get_string(void *obj, const char *name, const AVOption **o_out, c ...@@ -200,6 +232,12 @@ const char *av_get_string(void *obj, const char *name, const AVOption **o_out, c
case FF_OPT_TYPE_DOUBLE: snprintf(buf, buf_len, "%f" , *(double *)dst);break; case FF_OPT_TYPE_DOUBLE: snprintf(buf, buf_len, "%f" , *(double *)dst);break;
case FF_OPT_TYPE_RATIONAL: snprintf(buf, buf_len, "%d/%d", ((AVRational*)dst)->num, ((AVRational*)dst)->den);break; case FF_OPT_TYPE_RATIONAL: snprintf(buf, buf_len, "%d/%d", ((AVRational*)dst)->num, ((AVRational*)dst)->den);break;
case FF_OPT_TYPE_STRING: return *(void**)dst; case FF_OPT_TYPE_STRING: return *(void**)dst;
case FF_OPT_TYPE_BINARY:
len = *(int*)(((uint8_t *)dst) + sizeof(uint8_t *));
if(len >= (buf_len + 1)/2) return NULL;
bin = *(uint8_t**)dst;
for(i = 0; i < len; i++) snprintf(buf + i*2, 3, "%02X", bin[i]);
break;
default: return NULL; default: return NULL;
} }
return buf; return buf;
...@@ -306,6 +344,9 @@ static void opt_list(void *obj, void *av_log_obj, const char *unit) ...@@ -306,6 +344,9 @@ static void opt_list(void *obj, void *av_log_obj, const char *unit)
case FF_OPT_TYPE_RATIONAL: case FF_OPT_TYPE_RATIONAL:
av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<rational>" ); av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<rational>" );
break; break;
case FF_OPT_TYPE_BINARY:
av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "<binary>" );
break;
case FF_OPT_TYPE_CONST: case FF_OPT_TYPE_CONST:
default: default:
av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "" ); av_log( av_log_obj, AV_LOG_INFO, "%-7s ", "" );
...@@ -373,6 +414,7 @@ void av_opt_set_defaults2(void *s, int mask, int flags) ...@@ -373,6 +414,7 @@ void av_opt_set_defaults2(void *s, int mask, int flags)
} }
break; break;
case FF_OPT_TYPE_STRING: case FF_OPT_TYPE_STRING:
case FF_OPT_TYPE_BINARY:
/* Cannot set default for string as default_val is of type * double */ /* Cannot set default for string as default_val is of type * double */
break; break;
default: default:
......
...@@ -37,6 +37,7 @@ enum AVOptionType{ ...@@ -37,6 +37,7 @@ enum AVOptionType{
FF_OPT_TYPE_FLOAT, FF_OPT_TYPE_FLOAT,
FF_OPT_TYPE_STRING, FF_OPT_TYPE_STRING,
FF_OPT_TYPE_RATIONAL, FF_OPT_TYPE_RATIONAL,
FF_OPT_TYPE_BINARY, ///< offset must point to a pointer immediately followed by an int for the length
FF_OPT_TYPE_CONST=128, FF_OPT_TYPE_CONST=128,
}; };
......
...@@ -323,6 +323,7 @@ static const AVOption options[]={ ...@@ -323,6 +323,7 @@ static const AVOption options[]={
{"track", " set the track number", OFFSET(track), FF_OPT_TYPE_INT, DEFAULT, 0, INT_MAX, E}, {"track", " set the track number", OFFSET(track), FF_OPT_TYPE_INT, DEFAULT, 0, INT_MAX, E},
{"year", "set the year", OFFSET(year), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, E}, {"year", "set the year", OFFSET(year), FF_OPT_TYPE_INT, DEFAULT, INT_MIN, INT_MAX, E},
{"analyzeduration", "how many microseconds are analyzed to estimate duration", OFFSET(max_analyze_duration), FF_OPT_TYPE_INT, 3*AV_TIME_BASE, 0, INT_MAX, D}, {"analyzeduration", "how many microseconds are analyzed to estimate duration", OFFSET(max_analyze_duration), FF_OPT_TYPE_INT, 3*AV_TIME_BASE, 0, INT_MAX, D},
{"cryptokey", "decryption key", OFFSET(key), FF_OPT_TYPE_BINARY, 0, 0, 0, D},
{NULL}, {NULL},
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment