espressif/gprof

0.1.0

uploaded 11 months ago
Espressif GNU Profiler for ESP-IDF

readme

## Description

[![Component Registry](https://components.espressif.com/components/espressif/gprof/badge.svg)](https://components.espressif.com/components/espressif/gprof)

The Espressif GNU Profiler is used to evaluate the time and proportion consumed by various parts of the running program, enabling developers to optimize the software based on this information.

This software supports the main functionality of the GNU Profiler. Additionally, it also supports the following features:

Gathering information about calling OS APIs, such as sleep and read, these are specifically for Xtensa CPU.
Application to user-specified components in ESP-IDF, without the need to apply it to all components.
Storing information in a partition with a type of data and a subtype of 0x3a.

However, this software also has the following usage limitations:

It cannot be applied to kernel components like FreeRTOS, libc, hardware drivers, and so on.
It cannot gather information on functions that reside in IRAM.
It does not support multi-thread mode; it can only gather information from the thread that calls esp_gprof_init.

### Usage

Add a dependency on this component in your component or project's idf_component.yml file.

    ```yml
    dependencies:
      espressif/gprof: "0.*"
    ```

To use this feature, including the required CMake file in your project's CMakeLists.txt file after the line project(XXXX).

```cmake
project(XXXX)

include(gprof)
```

Enable GNU Profiler in the menuconfig and select target components in ESP-IDF as follows:

```
Component config  --->
    Espressif GNU Profiler(GProf)  --->
        [*] Enable Espressif GNU Profiler(GProf)
        (component_a;component_b) Select components for GProf
```

Each component must be separated by a ";" and cannot contain irrelevant symbols such as spaces.

Use your partition table that includes the following partition (type is data, and subtype is 0x3a):

```
# Name,   Type, SubType, Offset,  Size, Flags
gprof,    data, 0x3a,           , 0x1000,
```

You can increase the size if your selected components are large or numerous.

5. Add API calls in your project as follows:

```c
#include "gprof.h"

    ESP_ERROR_CHECK(esp_gprof_init());
    
    // Your Code

    ESP_ERROR_CHECK(esp_gprof_save());
    esp_gprof_deinit();
```

6. Build and run your project, and wait until the terminal shows the following information:

```
esp_gprof: GProf data is saved successfully
```

7. Obtain information from GNU Profiler using the following command:

```sh
idf.py gprof
```

If you want to generate a GNU Profiler picture in PNG format(Only support Ubuntu and MacOS), you need to install the required tools first using the following commands:

- Ubuntu:

```sh
sudo apt install graphviz
pip3 install gprof2dot
```

- MacOS:

```sh
brew install graphviz
pip3 install gprof2dot
```

Then, use the following command to generate the picture of your project. The picture will be located at build/{PROJECT_NAME}.gprof.png

```sh
idf.py gprof-graphic
```

### Adding the Component to Your Project

Please use the component manager command add-dependency to add the gprof component as a dependency in your project. During the CMake step, the component will be downloaded automatically.

```
idf.py add-dependency "espressif/gprof=*"
```

### Examples

Please use the component manager command create-project-from-example to create a project from the example template.

```
idf.py create-project-from-example "espressif/gprof=*:gprof_simple"
```

This command will download the example gprof_simple into the current folder. You can navigate into it to build and flash the example.

Alternatively, you can download examples from the esp-iot-solution repository:
1. [gprof_simple](https://github.com/espressif/esp-iot-solution/tree/master/examples/gprof/gprof_simple)

changelog

# ChangeLog

## v0.1.0 - 2023-05-18

* Add basic GProf component

Links

Supports all targets

License unspecified

To add this component to your project, run:

idf.py add-dependency "espressif/gprof^0.1.0"

or download archive

Dependencies

  • espressif/cmake_utilities 0.*
  • ESP-IDF >=4.4.3
  • Examples:

    gprof_simple

    To create a project from this example, run:

    idf.py create-project-from-example "espressif/gprof^0.1.0:gprof_simple"

    or download archive

    Stats

    • Downloaded in total
      Downloaded in total 22 times
    • Downloaded this version
      This version: 22 times

    Badge

    espressif/gprof version: 0.1.0
    |