Skip to main content

Firmware memory budgets and size-regression checks for CI. Your binary stays local.

Project description

memprobe

Firmware memory budgets and size-regression checks for CI, from the command line.

memprobe reads the section and symbol table out of your ELF locally and sends only that metadata to the memprobe API, which returns the analysis. Your binary never leaves your machine — only the sizes and symbol names it contains are sent, the same information readelf and nm print.

pip install memprobe

Quick start

  1. Create an API key at https://memprobe.dev (Account → API keys).

  2. Point the CLI at it:

    memprobe config set --key mp_live_xxxxxxxx
    
  3. Check a build against budgets:

    memprobe init            # writes a memprobe.toml with flash/ram budgets
    memprobe check build/firmware.elf
    

    check exits non-zero when a budget is exceeded, so it gates a CI job.

Commands

Command What it does
memprobe analyze <elf> Size summary: flash/ram totals, biggest sections and symbols.
memprobe check <elf> Fail (exit 1) if a budget in memprobe.toml is exceeded. The CI gate.
memprobe diff <old> <new> Size change between two builds, with per-symbol deltas. --format markdown for PR comments.
memprobe init Scaffold memprobe.toml with flash/ram budgets.
memprobe account Show your plan and this month's usage.
memprobe config set --key <key> [--server <url>] Store your API key (in ~/.memprobe/config.json).
memprobe config show Show the current key (masked) and server.

MEMPROBE_API_KEY and MEMPROBE_SERVER environment variables override the stored config, which is convenient in CI.

CI

Because memprobe check exits non-zero when a budget is exceeded, it works as a gate in any CI system. Run it as a build step with MEMPROBE_API_KEY set as a secret:

pip install memprobe
memprobe check build/firmware.elf

What runs where

Local (this tool) memprobe API
Reads your ELF yes never sees the binary
Extracts sections/symbols yes (via pyelftools)
Budget / diff / bloat analysis yes

This package contains no analysis logic and no proprietary code — it's a thin, open-source client. The deeper analysis (call graph, dead-code, stack usage, source attribution) lives in the web app at https://memprobe.dev.

License

MIT

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

memprobe-0.1.0.tar.gz (12.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

memprobe-0.1.0-py3-none-any.whl (12.3 kB view details)

Uploaded Python 3

File details

Details for the file memprobe-0.1.0.tar.gz.

File metadata

  • Download URL: memprobe-0.1.0.tar.gz
  • Upload date:
  • Size: 12.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for memprobe-0.1.0.tar.gz
Algorithm Hash digest
SHA256 36a8fd8f06b271ea4a0611bdde805b5c26c97d1121f00a69c12cd846772af12c
MD5 469c582b34281f6c661229999267a8ee
BLAKE2b-256 aaa89ebf5b6239267d90810a0d9895191682ed759aa3b4efcee12856961207f1

See more details on using hashes here.

Provenance

The following attestation bundles were made for memprobe-0.1.0.tar.gz:

Publisher: publish.yml on memprobe-dev/memprobe_api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file memprobe-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: memprobe-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 12.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for memprobe-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 935b8028e333ed27396505be6e4cbb593c618f1472abc1ddce31601f33189d7d
MD5 15397b8f04af4dc9e7ce652899dc2740
BLAKE2b-256 c7844660371597d1427cebebff0d29dba21137f232763510b82cdeece2bc643d

See more details on using hashes here.

Provenance

The following attestation bundles were made for memprobe-0.1.0-py3-none-any.whl:

Publisher: publish.yml on memprobe-dev/memprobe_api

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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