مشکل در استفاده از ماژول micro SD Card با ESP32

2 سال قبل
803 بازدید

0

سلام

برای استفاده از ماژول micro SD Card با بورد ESP32 با شرایط زیر به مشکلی برخوردم که ممنون میشم راهنمایی کنید.

  • DOIT ESP32 DEVKIT V1
  • ARDUINO IDE 2.0.0
  • Esp32 by Espressif Systems 2.0.5
  • کارت حافظه از نوع micro SD HC با ظرفیت 8 گیگ است
  • به عنوان منبع تغذیه هم از پاور سویچینگ 5V, 5A استفاده میکنم که به عملکردش اطمینان دارم.
  • برای اتصال ماژول حافظه به بورد از پایه های پیش فرض یعنی 5 و 18 و 19 و 23 به ترتیب برای CS و SCLK و MISO و MOSI استفاده میکنم.

در نهایت هدف من درست کردن چیزی شبیه دیتا لاگر است. به طور متناوب و با عملکرد یک میکروسویچ باید زمان دقیق همراه با اطلاعات خوانده شده از RFID در انتهای یک فایل موجود روی SD Card اضافه بشه.

برای تست کار با  SD Card وقتی از نمونه برنامه های موجود (از آموزش https://thecaferobot.com/learn/sd-micro-sd-read-write-arduino/ استفاده میکنم (کد ضمیمه)، فایل باز نمیشه و خروجی روی سریال به شرح زیر نمایش داده میشه. فرقی هم نمیکنه که فایل test.txt روی کارت موجود باشه یا نه. در هر صورت خروجی همین پیام است: 

�4)�fT�9��p�Initializing SD card...initialization done.

error opening test.txt

اگر از منبع تغذیه خارجی استفاده نکنم و از پورت usb کامپیوتر که برای اتصال بورد استفاده میکنم برای تغذیه هم استفاده کنم هم چیزی عوض نمیشه و خروجی همین است.

همین کد را روی آردوینو مگا تست کردم که بدون مشکل اجرا شد.

نمونه برنامه دیگری که تست کردم مثال SD_Test بود که با نصب esp32 روی ARDUINO IDE در قسمت مثال ها esp32 در دسترس است. آن کد ظاهرا از دستورات دیگه ای برای کار با فایل ها استفاده میکنه و همه دستورات کد بدون اشکال اجرا میشوند.

حالا سوال هایی که دارم این ها هستند.

1-      برای رفع ایراد کد اول باید چکار کنم؟

2-      کاراکترهای نامفهوم ابتدای خروجی را چطور باید حذف کنم (baud rate را درست تنظیم میکنم ولی باز هم این کاراکترها هستند).

هر دو کد را هم اینجا میتونید ببینید.

 

تشکر پیشاپیش

 

 

 

کد اول که به مشکل بر میخوره

#include <SPI.h>
#include <SD.h>
File myFile;
void setup() {
// Open serial communications and wait for port to open:
Serial.begin(9600);
while (!Serial) {
; // wait for serial port to connect. Needed for native USB port only
}
Serial.print("Initializing SD card...");
if (!SD.begin(5)) {
Serial.println("initialization failed!");
while (1);
}
Serial.println("initialization done.");
// open the file. note that only one file can be open at a time,
// so you have to close this one before opening another.
myFile = SD.open("test.txt", FILE_WRITE);
// if the file opened okay, write to it:
if (myFile) {
Serial.print("Writing to test.txt...");
myFile.println("This is a test file :)");
myFile.println("testing 1, 2, 3.");
for (int i = 0; i < 20; i++) {
myFile.println(i);
}
// close the file:
myFile.close();
Serial.println("done.");
} else {
// if the file didn't open, print an error:
Serial.println("error opening test.txt");
}
}
void loop() {
// nothing happens after setup
}


///////////////////////////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////////////////////////

کد دوم که بدون مشکل تا آخر اجرا میشه


/*
 * Connect the SD card to the following pins:
 *
 * SD Card | ESP32
 *    D2       -
 *    D3       SS
 *    CMD      MOSI
 *    VSS      GND
 *    VDD      3.3V
 *    CLK      SCK
 *    VSS      GND
 *    D0       MISO
 *    D1       -
 */
#include "FS.h"
#include "SD.h"
#include "SPI.h"

void listDir(fs::FS &fs, const char * dirname, uint8_t levels){
    Serial.printf("Listing directory: %s\n", dirname);

    File root = fs.open(dirname);
    if(!root){
        Serial.println("Failed to open directory");
        return;
    }
    if(!root.isDirectory()){
        Serial.println("Not a directory");
        return;
    }

    File file = root.openNextFile();
    while(file){
        if(file.isDirectory()){
            Serial.print("  DIR : ");
            Serial.println(file.name());
            if(levels){
                listDir(fs, file.path(), levels -1);
            }
        } else {
            Serial.print("  FILE: ");
            Serial.print(file.name());
            Serial.print("  SIZE: ");
            Serial.println(file.size());
        }
        file = root.openNextFile();
    }
}

void createDir(fs::FS &fs, const char * path){
    Serial.printf("Creating Dir: %s\n", path);
    if(fs.mkdir(path)){
        Serial.println("Dir created");
    } else {
        Serial.println("mkdir failed");
    }
}

void removeDir(fs::FS &fs, const char * path){
    Serial.printf("Removing Dir: %s\n", path);
    if(fs.rmdir(path)){
        Serial.println("Dir removed");
    } else {
        Serial.println("rmdir failed");
    }
}

