2017-12-19 15:49:03 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2010-2014 Intel Corporation
|
2013-06-03 00:00:00 +00:00
|
|
|
*/
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <rte_hexdump.h>
|
|
|
|
#include <rte_string_fns.h>
|
|
|
|
|
|
|
|
#define LINE_LEN 128
|
|
|
|
|
|
|
|
void
|
2019-04-02 08:23:49 -07:00
|
|
|
rte_hexdump(FILE *f, const char *title, const void *buf, unsigned int len)
|
2013-06-03 00:00:00 +00:00
|
|
|
{
|
2019-04-02 08:23:49 -07:00
|
|
|
unsigned int i, out, ofs;
|
|
|
|
const unsigned char *data = buf;
|
|
|
|
char line[LINE_LEN]; /* space needed 8+16*3+3+16 == 75 */
|
2013-06-03 00:00:00 +00:00
|
|
|
|
2019-04-02 08:23:49 -07:00
|
|
|
fprintf(f, "%s at [%p], len=%u\n",
|
|
|
|
title ? : " Dump data", data, len);
|
|
|
|
ofs = 0;
|
|
|
|
while (ofs < len) {
|
|
|
|
/* format the line in the buffer */
|
|
|
|
out = snprintf(line, LINE_LEN, "%08X:", ofs);
|
2019-04-02 08:23:50 -07:00
|
|
|
for (i = 0; i < 16; i++) {
|
|
|
|
if (ofs + i < len)
|
|
|
|
snprintf(line + out, LINE_LEN - out,
|
2019-04-02 08:23:49 -07:00
|
|
|
" %02X", (data[ofs + i] & 0xff));
|
2019-04-02 08:23:50 -07:00
|
|
|
else
|
|
|
|
strcpy(line + out, " ");
|
|
|
|
out += 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-04-02 08:23:49 -07:00
|
|
|
for (; i <= 16; i++)
|
|
|
|
out += snprintf(line + out, LINE_LEN - out, " | ");
|
|
|
|
|
|
|
|
for (i = 0; ofs < len && i < 16; i++, ofs++) {
|
|
|
|
unsigned char c = data[ofs];
|
2013-06-03 00:00:00 +00:00
|
|
|
|
2019-04-02 08:23:49 -07:00
|
|
|
if (c < ' ' || c > '~')
|
|
|
|
c = '.';
|
|
|
|
out += snprintf(line + out, LINE_LEN - out, "%c", c);
|
|
|
|
}
|
|
|
|
fprintf(f, "%s\n", line);
|
|
|
|
}
|
|
|
|
fflush(f);
|
|
|
|
}
|
2013-06-03 00:00:00 +00:00
|
|
|
|
|
|
|
void
|
2019-04-02 08:23:49 -07:00
|
|
|
rte_memdump(FILE *f, const char *title, const void *buf, unsigned int len)
|
2013-06-03 00:00:00 +00:00
|
|
|
{
|
2019-04-02 08:23:49 -07:00
|
|
|
unsigned int i, out;
|
|
|
|
const unsigned char *data = buf;
|
|
|
|
char line[LINE_LEN];
|
2013-06-03 00:00:00 +00:00
|
|
|
|
2019-04-02 08:23:49 -07:00
|
|
|
if (title)
|
|
|
|
fprintf(f, "%s: ", title);
|
2013-06-03 00:00:00 +00:00
|
|
|
|
2019-04-02 08:23:49 -07:00
|
|
|
line[0] = '\0';
|
|
|
|
for (i = 0, out = 0; i < len; i++) {
|
|
|
|
/* Make sure we do not overrun the line buffer length. */
|
|
|
|
if (out >= LINE_LEN - 4) {
|
2014-05-02 16:42:56 -07:00
|
|
|
fprintf(f, "%s", line);
|
2013-06-03 00:00:00 +00:00
|
|
|
out = 0;
|
|
|
|
line[out] = '\0';
|
|
|
|
}
|
2019-04-02 08:23:49 -07:00
|
|
|
out += snprintf(line + out, LINE_LEN - out, "%02x%s",
|
|
|
|
(data[i] & 0xff), ((i + 1) < len) ? ":" : "");
|
|
|
|
}
|
|
|
|
if (out > 0)
|
|
|
|
fprintf(f, "%s", line);
|
|
|
|
fprintf(f, "\n");
|
2013-06-03 00:00:00 +00:00
|
|
|
|
2019-04-02 08:23:49 -07:00
|
|
|
fflush(f);
|
2013-06-03 00:00:00 +00:00
|
|
|
}
|