2022-08-23 12:31:53 +08:00
|
|
|
/*
|
2023-06-08 16:12:01 +08:00
|
|
|
* SPDX-FileCopyrightText: 2015-2023 Espressif Systems (Shanghai) CO LTD
|
2022-08-23 12:31:53 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
2020-09-01 17:06:22 +08:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "esp_err.h"
|
|
|
|
#include "sdkconfig.h"
|
|
|
|
|
2023-06-08 16:12:01 +08:00
|
|
|
#if CONFIG_SPI_FLASH_ENABLE_COUNTERS || defined __DOXYGEN__
|
2020-09-01 17:06:22 +08:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Structure holding statistics for one type of operation
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2023-06-08 16:12:01 +08:00
|
|
|
uint32_t count; /*!< number of times operation was executed */
|
|
|
|
uint32_t time; /*!< total time taken, in microseconds */
|
|
|
|
uint32_t bytes; /*!< total number of bytes */
|
2022-08-23 12:31:53 +08:00
|
|
|
} esp_flash_counter_t;
|
2020-09-01 17:06:22 +08:00
|
|
|
|
2023-06-08 16:12:01 +08:00
|
|
|
/**
|
|
|
|
* Structure for counters of flash actions
|
|
|
|
*/
|
2020-09-01 17:06:22 +08:00
|
|
|
typedef struct {
|
2023-06-08 16:12:01 +08:00
|
|
|
esp_flash_counter_t read; /*!< counters for read action, like `esp_flash_read`*/
|
|
|
|
esp_flash_counter_t write; /*!< counters for write action, like `esp_flash_write`*/
|
|
|
|
esp_flash_counter_t erase; /*!< counters for erase action, like `esp_flash_erase`*/
|
2022-08-23 12:31:53 +08:00
|
|
|
} esp_flash_counters_t;
|
|
|
|
|
|
|
|
// for deprecate old api
|
|
|
|
typedef esp_flash_counter_t spi_flash_counter_t;
|
|
|
|
typedef esp_flash_counters_t spi_flash_counters_t;
|
2020-09-01 17:06:22 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Reset SPI flash operation counters
|
|
|
|
*/
|
2022-08-23 12:31:53 +08:00
|
|
|
void esp_flash_reset_counters(void);
|
|
|
|
void spi_flash_reset_counters(void) __attribute__((deprecated("Please use 'esp_flash_reset_counters' instead")));
|
2020-09-01 17:06:22 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Print SPI flash operation counters
|
|
|
|
*/
|
2022-08-23 12:31:53 +08:00
|
|
|
void esp_flash_dump_counters(FILE* stream);
|
|
|
|
void spi_flash_dump_counters(void) __attribute__((deprecated("Please use 'esp_flash_dump_counters' instead")));
|
2020-09-01 17:06:22 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Return current SPI flash operation counters
|
|
|
|
*
|
2022-08-23 12:31:53 +08:00
|
|
|
* @return pointer to the esp_flash_counters_t structure holding values
|
2020-09-01 17:06:22 +08:00
|
|
|
* of the operation counters
|
|
|
|
*/
|
2022-08-23 12:31:53 +08:00
|
|
|
const esp_flash_counters_t* esp_flash_get_counters(void);
|
|
|
|
const spi_flash_counters_t* spi_flash_get_counters(void) __attribute__((deprecated("Please use 'esp_flash_get_counters' instead")));
|
2020-09-01 17:06:22 +08:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2023-06-08 16:12:01 +08:00
|
|
|
#endif //CONFIG_SPI_FLASH_ENABLE_COUNTERS || defined __DOXYGEN__
|