blobmsg: add support for double

This adds support for double floating point type to make it more JSON
compatible. For type checking it also adds a stub BLOB_ATTR_DOUBLE type.
If necessary, the accessor functions for blob can be added later

Signed-off-by: André Gaul <andre@gaul.io>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
André Gaul 2016-11-19 18:55:49 +01:00 committed by Felix Fietkau
parent 0fe13749d0
commit 7f671b1e68
6 changed files with 37 additions and 0 deletions

1
blob.c
View file

@ -192,6 +192,7 @@ static const int blob_type_minlen[BLOB_ATTR_LAST] = {
[BLOB_ATTR_INT16] = sizeof(uint16_t), [BLOB_ATTR_INT16] = sizeof(uint16_t),
[BLOB_ATTR_INT32] = sizeof(uint32_t), [BLOB_ATTR_INT32] = sizeof(uint32_t),
[BLOB_ATTR_INT64] = sizeof(uint64_t), [BLOB_ATTR_INT64] = sizeof(uint64_t),
[BLOB_ATTR_DOUBLE] = sizeof(double),
}; };
bool bool

1
blob.h
View file

@ -39,6 +39,7 @@ enum {
BLOB_ATTR_INT16, BLOB_ATTR_INT16,
BLOB_ATTR_INT32, BLOB_ATTR_INT32,
BLOB_ATTR_INT64, BLOB_ATTR_INT64,
BLOB_ATTR_DOUBLE,
BLOB_ATTR_LAST BLOB_ATTR_LAST
}; };

View file

@ -20,6 +20,7 @@ static const int blob_type[__BLOBMSG_TYPE_LAST] = {
[BLOBMSG_TYPE_INT16] = BLOB_ATTR_INT16, [BLOBMSG_TYPE_INT16] = BLOB_ATTR_INT16,
[BLOBMSG_TYPE_INT32] = BLOB_ATTR_INT32, [BLOBMSG_TYPE_INT32] = BLOB_ATTR_INT32,
[BLOBMSG_TYPE_INT64] = BLOB_ATTR_INT64, [BLOBMSG_TYPE_INT64] = BLOB_ATTR_INT64,
[BLOBMSG_TYPE_DOUBLE] = BLOB_ATTR_DOUBLE,
[BLOBMSG_TYPE_STRING] = BLOB_ATTR_STRING, [BLOBMSG_TYPE_STRING] = BLOB_ATTR_STRING,
[BLOBMSG_TYPE_UNSPEC] = BLOB_ATTR_BINARY, [BLOBMSG_TYPE_UNSPEC] = BLOB_ATTR_BINARY,
}; };

View file

