Skip to main content

Memory usage visualiser for embedded applications

Project description

Overview

Nesiac is a terminal tool for visualising memory usage in embedded programs.

As an example when run on the STM32 "HID_Standalone" project for STM32H747I-DISCO board:

image

Installation

Nesiac may be installed with pip via:

python -m pip install nesiac

The nesiac executable will then be made available in your python executables directory, which should be on your path.

Usage

Nesiac requires two files to do its analysis:

  • An ELF file for section and symbol info
  • A map file (in GCC style) for memory region info

If Nesiac is given a single path as argument, that path should be a directory containing exactly one .elf and one .map file. In that case, Nesiac will use those files for analysis.

Alternatively those paths may be overriden with the -e,--elf-file and -m,--map-file arguments.

Exporting a map file from GCC may be enabled with the -Wl,-Map=<FILE> flag.

If you are using a linker that cannot generate GCC style map files, then you can provide a dummy map file with the region info in the correct format:

Memory Configuration

Name             Origin             Length             Attributes
FLASH            0x0000000008000000 0x0000000000100000 xr
RAM              0x0000000024000000 0x0000000000020000 xrw
ITCMRAM          0x0000000000000000 0x0000000000010000 xrw
*default*        0x0000000000000000 0xffffffffffffffff

Languages

Nesiac will demangle C++ and Rust symbols when it finds them.

image

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nesiac-0.4.2.tar.gz (8.0 kB view details)

Uploaded Source

Built Distribution

nesiac-0.4.2-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file nesiac-0.4.2.tar.gz.

File metadata

  • Download URL: nesiac-0.4.2.tar.gz
  • Upload date:
  • Size: 8.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.3 Windows/10

File hashes

Hashes for nesiac-0.4.2.tar.gz
Algorithm Hash digest
SHA256 55622934ef3d00576a6e107605d873c098b7bf882515ba97e52fff8f961d1bed
MD5 3c955943e266f80999517ef634471332
BLAKE2b-256 f6820d54dfe055f03270072b16d5bfb17650f0ac314305f62e05fdab56c183e2

See more details on using hashes here.

File details

Details for the file nesiac-0.4.2-py3-none-any.whl.

File metadata

  • Download URL: nesiac-0.4.2-py3-none-any.whl
  • Upload date:
  • Size: 10.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.6.1 CPython/3.11.3 Windows/10

File hashes

Hashes for nesiac-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b5edb58c5c2145c6d12448208361abb8f6840e7421c7d344a0fb70fb3d17d5ac
MD5 410957298db9a56d9ca2ff4bdbb19b71
BLAKE2b-256 fd0a7b75981d18ecbed9d77de74ed55c014ca02ba8dd4554684b15a483f514f5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page