summaryrefslogtreecommitdiff
path: root/src/debug.h
diff options
context:
space:
mode:
authorKévin Le Gouguec <kevin.legouguec@airbus.com>2018-11-27 08:58:46 +0100
committerKévin Le Gouguec <kevin.legouguec@airbus.com>2018-11-27 08:58:46 +0100
commitd14739644394986cb584acb45ed9b214dff1c501 (patch)
tree3bd49b3feeafcd3aeb23a779d161f67664a1eaec /src/debug.h
parent89ff89643cf6682742730c3f65b572debe2c2ab1 (diff)
downloadlilliput-ae-implem-d14739644394986cb584acb45ed9b214dff1c501.tar.xz
Mise en commun du code TBC et ΘCB3
Il ne devrait pas varier selon les paramètres AFAICT.
Diffstat (limited to 'src/debug.h')
-rw-r--r--src/debug.h50
1 files changed, 50 insertions, 0 deletions
diff --git a/src/debug.h b/src/debug.h
new file mode 100644
index 0000000..87140e5
--- /dev/null
+++ b/src/debug.h
@@ -0,0 +1,50 @@
+#ifndef DEBUG_H
+#define DEBUG_H
+
+#include <inttypes.h>
+#include <stdio.h>
+
+
+static inline void debug_dump_lanes(FILE *output, const char *header, size_t len, const uint8_t buf[len], int indent)
+{
+ if (!output)
+ {
+ return;
+ }
+
+ fprintf(output, "%s\n", header);
+
+ for (size_t line=0; line<len/8; line++)
+ {
+ fprintf(output, "%*s", indent, "");
+ for (size_t b=0; b<8; b++)
+ {
+ /* start with MSB */
+ size_t byte_index = len-(1+line*8+b);
+ fprintf(output, "%*s%02x", 5, "", buf[byte_index]);
+ }
+ fprintf(output, "\n");
+ }
+ fprintf(output, "\n");
+}
+
+static inline void debug_dump_buffer(FILE *output, const char *header, size_t len, const uint8_t buf[len], int indent)
+{
+ if (!output)
+ {
+ return;
+ }
+
+ fprintf(output, "%s\n", header);
+
+ fprintf(output, "%*s", indent, "");
+ for (size_t b=0; b<len; b++)
+ {
+ /* start with MSB */
+ size_t byte_index = len-1-b;
+ fprintf(output, "%*s%02x", 5, "", buf[byte_index]);
+ }
+ fprintf(output, "\n");
+}
+
+#endif /* DEBUG_H */