1
0
Fork 0
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
hmz007 6d24f2138b
Rockchip Anroid12_SDK 20220721-rkr10 (e1522e56)
3 years ago
..
Makefile Rockchip Anroid12_SDK 20220721-rkr10 (e1522e56) 3 years ago
README.txt Rockchip Anroid12_SDK 20220721-rkr10 (e1522e56) 3 years ago
decode_double.c Rockchip Anroid12_SDK 20220721-rkr10 (e1522e56) 3 years ago
double_conversion.c Rockchip Anroid12_SDK 20220721-rkr10 (e1522e56) 3 years ago
double_conversion.h Rockchip Anroid12_SDK 20220721-rkr10 (e1522e56) 3 years ago
doubleproto.proto Rockchip Anroid12_SDK 20220721-rkr10 (e1522e56) 3 years ago
encode_double.c Rockchip Anroid12_SDK 20220721-rkr10 (e1522e56) 3 years ago
test_conversions.c Rockchip Anroid12_SDK 20220721-rkr10 (e1522e56) 3 years ago

README.txt

Nanopb example "using_double_on_avr"
====================================

Some processors/compilers, such as AVR-GCC, do not support the double
datatype. Instead, they have sizeof(double) == 4. Because protocol
binary format uses the double encoding directly, this causes trouble
if the protocol in .proto requires double fields.

This directory contains a solution to this problem. It uses uint64_t
to store the raw wire values, because its size is correct on all
platforms. The file double_conversion.c provides functions that
convert these values to/from floats, without relying on compiler
support.

To use this method, you need to make some modifications to your code:

1) Change all 'double' fields into 'fixed64' in the .proto.

2) Whenever writing to a 'double' field, use float_to_double().

3) Whenever reading a 'double' field, use double_to_float().

The conversion routines are as accurate as the float datatype can
be. Furthermore, they should handle all special values (NaN, inf, denormalized
numbers) correctly. There are testcases in test_conversions.c.