52 #define PRINTF(...) printf(__VA_ARGS__)
59 get_len_type(
const oma_tlv_t *tlv)
63 }
else if(tlv->length < 256) {
65 }
else if(tlv->length < 0x10000) {
73 oma_tlv_read(oma_tlv_t *tlv,
const uint8_t *buffer,
size_t len)
79 tlv->type = (buffer[0] >> 6) & 3;
80 len_type = (buffer[0] >> 3) & 3;
81 len_pos = 1 + (((buffer[0] & (1 << 5)) != 0) ? 2 : 1);
86 tlv->id = (tlv->id << 8) + buffer[2];
90 tlv_len = buffer[0] & 7;
95 tlv_len = tlv_len << 8 | buffer[len_pos++];
100 tlv->length = tlv_len;
101 tlv->value = &buffer[len_pos];
103 return len_pos + tlv_len;
107 oma_tlv_get_size(
const oma_tlv_t *tlv)
111 size = 1 + get_len_type(tlv);
113 size += (tlv->id > 255) ? 2 : 1;
121 oma_tlv_write(
const oma_tlv_t *tlv, uint8_t *buffer,
size_t len)
127 len_type = get_len_type(tlv);
130 if(len < tlv->length + pos) {
131 PRINTF(
"OMA-TLV: Could not write the TLV - buffer overflow.\n");
136 buffer[0] = (tlv->type << 6) |
137 (tlv->id > 255 ? (1 << 5) : 0) |
139 (len_type == 0 ? tlv->length : 0);
144 buffer[pos++] = (tlv->id >> 8) & 0xff;
146 buffer[pos++] = tlv->id & 0xff;
149 buffer[pos++] = (tlv->length >> 16) & 0xff;
152 buffer[pos++] = (tlv->length >> 8) & 0xff;
155 buffer[pos++] = tlv->length & 0xff;
159 memcpy(&buffer[pos], tlv->value, tlv->length);
164 for(i = 0; i < pos + tlv->length; i++) {
165 PRINTF(
"%02x", buffer[i]);
170 return pos + tlv->length;
174 oma_tlv_get_int32(
const oma_tlv_t *tlv)
179 for(i = 0; i < tlv->length; i++) {
180 value = (value << 8) | tlv->value[i];
186 oma_tlv_write_int32(int16_t
id, int32_t value, uint8_t *buffer,
size_t len)
192 PRINTF(
"Exporting int32 %d %ld ",
id, (
long)value);
194 buf[3] = value & 0xff;
196 for(i = 1; value > 0 && i < 4; i++) {
197 buf[3 - i] = value & 0xff;
203 PRINTF(
"len: %zu\n", tlvlen);
204 tlv.type = OMA_TLV_TYPE_RESOURCE;
206 tlv.value = &buf[3 - (tlvlen - 1)];
208 return oma_tlv_write(&tlv, buffer, len);
213 oma_tlv_write_float32(int16_t
id, int32_t value,
int bits,
214 uint8_t *buffer,
size_t len)
231 val = val | (1L << 22);
237 PRINTF(
"Sign: %d, Fraction: %06lx 0b", value < 0, (
long)val);
238 for(i = 0; i < 23; i++) {
239 PRINTF(
"%d", (
int)((val >> (22 - i)) & 1));
241 PRINTF(
"\nExp:%d\n", e);
247 b[0] = (value < 0 ? 0x80 : 0) | (e >> 1);
248 b[1] = ((e & 1) << 7) | ((val >> 16) & 0x7f);
249 b[2] = (val >> 8) & 0xff;
253 tlv.type = OMA_TLV_TYPE_RESOURCE;
258 return oma_tlv_write(&tlv, buffer, len);
263 oma_tlv_float32_to_fix(
const oma_tlv_t *tlv, int32_t *value,
int bits)
268 int sign = (tlv->value[0] & 0x80) != 0;
269 e = ((tlv->value[0] << 1) & 0xff) | (tlv->value[1] >> 7);
270 val = (((long)tlv->value[1] & 0x7f) << 16) | (tlv->value[2] << 8) | tlv->value[3];
272 PRINTF(
"Sign: %d, Fraction: %06lx 0b", val < 0, (
long)val);
273 for(i = 0; i < 23; i++) {
274 PRINTF(
"%d", (
int)((val >> (22 - i)) & 1));
276 PRINTF(
"\nExp:%d => %d\n", e, e - 127);
282 PRINTF(
"Actual e=%d\n", e);
284 PRINTF(
"E after sub %d\n", e);
285 val = val | 1L << 23;
292 *value = sign ? -val : val;
Header file for the Contiki OMA LWM2M TLV