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.3.1.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

nesiac-0.3.1-py3-none-any.whl (9.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: nesiac-0.3.1.tar.gz
  • Upload date:
  • Size: 7.8 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.3.1.tar.gz
Algorithm Hash digest
SHA256 d68e97a88a0f10528b1b8f4510e1b5c5e4eeb2d952c83aceec2cb02af3a65a22
MD5 63ecc250a883a3cc883e76788fb078a1
BLAKE2b-256 542cb23294602527b4116036d8db3abbe817ff2b817633c898273b3efecef09c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: nesiac-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 9.9 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.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7b7d1d6a0da581033af807feb13012d91e4465f33f96253971575372e66db5a7
MD5 794be86cb6d880592ef39769dd4bcddf
BLAKE2b-256 965a35c14ef46cecc72afdc9494015bc04977c24b5b54843485a8b02a9485e25

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