2018-09-05 02:39:50 +02:00
|
|
|
/*
|
2019-09-05 13:35:58 +02:00
|
|
|
* Copyright (C) 2019 Gunar Schorcht
|
2018-09-05 02:39:50 +02:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup cpu_esp8266
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Implementation of some tools
|
|
|
|
*
|
|
|
|
* @author Gunar Schorcht <gunar@schorcht.net>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2018-12-26 15:42:09 +01:00
|
|
|
#include <malloc.h>
|
2018-09-05 02:39:50 +02:00
|
|
|
|
2019-09-05 13:35:58 +02:00
|
|
|
#ifdef MCU_ESP8266
|
|
|
|
#include <inttypes.h>
|
|
|
|
#include "sdk/sdk.h"
|
|
|
|
#else
|
|
|
|
#include "rom/ets_sys.h"
|
|
|
|
#endif
|
|
|
|
|
2018-09-05 02:39:50 +02:00
|
|
|
#include "esp/common_macros.h"
|
|
|
|
#include "tools.h"
|
|
|
|
|
2018-12-26 15:42:09 +01:00
|
|
|
extern void malloc_stats (void);
|
|
|
|
extern unsigned int get_free_heap_size (void);
|
|
|
|
extern uint8_t _eheap; /* end of heap (defined in esp8266.riot-os.app.ld) */
|
|
|
|
extern uint8_t _sheap; /* start of heap (defined in esp8266.riot-os.app.ld) */
|
|
|
|
|
|
|
|
void print_meminfo (void)
|
|
|
|
{
|
|
|
|
struct mallinfo minfo = mallinfo();
|
|
|
|
ets_printf("heap: %lu (free %lu) byte\n", &_eheap - &_sheap, get_free_heap_size());
|
|
|
|
ets_printf("sysmem: %d (used %d, free %d)\n", minfo.arena, minfo.uordblks, minfo.fordblks);
|
|
|
|
}
|
|
|
|
|
2018-09-05 02:39:50 +02:00
|
|
|
void esp_hexdump (const void* addr, uint32_t num, char width, uint8_t per_line)
|
|
|
|
{
|
|
|
|
uint32_t count = 0;
|
|
|
|
uint32_t size;
|
|
|
|
|
|
|
|
uint8_t* addr8 = (uint8_t*) addr;
|
|
|
|
uint16_t* addr16 = (uint16_t*)addr;
|
|
|
|
uint32_t* addr32 = (uint32_t*)addr;
|
|
|
|
uint64_t* addr64 = (uint64_t*)addr;
|
|
|
|
|
|
|
|
switch (width) {
|
|
|
|
case 'b': size = 1; break;
|
|
|
|
case 'h': size = 2; break;
|
|
|
|
case 'w': size = 4; break;
|
|
|
|
case 'g': size = 8; break;
|
|
|
|
default : size = 1; break;
|
|
|
|
}
|
|
|
|
|
|
|
|
while (count < num) {
|
|
|
|
if (count % per_line == 0) {
|
2019-09-05 13:35:58 +02:00
|
|
|
ets_printf ("%08" PRIx32 ": ", (uint32_t)((uint8_t*)addr+count*size));
|
2018-09-05 02:39:50 +02:00
|
|
|
}
|
|
|
|
switch (width) {
|
2019-09-05 13:35:58 +02:00
|
|
|
case 'b': ets_printf("%02" PRIx8 " ", addr8[count++]); break;
|
|
|
|
case 'h': ets_printf("%04" PRIx16 " ", addr16[count++]); break;
|
|
|
|
case 'w': ets_printf("%08" PRIx32 " ", addr32[count++]); break;
|
|
|
|
case 'g': ets_printf("%016" PRIx64 " ", addr64[count++]); break;
|
|
|
|
default : ets_printf("."); count++; break;
|
2018-09-05 02:39:50 +02:00
|
|
|
}
|
|
|
|
if (count % per_line == 0) {
|
2019-09-05 13:35:58 +02:00
|
|
|
ets_printf ("\n");
|
2018-09-05 02:39:50 +02:00
|
|
|
}
|
|
|
|
}
|
2019-09-05 13:35:58 +02:00
|
|
|
ets_printf ("\n");
|
2018-09-05 02:39:50 +02:00
|
|
|
}
|