Fix: respect signed integers' length when printing in hex base
[babeltrace.git] / formats / ctf-text / types / integer.c
index 0886b0628fffc6a5ffb8784f8fb610b401e41fd3..9602a902a766d8673a14e8896ee91bc59e3d34e7 100644 (file)
@@ -32,7 +32,7 @@
 #include <stdint.h>
 #include <babeltrace/bitfield.h>
 
-int ctf_text_integer_write(struct stream_pos *ppos, struct definition *definition)
+int ctf_text_integer_write(struct bt_stream_pos *ppos, struct bt_definition *definition)
 {
        struct definition_integer *integer_definition =
                container_of(definition, struct definition_integer, p);
@@ -112,10 +112,15 @@ int ctf_text_integer_write(struct stream_pos *ppos, struct definition *definitio
        {
                uint64_t v;
 
-               if (!integer_declaration->signedness)
+               if (!integer_declaration->signedness) {
                        v = integer_definition->value._unsigned;
-               else
+               } else {
+                       /* Round length to the nearest nibble */
+                       uint8_t rounded_len = ((integer_declaration->len + 3) & ~0x3);
+
                        v = (uint64_t) integer_definition->value._signed;
+                       v &= ((uint64_t) 1 << rounded_len) - 1;
+               }
 
                fprintf(pos->fp, "0x%" PRIX64, v);
                break;
This page took 0.022698 seconds and 4 git commands to generate.