void readFile(fs::FS &fs, const char * path){
    Serial.printf("Reading file: %s\n", path);

    File file = fs.open(path);
    if(!file){
        Serial.println("Failed to open file for reading");
        return;
    }

    Serial.print("Read from file: ");
    while(file.available()){
        Serial.write(file.read());
    }
    file.close();
}

void writeFile(fs::FS &fs, const char * path, const char * message){
    Serial.printf("Writing file: %s\n", path);

    File file = fs.open(path, FILE_WRITE);
    if(!file){
        Serial.println("Failed to open file for writing");
        return;
    }
    if(file.print(message)){
        Serial.println("File written");
    } else {
        Serial.println("Write failed");
    }
    file.close();
}

void appendFile(fs::FS &fs, const char * path, const char * message){
    Serial.printf("Appending to file: %s\n", path);

    File file = fs.open(path, FILE_APPEND);
    if(!file){
        Serial.println("Failed to open file for appending");
        return;
    }
    if(file.print(message)){
        Serial.println("Message appended");
    } else {
        Serial.println("Append failed");
    }
    file.close();
}

void renameFile(fs::FS &fs, const char * path1, const char * path2){
    Serial.printf("Renaming file %s to %s\n", path1, path2);
    if (fs.rename(path1, path2)) {
        Serial.println("File renamed");
    } else {
        Serial.println("Rename failed");
    }
}

void deleteFile(fs::FS &fs, const char * path){
    Serial.printf("Deleting file: %s\n", path);
    if(fs.remove(path)){
        Serial.println("File deleted");
    } else {
        Serial.println("Delete failed");
    }
}

void testFileIO(fs::FS &fs, const char * path){
    File file = fs.open(path);
    static uint8_t buf[512];
    size_t len = 0;
    uint32_t start = millis();
    uint32_t end = start;
    if(file){
        len = file.size();
        size_t flen = len;
        start = millis();
        while(len){
            size_t toRead = len;
            if(toRead > 512){
                toRead = 512;
            }
            file.read(buf, toRead);
            len -= toRead;
        }
        end = millis() - start;
        Serial.printf("%u bytes read for %u ms\n", flen, end);
        file.close();
    } else {
        Serial.println("Failed to open file for reading");
    }


    file = fs.open(path, FILE_WRITE);
    if(!file){
        Serial.println("Failed to open file for writing");
        return;
    }

    size_t i;
    start = millis();
    for(i=0; i<2048; i++){
        file.write(buf, 512);
    }
    end = millis() - start;
    Serial.printf("%u bytes written for %u ms\n", 2048 * 512, end);
    file.close();
}

void setup(){
    Serial.begin(9600);
    if(!SD.begin(5)){
        Serial.println("Card Mount Failed");
        return;
    }
    uint8_t cardType = SD.cardType();

    if(cardType == CARD_NONE){
        Serial.println("No SD card attached");
        return;
    }

    Serial.print("SD Card Type: ");
    if(cardType == CARD_MMC){
        Serial.println("MMC");
    } else if(cardType == CARD_SD){
        Serial.println("SDSC");
    } else if(cardType == CARD_SDHC){
        Serial.println("SDHC");
    } else {
        Serial.println("UNKNOWN");
    }

    uint64_t cardSize = SD.cardSize() / (1024 * 1024);
    Serial.printf("SD Card Size: %lluMB\n", cardSize);

    listDir(SD, "/", 0);
    createDir(SD, "/mydir");
    listDir(SD, "/", 0);
    removeDir(SD, "/mydir");
    listDir(SD, "/", 2);
    writeFile(SD, "/hello.txt", "Hello ");
    appendFile(SD, "/hello.txt", "World!\n");
    readFile(SD, "/hello.txt");
    deleteFile(SD, "/foo.txt");
    renameFile(SD, "/hello.txt", "/foo.txt");
    readFile(SD, "/foo.txt");
    testFileIO(SD, "/test.txt");
    Serial.printf("Total space: %lluMB\n", SD.totalBytes() / (1024 * 1024));
    Serial.printf("Used space: %lluMB\n", SD.usedBytes() / (1024 * 1024));
}

void loop(){

}
07 آبان 01 در 06:45
رضا مهدی پور
19

افزودن دیدگاه

1 پاسخ ثبت شده است
1

با سلام

در مرحله اول نیازی نیست تغذیه را به صورت جداگانه تامین کنید

کافی است پایه vcc ماژول SD Card را به پایه تغذیه 3.3 ولت برد ESP32 وصل کنید و پایه های رگوراتور AMS1117 که بر روی SD Card می باشد را به هم اتصال کوتاه بدهید مشابه عکس زیر.

مورد دیگری که باید بررسی کنید حجم حافظه فلش می باشد گاهی به حجم های بالا خطا می دهد برای رفع این موضوع از نرم افزار PartitionGuru استفاده می شود می توانید از این لینک برای دانلود این نرم افزار استفاده کنید.

پس از نصب نرم افزار را باز کرده و طبق مراحل زیر پارتیشن را انتخاب میکنید و حجم پارتیشن را کم میکنید

اگر پارتیشن از قبل وجود داشت از گزینه delete برای حذف پارتیشن می توانید استفاده کنید.

در نهایت بر روی گزینه save all بزنید و فایل test.txt را بر روی میکرو بریزید و دوباره تست کنید.

یک احتمال نیز قرار دادن این خط ها در ابتدا کد خودتان.

#include "FS.h"
#include "SD.h"
#include "SPI.h"
07 آبان 01 در 08:04
محمد دمیرچی
4220

افزودن دیدگاه


انجمن کافه‌ربات © 1400