mirror of
				https://github.com/0xFEEDC0DE64/arduino-esp32.git
				synced 2025-10-31 14:11:42 +01:00 
			
		
		
		
	v2.0.0 Add support for ESP32S2 and update ESP-IDF to 4.4 (#4996)
This is very much still work in progress and much more will change before the final 2.0.0 Some APIs have changed. New libraries have been added. LittleFS included. Co-authored-by: Seon Rozenblum <seonr@3sprockets.com> Co-authored-by: Me No Dev <me-no-dev@users.noreply.github.com> Co-authored-by: geeksville <kevinh@geeksville.com> Co-authored-by: Mike Dunston <m_dunston@comcast.net> Co-authored-by: Unexpected Maker <seon@unexpectedmaker.com> Co-authored-by: Seon Rozenblum <seonr@3sprockets.com> Co-authored-by: microDev <70126934+microDev1@users.noreply.github.com> Co-authored-by: tobozo <tobozo@users.noreply.github.com> Co-authored-by: bobobo1618 <bobobo1618@users.noreply.github.com> Co-authored-by: lorol <lorolouis@gmail.com> Co-authored-by: geeksville <kevinh@geeksville.com> Co-authored-by: Limor "Ladyada" Fried <limor@ladyada.net> Co-authored-by: Sweety <switi.mhaiske@espressif.com> Co-authored-by: Loick MAHIEUX <loick111@gmail.com> Co-authored-by: Larry Bernstone <lbernstone@gmail.com> Co-authored-by: Valerii Koval <valeros@users.noreply.github.com> Co-authored-by: 快乐的我531 <2302004040@qq.com> Co-authored-by: chegewara <imperiaonline4@gmail.com> Co-authored-by: Clemens Kirchgatterer <clemens@1541.org> Co-authored-by: Aron Rubin <aronrubin@gmail.com> Co-authored-by: Pete Lewis <601236+lewispg228@users.noreply.github.com>
This commit is contained in:
		| @@ -0,0 +1,136 @@ | ||||
| // Copyright 2015-2017 Espressif Systems (Shanghai) PTE LTD | ||||
| // | ||||
| // Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| // you may not use this file except in compliance with the License. | ||||
| // You may obtain a copy of the License at | ||||
| // | ||||
| //     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| // | ||||
| // Unless required by applicable law or agreed to in writing, software | ||||
| // distributed under the License is distributed on an "AS IS" BASIS, | ||||
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
|  | ||||
| #ifndef _wear_levelling_H_ | ||||
| #define _wear_levelling_H_ | ||||
|  | ||||
| #include "esp_log.h" | ||||
| #include "esp_partition.h" | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| extern "C" { | ||||
| #endif | ||||
|  | ||||
| /** | ||||
| * @brief wear levelling handle | ||||
| */ | ||||
| typedef int32_t wl_handle_t; | ||||
|  | ||||
| #define WL_INVALID_HANDLE -1 | ||||
|  | ||||
| /** | ||||
| * @brief Mount WL for defined partition | ||||
| * | ||||
| * @param partition that will be used for access | ||||
| * @param out_handle handle of the WL instance | ||||
| * | ||||
| * @return | ||||
| *       - ESP_OK, if the allocation was successfully; | ||||
| *       - ESP_ERR_INVALID_ARG, if WL allocation was unsuccessful; | ||||
| *       - ESP_ERR_NO_MEM, if there was no memory to allocate WL components; | ||||
| */ | ||||
| esp_err_t wl_mount(const esp_partition_t *partition, wl_handle_t *out_handle); | ||||
|  | ||||
| /** | ||||
| * @brief Unmount WL for defined partition | ||||
| * | ||||
| * @param handle WL partition handle | ||||
| * | ||||
| * @return | ||||
| *       - ESP_OK, if the operation completed successfully; | ||||
| *       - or one of error codes from lower-level flash driver. | ||||
| */ | ||||
| esp_err_t wl_unmount(wl_handle_t handle); | ||||
|  | ||||
| /** | ||||
| * @brief Erase part of the WL storage | ||||
| * | ||||
| * @param handle WL handle that are related to the partition | ||||
| * @param start_addr Address where erase operation should start. Must be aligned | ||||
| *                   to the result of function wl_sector_size(...). | ||||
| * @param size Size of the range which should be erased, in bytes. | ||||
| *                   Must be divisible by result of function wl_sector_size(...).. | ||||
| * | ||||
| * @return | ||||
| *       - ESP_OK, if the range was erased successfully; | ||||
| *       - ESP_ERR_INVALID_ARG, if iterator or dst are NULL; | ||||
| *       - ESP_ERR_INVALID_SIZE, if erase would go out of bounds of the partition; | ||||
| *       - or one of error codes from lower-level flash driver. | ||||
| */ | ||||
| esp_err_t wl_erase_range(wl_handle_t handle, size_t start_addr, size_t size); | ||||
|  | ||||
| /** | ||||
| * @brief Write data to the WL storage | ||||
| * | ||||
| * Before writing data to flash, corresponding region of flash needs to be erased. | ||||
| * This can be done using wl_erase_range function. | ||||
| * | ||||
| * @param handle WL handle that are related to the partition | ||||
| * @param dest_addr Address where the data should be written, relative to the | ||||
| *                   beginning of the partition. | ||||
| * @param src Pointer to the source buffer.  Pointer must be non-NULL and | ||||
| *            buffer must be at least 'size' bytes long. | ||||
| * @param size Size of data to be written, in bytes. | ||||
| * | ||||
| * @note Prior to writing to WL storage, make sure it has been erased with | ||||
| *       wl_erase_range call. | ||||
| * | ||||
| * @return | ||||
| *       - ESP_OK, if data was written successfully; | ||||
| *       - ESP_ERR_INVALID_ARG, if dst_offset exceeds partition size; | ||||
| *       - ESP_ERR_INVALID_SIZE, if write would go out of bounds of the partition; | ||||
| *       - or one of error codes from lower-level flash driver. | ||||
| */ | ||||
| esp_err_t wl_write(wl_handle_t handle, size_t dest_addr, const void *src, size_t size); | ||||
|  | ||||
| /** | ||||
| * @brief Read data from the WL storage | ||||
| * | ||||
| * @param handle WL module instance that was initialized before | ||||
| * @param dest Pointer to the buffer where data should be stored. | ||||
| *            Pointer must be non-NULL and buffer must be at least 'size' bytes long. | ||||
| * @param src_addr Address of the data to be read, relative to the | ||||
| *                   beginning of the partition. | ||||
| * @param size Size of data to be read, in bytes. | ||||
| * | ||||
| * @return | ||||
| *       - ESP_OK, if data was read successfully; | ||||
| *       - ESP_ERR_INVALID_ARG, if src_offset exceeds partition size; | ||||
| *       - ESP_ERR_INVALID_SIZE, if read would go out of bounds of the partition; | ||||
| *       - or one of error codes from lower-level flash driver. | ||||
| */ | ||||
| esp_err_t wl_read(wl_handle_t handle, size_t src_addr, void *dest, size_t size); | ||||
|  | ||||
| /** | ||||
| * @brief Get size of the WL storage | ||||
| * | ||||
| * @param handle WL module handle that was initialized before | ||||
| * @return usable size, in bytes | ||||
| */ | ||||
| size_t wl_size(wl_handle_t handle); | ||||
|  | ||||
| /** | ||||
| * @brief Get sector size of the WL instance | ||||
| * | ||||
| * @param handle WL module handle that was initialized before | ||||
| * @return sector size, in bytes | ||||
| */ | ||||
| size_t wl_sector_size(wl_handle_t handle); | ||||
|  | ||||
|  | ||||
| #ifdef __cplusplus | ||||
| } // extern "C" | ||||
| #endif | ||||
|  | ||||
| #endif // _wear_levelling_H_ | ||||
		Reference in New Issue
	
	Block a user