瀏覽代碼

Rolling 20210327

jomjol 4 年之前
父節點
當前提交
98dfba0640
共有 6 個文件被更改,包括 61 次插入20 次删除
  1. 3 0
      README.md
  2. 52 14
      code/main/main.cpp
  3. 3 3
      code/main/version.cpp
  4. 3 3
      code/version.cpp
  5. 二進制
      firmware/bootloader.bin
  6. 二進制
      firmware/firmware.bin

+ 3 - 0
README.md

@@ -39,7 +39,10 @@ If you would like to support the developer with a cup of coffee you can do that
 
 **General remark:** Beside the `firmware.bin`, typically also the content of `/html` needs to be updated!
 
+##### Rolling - (2021-03-27)
 
+* Update SD-card handling (more stable support of different types)
+* based on v6.5.0
 
 ##### 6.5.0 Image Processing in Memory - (2021-03-25)
 

+ 52 - 14
code/main/main.cpp

@@ -25,7 +25,14 @@
 #include "ClassControllCamera.h"
 #include "server_main.h"
 #include "server_camera.h"
+
+
+#define __SD_USE_ONE_LINE_MODE__
+
+#ifdef __SD_USE_ONE_LINE_MODE__
 #include "server_GPIO.h"
+#endif
+
 static const char *TAGMAIN = "connect_wlan_main";
 
 #define FLASH_GPIO GPIO_NUM_4
@@ -37,34 +44,61 @@ void Init_NVS_SDCard()
         ESP_ERROR_CHECK(nvs_flash_erase());
         ret = nvs_flash_init();
     }
+////////////////////////////////////////////////
 
-    ESP_LOGI(TAGMAIN, "Initializing SD card");
+    ESP_LOGI(TAG, "Using SDMMC peripheral");
     sdmmc_host_t host = SDMMC_HOST_DEFAULT();
-    host.flags = SDMMC_HOST_FLAG_1BIT;    
-//    sdmmc_host_t host = SDMMC_HOST_SLOT_1();
-//    host.flags = SDMMC_HOST_FLAG_1BIT;
-    sdmmc_slot_config_t slot_config = SDMMC_SLOT_CONFIG_DEFAULT();
-    slot_config.width = 1;  // 1 line SD mode
-    
-    esp_vfs_fat_sdmmc_mount_config_t mount_config = { };
-    mount_config.format_if_mount_failed = false;
-    mount_config.max_files = 5;
 
-    gpio_set_pull_mode((gpio_num_t) 15, GPIO_PULLUP_ONLY);   // CMD, needed in 4- and 1- line modes
-    gpio_set_pull_mode((gpio_num_t) 2, GPIO_PULLUP_ONLY);    // D0, needed in 4- and 1-line modes
+    // This initializes the slot without card detect (CD) and write protect (WP) signals.
+    // Modify slot_config.gpio_cd and slot_config.gpio_wp if your board has these signals.
+    sdmmc_slot_config_t slot_config = SDMMC_SLOT_CONFIG_DEFAULT();
 
+    // To use 1-line SD mode, uncomment the following line:
+
+#ifdef __SD_USE_ONE_LINE_MODE__
+    slot_config.width = 1;
+#endif
+
+    // GPIOs 15, 2, 4, 12, 13 should have external 10k pull-ups.
+    // Internal pull-ups are not sufficient. However, enabling internal pull-ups
+    // does make a difference some boards, so we do that here.
+    gpio_set_pull_mode(GPIO_NUM_15, GPIO_PULLUP_ONLY);   // CMD, needed in 4- and 1- line modes
+    gpio_set_pull_mode(GPIO_NUM_2, GPIO_PULLUP_ONLY);    // D0, needed in 4- and 1-line modes
+    gpio_set_pull_mode(GPIO_NUM_4, GPIO_PULLUP_ONLY);    // D1, needed in 4-line mode only
+    gpio_set_pull_mode(GPIO_NUM_12, GPIO_PULLUP_ONLY);   // D2, needed in 4-line mode only
+    gpio_set_pull_mode(GPIO_NUM_13, GPIO_PULLUP_ONLY);   // D3, needed in 4- and 1-line modes
+
+    // Options for mounting the filesystem.
+    // If format_if_mount_failed is set to true, SD card will be partitioned and
+    // formatted in case when mounting fails.
+    esp_vfs_fat_sdmmc_mount_config_t mount_config = {
+        .format_if_mount_failed = false,
+        .max_files = 5,
+        .allocation_unit_size = 16 * 1024
+    };
+
+    // Use settings defined above to initialize SD card and mount FAT filesystem.
+    // Note: esp_vfs_fat_sdmmc_mount is an all-in-one convenience function.
+    // Please check its source code and implement error recovery when developing
+    // production applications.
     sdmmc_card_t* card;
     ret = esp_vfs_fat_sdmmc_mount("/sdcard", &host, &slot_config, &mount_config, &card);
+
     if (ret != ESP_OK) {
         if (ret == ESP_FAIL) {
-            ESP_LOGE(TAGMAIN, "Failed to mount filesystem. If you want the card to be formatted, set format_if_mount_failed = true.");
+            ESP_LOGE(TAG, "Failed to mount filesystem. "
+                "If you want the card to be formatted, set format_if_mount_failed = true.");
         } else {
-            ESP_LOGE(TAGMAIN, "Failed to initialize the card (%d). Make sure SD card lines have pull-up resistors in place.", ret);
+            ESP_LOGE(TAG, "Failed to initialize the card (%s). "
+                "Make sure SD card lines have pull-up resistors in place.", esp_err_to_name(ret));
         }
         return;
     }
+
+    // Card has been initialized, print its properties
     sdmmc_card_print_info(stdout, card);
 
+
 	// Init the GPIO
     // Flash ausschalten
     gpio_pad_select_gpio(FLASH_GPIO);
@@ -113,7 +147,11 @@ extern "C" void app_main(void)
     register_server_tflite_uri(server);
     register_server_file_uri(server, "/sdcard");
     register_server_ota_sdcard_uri(server);
+
+#ifdef __SD_USE_ONE_LINE_MODE__
     register_server_GPIO_uri(server);
+#endif    
+
     register_server_main_uri(server, "/sdcard");
 
     TFliteDoAutoStart();

+ 3 - 3
code/main/version.cpp

@@ -1,4 +1,4 @@
-const char* GIT_REV="7bc4e63";
+const char* GIT_REV="574c908";
 const char* GIT_TAG="";
-const char* GIT_BRANCH="master";
-const char* BUILD_TIME="2021-03-25 20:52";
+const char* GIT_BRANCH="rolling";
+const char* BUILD_TIME="2021-03-27 17:12";

+ 3 - 3
code/version.cpp

@@ -1,4 +1,4 @@
-const char* GIT_REV="7bc4e63";
+const char* GIT_REV="574c908";
 const char* GIT_TAG="";
-const char* GIT_BRANCH="master";
-const char* BUILD_TIME="2021-03-25 20:52";
+const char* GIT_BRANCH="rolling";
+const char* BUILD_TIME="2021-03-27 17:11";

二進制
firmware/bootloader.bin


二進制
firmware/firmware.bin