-
Notifications
You must be signed in to change notification settings - Fork 119
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: Add the SDIO inteface and the corresponding esp port
- Loading branch information
Showing
21 changed files
with
990 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
# The following lines of boilerplate have to be in your project's CMakeLists | ||
# in this exact order for cmake to work correctly | ||
cmake_minimum_required(VERSION 3.16) | ||
|
||
set(EXTRA_COMPONENT_DIRS ../../) | ||
include($ENV{IDF_PATH}/tools/cmake/project.cmake) | ||
project(esp32-sdio-ram-loader) | ||
|
||
# There are issues with ESP-IDF 4.4 and -Wunused-parameter | ||
if ("${IDF_VERSION_MAJOR}.${IDF_VERSION_MINOR}" VERSION_GREATER "4.4") | ||
idf_component_get_property(flasher esp-serial-flasher COMPONENT_LIB) | ||
|
||
target_compile_options(${flasher} | ||
PRIVATE | ||
-Wunused-parameter | ||
-Wshadow | ||
) | ||
endif() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
# Example of loading the program into RAM through SDIO | ||
|
||
## Overview | ||
|
||
This example demonstrates how to upload an app to RAM of an Espressif MCU (target) with SDIO download support from another MCU (host) using the `esp_serial_flasher`. In this case, another Espressif MCU is used as the host. Binaries to be uploaded to RAM from the host MCU to the target Espressif SoC can be found in `binaries/RAM_APP` folder and are converted into C-array during build process. | ||
|
||
The following steps are performed in order to re-program the targets memory: | ||
|
||
1. SDIO interface in slot 1 through which the binary will be transfered is initialized. | ||
2. The host puts the slave device into joint download mode and tries to connect by calling `esp_loader_connect()`. | ||
3. Then `esp_loader_mem_start()` is called for each segment in RAM. | ||
4. `esp_loader_mem_write()` function is called repeatedly for every segment until the whole binary image is transfered. | ||
5. `esp_loader_mem_finish()` is called with the binary entrypoint, telling the chip to start the uploaded program. | ||
6. UART2 is initialized for the connection to the target. | ||
7. Target output is continually read and printed out. | ||
|
||
## Hardware Required | ||
|
||
* Two development boards, one with an Espressif SoC with an SDMMC peripheral and one Espressif SoC with SDIO download support. Here is a short list of supported MCUs: | ||
1. ESP32-C6 | ||
* One or two USB cables for power supply and programming. | ||
|
||
> Note: Please check if your board has [possible issues](https://docs.espressif.com/projects/esp-idf/en/stable/esp32/api-reference/peripherals/sd_pullup_requirements.html) regarding SDIO requirements. | ||
## Hardware connection | ||
|
||
Table below shows connection between two Espressif MCUs. | ||
|
||
| Host (ESP32) | Target | | ||
|:------------:|:-------------:| | ||
| IO_18 | RESET | | ||
| IO_19 | BOOT | | ||
| IO_2 | D0 | | ||
| IO_4 | D1 | | ||
| IO_12 | D2 | | ||
| IO_13 | D3 | | ||
| IO_14 | CLK | | ||
| IO_15 | CMD | | ||
| IO_22 | UART0_RX | | ||
| IO_23 | UART0_TX | | ||
|
||
You can find the target SDIO pins for each target [here](https://docs.espressif.com/projects/esp-idf/en/stable/esp32/api-reference/peripherals/sdio_slave.html). | ||
|
||
SDIO pins CMD and DAT0-3 must be pulled up with adequate values, please take a look at the [SD Pull-up Requirements](https://docs.espressif.com/projects/esp-idf/en/stable/esp32/api-reference/peripherals/sd_pullup_requirements.html) for more info. | ||
|
||
> Note: For the ESP32 used as a reference, it is not possible to reassign SDIO pins, due to GPIO matrix limitations | ||
## Build and flash | ||
|
||
To run the example, type the following command: | ||
|
||
```CMake | ||
idf.py -p PORT flash monitor | ||
``` | ||
|
||
(To exit the serial monitor, type ``Ctrl-]``.) | ||
|
||
See the Getting Started Guide for full steps to configure and use ESP-IDF to build projects. | ||
|
||
## Example output | ||
|
||
Here is the example's console output: | ||
|
||
``` | ||
Connected to target | ||
I (701) sdio_ram_loader: Loading app to RAM ... | ||
Start loading | ||
Downloading 52296 bytes at 0x40800000... | ||
Downloading 312 bytes at 0x4080d990... | ||
Finished loading | ||
I (741) sdio_ram_loader: ******************************************** | ||
I (741) sdio_ram_loader: *** Logs below are print from slave .... *** | ||
I (751) sdio_ram_loader: ******************************************** | ||
Hello world! | ||
... | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
set(srcs main.c ../../common/example_common.c) | ||
set(include_dirs . ../../common) | ||
|
||
idf_component_register(SRCS ${srcs} | ||
INCLUDE_DIRS ${include_dirs}) | ||
set(target ${COMPONENT_LIB}) | ||
|
||
# Embed binaries into the app. | ||
# In ESP-IDF this can also be done using EMBED_FILES option of idf_component_register. | ||
# Here an external tool is used to make file embedding similar with other ports. | ||
include(${CMAKE_CURRENT_LIST_DIR}/../../common/bin2array.cmake) | ||
create_resources(${CMAKE_CURRENT_LIST_DIR}/../../binaries/RAM_APP ${CMAKE_BINARY_DIR}/binaries.c) | ||
set_property(SOURCE ${CMAKE_BINARY_DIR}/binaries.c PROPERTY GENERATED 1) | ||
target_sources(${target} PRIVATE ${CMAKE_BINARY_DIR}/binaries.c) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
/* Example of loading the program into RAM through SDIO | ||
This example code is in the Public Domain (or CC0 licensed, at your option.) | ||
Unless required by applicable law or agreed to in writing, this | ||
software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR | ||
CONDITIONS OF ANY KIND, either express or implied. | ||
*/ | ||
|
||
#include <sys/param.h> | ||
#include <string.h> | ||
#include "esp_err.h" | ||
#include "esp_log.h" | ||
#include "esp_task_wdt.h" | ||
#include "driver/sdmmc_host.h" | ||
#include "driver/uart.h" | ||
#include "driver/gpio.h" | ||
#include "esp32_sdio_port.h" | ||
#include "esp_loader.h" | ||
#include "example_common.h" | ||
#include "freertos/FreeRTOS.h" | ||
|
||
static const char *TAG = "sdio_ram_loader"; | ||
|
||
// Max line size | ||
#define BUF_LEN 128 | ||
static uint8_t buf[BUF_LEN] = {0}; | ||
|
||
void slave_monitor(void *arg) | ||
{ | ||
// Initialize UART | ||
uart_config_t uart_config = { | ||
.baud_rate = 115200, | ||
.data_bits = UART_DATA_8_BITS, | ||
.parity = UART_PARITY_DISABLE, | ||
.stop_bits = UART_STOP_BITS_1, | ||
.flow_ctrl = UART_HW_FLOWCTRL_DISABLE, | ||
#if ESP_IDF_VERSION >= ESP_IDF_VERSION_VAL(5, 0, 0) | ||
.source_clk = UART_SCLK_DEFAULT, | ||
#endif | ||
}; | ||
|
||
ESP_ERROR_CHECK(uart_param_config(UART_NUM_2, &uart_config)); | ||
|
||
ESP_ERROR_CHECK(uart_set_pin(UART_NUM_2, GPIO_NUM_22, GPIO_NUM_23, | ||
UART_PIN_NO_CHANGE, UART_PIN_NO_CHANGE)); | ||
|
||
ESP_ERROR_CHECK(uart_driver_install(UART_NUM_2, BUF_LEN * 4, BUF_LEN * 4, 0, NULL, 0)); | ||
|
||
while (1) { | ||
int rxBytes = uart_read_bytes(UART_NUM_2, buf, BUF_LEN, 100 / portTICK_PERIOD_MS); | ||
buf[rxBytes] = '\0'; | ||
printf("%s", buf); | ||
} | ||
} | ||
|
||
void app_main(void) | ||
{ | ||
example_ram_app_binary_t bin; | ||
|
||
// The ESP32 used for the example actually does not allow us to change the SD pins, | ||
// so setting them in the configuration is meaningless. | ||
// The pins used by the ESP32 are: | ||
// sdio_clk_pin - GPIO14 | ||
// sdio_d0_pin - GPIO2 | ||
// sdio_d1_pin - GPIO4 | ||
// sdio_d2_pin - GPIO12 | ||
// sdio_d3_pin - GPIO13 | ||
// sdio_cmd_pin - GPIO15 | ||
const loader_esp32_sdio_config_t config = { | ||
.slot = SDMMC_HOST_SLOT_1, | ||
.max_freq_khz = SDMMC_FREQ_DEFAULT, | ||
.reset_trigger_pin = GPIO_NUM_18, | ||
.boot_pin = GPIO_NUM_19, | ||
}; | ||
|
||
if (loader_port_esp32_sdio_init(&config) != ESP_LOADER_SUCCESS) { | ||
ESP_LOGE(TAG, " SDIO initialization failed."); | ||
abort(); | ||
} | ||
|
||
if (connect_to_target(0) == ESP_LOADER_SUCCESS) { | ||
get_example_ram_app_binary(esp_loader_get_target(), &bin); | ||
ESP_LOGI(TAG, "Loading app to RAM ..."); | ||
esp_loader_error_t err = load_ram_binary(bin.ram_app.data); | ||
if (err == ESP_LOADER_SUCCESS) { | ||
// Forward slave's serial output | ||
ESP_LOGI(TAG, "********************************************"); | ||
ESP_LOGI(TAG, "*** Logs below are print from slave .... ***"); | ||
ESP_LOGI(TAG, "********************************************"); | ||
xTaskCreate(slave_monitor, "slave_monitor", 2048, NULL, configMAX_PRIORITIES - 1, NULL); | ||
} else { | ||
ESP_LOGE(TAG, "Loading to RAM failed ..."); | ||
} | ||
} | ||
vTaskDelete(NULL); | ||
} |
8 changes: 8 additions & 0 deletions
8
examples/esp32_sdio_load_ram_example/pytest_esp32_sdio_load_ram_example.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
import pytest | ||
from pytest_embedded import Dut | ||
|
||
|
||
@pytest.mark.esp32 | ||
def test_esp32_sdio_load_ram_example(dut: Dut) -> None: | ||
dut.expect("Finished loading") | ||
dut.expect("Hello world!") |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
CONFIG_IDF_TARGET="esp32" | ||
CONFIG_SERIAL_FLASHER_INTERFACE_SDIO=y |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.