@ -31,6 +31,7 @@ enum blobmsg_type {
BLOBMSG_TYPE_INT32, BLOBMSG_TYPE_INT32,
BLOBMSG_TYPE_INT16, BLOBMSG_TYPE_INT16,
BLOBMSG_TYPE_INT8, BLOBMSG_TYPE_INT8,
BLOBMSG_TYPE_DOUBLE,
__BLOBMSG_TYPE_LAST, __BLOBMSG_TYPE_LAST,
BLOBMSG_TYPE_LAST = __BLOBMSG_TYPE_LAST - 1, BLOBMSG_TYPE_LAST = __BLOBMSG_TYPE_LAST - 1,
BLOBMSG_TYPE_BOOL = BLOBMSG_TYPE_INT8, BLOBMSG_TYPE_BOOL = BLOBMSG_TYPE_INT8,
@ -113,6 +114,18 @@ int blobmsg_parse_array(const struct blobmsg_policy *policy, int policy_len,
int blobmsg_add_field(struct blob_buf *buf, int type, const char *name, int blobmsg_add_field(struct blob_buf *buf, int type, const char *name,
const void *data, unsigned int len); const void *data, unsigned int len);
static inline int
blobmsg_add_double(struct blob_buf *buf, const char *name, double val)
{
union {
double d;
uint64_t u64;
} v;
v.d = val;
v.u64 = cpu_to_be64(v.u64);
return blobmsg_add_field(buf, BLOBMSG_TYPE_DOUBLE, name, &v.u64, 8);
}
static inline int static inline int
blobmsg_add_u8(struct blob_buf *buf, const char *name, uint8_t val) blobmsg_add_u8(struct blob_buf *buf, const char *name, uint8_t val)
{ {
@ -212,6 +225,16 @@ static inline uint64_t blobmsg_get_u64(struct blob_attr *attr)
return tmp; return tmp;
} }
static inline double blobmsg_get_double(struct blob_attr *attr)
{
union {
double d;
uint64_t u64;
} v;
v.u64 = blobmsg_get_u64(attr);
return v.d;
}
static inline char *blobmsg_get_string(struct blob_attr *attr) static inline char *blobmsg_get_string(struct blob_attr *attr)
{ {
if (!attr) if (!attr)

View file

@ -69,6 +69,9 @@ bool blobmsg_add_json_element(struct blob_buf *b, const char *name, json_object
case json_type_int: case json_type_int:
blobmsg_add_u32(b, name, json_object_get_int(obj)); blobmsg_add_u32(b, name, json_object_get_int(obj));
break; break;
case json_type_double:
blobmsg_add_double(b, name, json_object_get_double(obj));
break;
case json_type_null: case json_type_null:
blobmsg_add_field(b, BLOBMSG_TYPE_UNSPEC, name, NULL, 0); blobmsg_add_field(b, BLOBMSG_TYPE_UNSPEC, name, NULL, 0);
break; break;
@ -255,6 +258,9 @@ static void blobmsg_format_element(struct strbuf *s, struct blob_attr *attr, boo
case BLOBMSG_TYPE_INT64: case BLOBMSG_TYPE_INT64:
sprintf(buf, "%" PRId64, (int64_t) be64_to_cpu(*(uint64_t *)data)); sprintf(buf, "%" PRId64, (int64_t) be64_to_cpu(*(uint64_t *)data));
break; break;
case BLOBMSG_TYPE_DOUBLE:
sprintf(buf, "%lf", blobmsg_get_double(attr));
break;
case BLOBMSG_TYPE_STRING: case BLOBMSG_TYPE_STRING:
blobmsg_format_string(s, data); blobmsg_format_string(s, data);
return; return;

View file

@ -49,6 +49,9 @@ static void dump_attr_data(struct blob_attr *data, int indent, int next_indent)
case BLOBMSG_TYPE_INT64: case BLOBMSG_TYPE_INT64:
indent_printf(indent, "%"PRIu64"\n", blobmsg_get_u64(data)); indent_printf(indent, "%"PRIu64"\n", blobmsg_get_u64(data));
break; break;
case BLOBMSG_TYPE_DOUBLE:
indent_printf(indent, "%lf\n", blobmsg_get_double(data));
break;
case BLOBMSG_TYPE_TABLE: case BLOBMSG_TYPE_TABLE:
case BLOBMSG_TYPE_ARRAY: case BLOBMSG_TYPE_ARRAY:
if (!indent) if (!indent)
@ -113,6 +116,7 @@ fill_message(struct blob_buf *buf)
blobmsg_add_string(buf, "message", "Hello, world!"); blobmsg_add_string(buf, "message", "Hello, world!");
tbl = blobmsg_open_table(buf, "testdata"); tbl = blobmsg_open_table(buf, "testdata");
blobmsg_add_double(buf, "double", 1.337e2);
blobmsg_add_u32(buf, "hello", 1); blobmsg_add_u32(buf, "hello", 1);
blobmsg_add_string(buf, "world", "2"); blobmsg_add_string(buf, "world", "2");
blobmsg_close_table(buf, tbl); blobmsg_close_table(buf, tbl);
@ -121,6 +125,7 @@ fill_message(struct blob_buf *buf)
blobmsg_add_u32(buf, NULL, 0); blobmsg_add_u32(buf, NULL, 0);
blobmsg_add_u32(buf, NULL, 1); blobmsg_add_u32(buf, NULL, 1);
blobmsg_add_u32(buf, NULL, 2); blobmsg_add_u32(buf, NULL, 2);
blobmsg_add_double(buf, "double", 1.337e2);
blobmsg_close_table(buf, tbl); blobmsg_close_table(buf, tbl);
} }