micropython / micropython-lib

Core Python libraries ported to MicroPython
Other
2.36k stars 992 forks source link

no SD card #627

Open hairem opened 1 year ago

hairem commented 1 year ago

I am trying to use this library on a rpi pico:

cs = machine.Pin(22, machine.Pin.OUT)
spi = machine.SPI(0,
                  baudrate=1000000,
                  polarity=0,
                  phase=0,
                  bits=8,
                  firstbit=machine.SPI.MSB,
                  sck=machine.Pin(18),
                  mosi=machine.Pin(19),
                  miso=machine.Pin(16))
sd = sdcard.SDCard(spi, cs)

# Mount filesystem
vfs = uos.VfsFat(sd)
os.mount(vfs, "/sd")

but every time I try to run my script in micropython I get eh error of:

"Traceback (most recent call last):
  File "<stdin>", line 27, in <module>
  File "lib/sdcard.py", line 54, in __init__
  File "lib/sdcard.py", line 82, in init_card
OSError: no SD card"

Any ideas on how to fix this?

hairem commented 1 year ago

I have the SDcard formatted in Fat32, but it doesn't seem to get to that point, it's not mounting the card because it can't see the card

dpgeorge commented 1 year ago

The most likely explanation is that the SD card is not wired up correctly (has it got power?).

hairem commented 1 year ago

Yes, I have used both my 5v rail and my 3.3v rail to power the unit, at different times since I thought it might not be receiving enough power on the 3.3v. When on the 5v rail I do get a different error: Traceback (most recent call last): File "", line 27, in File "lib/sdcard.py", line 54, in init File "lib/sdcard.py", line 98, in init_card File "lib/sdcard.py", line 196, in readinto OSError: timeout waiting for response

hairem commented 1 year ago

I confirmed power and I am still having issues with accessing the SD card. Any suggestions?

hairem commented 1 year ago

''' This is version 0.9a of the PM Monitor program. Data is stored a SD Card. ''' import machine from machine import Pin,UART import time import bme280 from lib import RTC_DS3231 from pms5003 import PMS5003 from lib import sdcard import uos import gc gc.enable()

Setup SPI SD Card

assign CS Pin

cs = machine.Pin(22, machine.Pin.OUT) spi = machine.SPI(0, baudrate=1000000, polarity=0, phase=0, bits=8, firstbit=machine.SPI.MSB, sck=machine.Pin(18), mosi=machine.Pin(19), miso=machine.Pin(16)) sd = sdcard.SDCard(spi, cs)

Mount filesystem

vfs = uos.VfsFat(sd) uos.mount(vfs, "/sd")

I2C device Settings

i2c0=machine.I2C(1,sda=machine.Pin(8), scl=machine.Pin(9), freq=400000)

i2c0=machine.I2C(0,sda=machine.Pin(0), scl=machine.Pin(1), freq=400000)

Serial Ports

uart1 = UART(0, baudrate=9600, tx=Pin(12), rx=Pin(13)) uart1.init(bits=8, parity=None, stop=1) uart0 = UART(0, baudrate=9600, tx=Pin(16), rx=Pin(17)) uart0.init(bits=8, parity=None, stop=1)

Device settings

bme = bme280.BME280(i2c=i2c0) rtc = RTC_DS3231.RTC() pms5003 = PMS5003( uart=uart1, pin_enable=machine.Pin(3), pin_reset=machine.Pin(2), mode="active" )

Clean up

def CleanMet(MET): Met=str(MET) Met=str(Met.replace("(",",").replace(")",",")) met=str(Met.replace("'","").replace("C","").replace("hPa","").replace("%","")) met = met.split(",") return(met)

Values

def Readings(): try: i = 0 Temp = 0.0 Press = 0.0 RH = 0.0 PM25 = 0.0 while 1: t = rtc.DS3231_ReadTime(2) MET = bme.values Met = CleanMet(MET) data = pms5003.read() Data = data.pm_ug_per_m3(2.5)

print(str(t) + "," + str(Met[1]) + "," + str(Met[2])+ "," + str(Met[3]) + "," +str(Data))

print(rtc.DS3231_ReadTime(3))

if int(rtc.DS3231_ReadTime(3)) > 0: Temp = float(Temp) + float(Met[1]) Press = float(Press) + float(Met[2]) RH = float(RH) + float(Met[3]) PM25 = float(PM25) + float(Data) i=i+1 else: avgT = round(Temp/i,1) avgP = round((Press/i)*0.75006,1) avgRH = round(RH/i, 1) avgPM25 = round(PM25/i,1) line = str(t) + "," + str(avgT) + "," + str(avgP) + "," + str(avgRH) + "," + str(avgPM25)+ "," + str(i) print(str(t) + "," + str(avgT) + "," + str(avgP) + "," + str(avgRH) + "," + str(avgPM25)+ "," + str(i)) with open("/sd/PMData.csv", "a") as file: file.write(str(line) + "\r\n") file.close()

print(gc.mem_free())

 i = 0
 Temp = 0.0
 Press = 0.0
 RH = 0.0
 PM25 = 0.0
 gc.collect()

except: print("Error") gc.collect() time.sleep(1) Readings()

if name == "main": Readings()

andrewleech commented 1 year ago

If 5v was applied to the card it might be dead now, unless your card reader is on a breakout with level shifters? Can you confirm the card still works in a PC reader? Are all the other spi pins definitely wired to the correct sd pins?

hairem commented 1 year ago

It's still good because I was using it today to move files from one computer to another

On Mon, Mar 13, 2023, 12:00 Andrew Leech @.***> wrote:

If 5v was applied to the card it might be dead now, unless your card reader is on a breakout with level shifters? Can you confirm the card still works in a PC reader? Are all the other spi pins definitely wired to the correct sd pins?

— Reply to this email directly, view it on GitHub https://github.com/micropython/micropython-lib/issues/627#issuecomment-1466773560, or unsubscribe https://github.com/notifications/unsubscribe-auth/ALQY2DMLTQ3XVBMFWXS76HTW35VFJANCNFSM6AAAAAAVRYK5WU . You are receiving this because you authored the thread.Message ID: @.***>

andrewleech commented 1 year ago

Pinout: are all the card reader pins wired correctly? Card reader: is the socket faulty? Software: where did your copy of sdcard.py come from? Micropython: which version is loaded on your Pico?

https://core-electronics.com.au/guides/raspberry-pi-pico/makerverse-micro-sd-adapter-micropython-guide/

You might also have more luck asking about this on the micropython discord, this issue tracker is generally for tracking SW bugs and not monitored by many people.

hairem commented 1 year ago

I have tried multiple SD card reader modules, same error, I have confirmed the wiring multiple times and had a second person check it. I got the library from this GitHub.

On Mon, Mar 13, 2023, 12:18 Andrew Leech @.***> wrote:

Pinout: are all the card reader pins wired correctly? Card reader: is the socket faulty? Software: where did your copy of sdcard.py come from?

https://core-electronics.com.au/guides/raspberry-pi-pico/makerverse-micro-sd-adapter-micropython-guide/

You might also have more luck asking about this on the micropython discord, this issue tracker is generally for tracking SW bugs and not monitored by many people.

— Reply to this email directly, view it on GitHub https://github.com/micropython/micropython-lib/issues/627#issuecomment-1466809341, or unsubscribe https://github.com/notifications/unsubscribe-auth/ALQY2DJU3L6CO2IQGRASHZ3W35XHLANCNFSM6AAAAAAVRYK5WU . You are receiving this because you authored the thread.Message ID: @.***>

andrewleech commented 1 year ago

Might be an issue with the size / brand of sd card, seems there can be some differences at times: https://e2e.ti.com/support/microcontrollers/msp-low-power-microcontrollers-group/msp430/f/msp-low-power-microcontroller-forum/294813/sdhc-code-with-spi-works-on-kingston-card-but-not-on-sony-card

hairem commented 1 year ago

I doubt it's the SD card because I have used this one before with this spi module

SanDisk Industrial 8GB Micro SD... https://www.amazon.com/dp/B085GL8XBH?ref=ppx_pop_mob_ap_share

On Mon, Mar 13, 2023, 12:30 Andrew Leech @.***> wrote:

Might be an issue with the size / brand of sd card, seems there can be some differences at times: https://e2e.ti.com/support/microcontrollers/msp-low-power-microcontrollers-group/msp430/f/msp-low-power-microcontroller-forum/294813/sdhc-code-with-spi-works-on-kingston-card-but-not-on-sony-card

— Reply to this email directly, view it on GitHub https://github.com/micropython/micropython-lib/issues/627#issuecomment-1466824710, or unsubscribe https://github.com/notifications/unsubscribe-auth/ALQY2DN6LI22NACFGFWLZ63W35YURANCNFSM6AAAAAAVRYK5WU . You are receiving this because you authored the thread.Message ID: @.***>

andrewleech commented 1 year ago

I haven't used this sdcard.py on a pico but there's plenty of tutorials online using it so it must be broadly compatible.

I keep going back to the pinout because it's a common issue and we can't actually see what you've done; so for the pins specified in the code, eg. Pin(18) have you definitely wired GP18 and not pin number 18?

Also, what version micropython are you running on the pico? Maybe try updating that to latest nightly if you haven't already recently.

hairem commented 1 year ago

(sysname='rp2', nodename='rp2', release='1.19.1', version='v1.19.1 on 2022-06-18 (GNU 11.2.0 MinSizeRel)', machine='Raspberry Pi Pico with RP2040')

I have multiple other modules that work fine, the only issue I am having is with the SD card module. I have looked at several tutorials and walkthroughs and have tried them as well, well the ones that don't link to a dead copy of this library, The first one I tried was the Digikey walkthrough but I run into the same issue which leads me to ask the owner of the GitHub.

hairem commented 1 year ago

I am using the following pins: pin 21 = GP16 =MISO pin 22 = GP17 = CS pin 24 = GP18 = SCK pin 25 = GP19 = MOSI

I am using this pinout guide : https://electrocredible.com/wp-content/uploads/2022/05/raspberry-pi-pico-w-pinout.webp

andrewleech commented 1 year ago

That looks like the issue then! In your code above you have:

cs = machine.Pin(22)
sck = machine.Pin(18)
mosi = machine.Pin(19)
miso = machine.Pin(16)

The Pin number refers to the GP number, not the raw pin number. It looks like you have the Pins that are passed to Spi correct but cs is declared as GP22, not GP17

hairem commented 1 year ago

That was fixed and still getting the same error

On Wed, Mar 15, 2023, 08:44 Andrew Leech @.***> wrote:

That looks like the issue then! In your code above you have:

cs = machine.Pin(22) sck = machine.Pin(18) mosi = machine.Pin(19) miso = machine.Pin(16)

The Pin number refers to the GP number, not the raw pin number. It looks like you have the Pins that are passed to Spi correct but cs is declared as GP22, not GP17

— Reply to this email directly, view it on GitHub https://github.com/micropython/micropython-lib/issues/627#issuecomment-1470275078, or unsubscribe https://github.com/notifications/unsubscribe-auth/ALQY2DP66GBHH5F72IG7VETW4HPUJANCNFSM6AAAAAAVRYK5WU . You are receiving this because you authored the thread.Message ID: @.***>

khansahab117 commented 8 months ago

Yes, I have used both my 5v rail and my 3.3v rail to power the unit, at different times since I thought it might not be receiving enough power on the 3.3v. When on the 5v rail I do get a different error: Traceback (most recent call last): File "", line 27, in File "lib/sdcard.py", line 54, in init File "lib/sdcard.py", line 98, in init_card File "lib/sdcard.py", line 196, in readinto OSError: timeout waiting for response

I am also getting this error. Were you able to find the fix for this?

hairem commented 8 months ago

I did but but I would have to be at my desk to look at what I did to fix it and I am in vacation with family ATM.

On Sat, Dec 23, 2023, 22:24 Amaan Khan @.***> wrote:

Yes, I have used both my 5v rail and my 3.3v rail to power the unit, at different times since I thought it might not be receiving enough power on the 3.3v. When on the 5v rail I do get a different error: Traceback (most recent call last): File "", line 27, in File "lib/sdcard.py", line 54, in init File "lib/sdcard.py", line 98, in init_card File "lib/sdcard.py", line 196, in readinto OSError: timeout waiting for response

I am also getting this error. Were you able to find the fix for this?

— Reply to this email directly, view it on GitHub https://github.com/micropython/micropython-lib/issues/627#issuecomment-1868429729, or unsubscribe https://github.com/notifications/unsubscribe-auth/ALQY2DOM35XF4YNDLWE76W3YK6U6BAVCNFSM6AAAAAAVRYK5WWVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMYTQNRYGQZDSNZSHE . You are receiving this because you authored the thread.Message ID: @.***>

fox-Nh133 commented 6 months ago

I also encountered this error; "OSError: no SD card". for me, adjusting _CMD_TIMEOUT value in sdcard.py from 100 to 1000, and connecting sufficient power to the sd module solved the problem.

Initially, I wired 3.3v power to the sd module, but after checking the datasheet, it turned out that the module accepts 4.5-5.5v as input. so I switched the power supply port from VSYS to VBUS.

Hristo-Nikodimov-Nenkov commented 6 months ago

Same problem, both with Pico W and RP2040 clone with 16MB ROM.

from machine import SPI from sdcard import SDCard from uos import VfsFat, mount, listdir

cs_pin = Pin(13, Pin.OUT) sck = Pin(14) mosi = Pin(15) miso = Pin(12)

spi = SPI(1, baudrate=1000000, polarity=0, phase=0, bits=8, firstbit=SPI.MSB, sck=sck, mosi=mosi, miso=miso)

sd = SDCard(spi, cs_pin) vfs = VfsFat(sd)

mount(vfs, '/card')

print(listdir("/card"))

Traceback (most recent call last): File "", line 50, in File "/lib/sdcard.py", line 54, in init File "/lib/sdcard.py", line 82, in init_card OSError: no SD card

I've tried with 1GB Nokia, 2GB SanDisk and 4GB N/A all cards are formated as FAT32 and work fine on both my laptop and my headphones,

As for power I've used both the 3.3V of the Picos and external power converter for breadbords.

I've even tried the 1GB and 2GB cards formated as FAT with same result.

dev12p commented 5 months ago

Same problem, both with Pico W and RP2040 clone with 16MB ROM.

from machine import SPI from sdcard import SDCard from uos import VfsFat, mount, listdir

cs_pin = Pin(13, Pin.OUT) sck = Pin(14) mosi = Pin(15) miso = Pin(12)

spi = SPI(1, baudrate=1000000, polarity=0, phase=0, bits=8, firstbit=SPI.MSB, sck=sck, mosi=mosi, miso=miso)

sd = SDCard(spi, cs_pin) vfs = VfsFat(sd)

mount(vfs, '/card')

print(listdir("/card"))

Traceback (most recent call last): File "", line 50, in File "/lib/sdcard.py", line 54, in init File "/lib/sdcard.py", line 82, in init_card OSError: no SD card

I've tried with 1GB Nokia, 2GB SanDisk and 4GB N/A all cards are formated as FAT32 and work fine on both my laptop and my headphones,

As for power I've used both the 3.3V of the Picos and external power converter for breadbords.

I've even tried the 1GB and 2GB cards formated as FAT with same result.

Did you end up finding a solution?

hairem commented 5 months ago

Went with a different SD card module

On Thu, Mar 21, 2024, 20:04 dev12p @.***> wrote:

Same problem, both with Pico W and RP2040 clone with 16MB ROM.

from machine import SPI from sdcard import SDCard from uos import VfsFat, mount, listdir

cs_pin = Pin(13, Pin.OUT) sck = Pin(14) mosi = Pin(15) miso = Pin(12)

spi = SPI(1, baudrate=1000000, polarity=0, phase=0, bits=8, firstbit=SPI.MSB, sck=sck, mosi=mosi, miso=miso)

sd = SDCard(spi, cs_pin) vfs = VfsFat(sd)

mount(vfs, '/card')

print(listdir("/card"))

Traceback (most recent call last): File "", line 50, in File "/lib/sdcard.py", line 54, in init File "/lib/sdcard.py", line 82, in init_card OSError: no SD card

I've tried with 1GB Nokia, 2GB SanDisk and 4GB N/A all cards are formated as FAT32 and work fine on both my laptop and my headphones,

As for power I've used both the 3.3V of the Picos and external power converter for breadbords.

I've even tried the 1GB and 2GB cards formated as FAT with same result.

Did you end up finding a solution?

— Reply to this email directly, view it on GitHub https://github.com/micropython/micropython-lib/issues/627#issuecomment-2014260028, or unsubscribe https://github.com/notifications/unsubscribe-auth/ALQY2DNC5UTHZMB6FHMI7JTYZONVLAVCNFSM6AAAAAAVRYK5WWVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDAMJUGI3DAMBSHA . You are receiving this because you authored the thread.Message ID: @.***>

Hristo-Nikodimov-Nenkov commented 5 months ago

I found the problem, it was a combination of old breadboard and cheep patch cables. I'm realy sorry for not even suspecting the breadboard.

ZeynX92 commented 2 months ago

Hello, I Have same problem

import machine
import sdcard
import uos

cs = machine.Pin(1, machine.Pin.OUT)

spi = machine.SPI(0,
          baudrate=1000000,
          polarity=0,
          phase=0,
          bits=8,
          firstbit=machine.SPI.MSB,
          sck=machine.Pin(2),
          mosi=machine.Pin(3),
          miso=machine.Pin(4))

sd = sdcard.SDCard(spi, cs)

vfs=uos.VfsFat(sd)
uos.mount(sd,'/sd')

Error

Traceback (most recent call last):
  File "<stdin>", line 24, in <module>
  File "sdcard.py", line 54, in __init__
  File "sdcard.py", line 82, in init_card
OSError: no SD card

I really don't know what to do. because i check all contacts, power, use and format 3 different SD cards, change _CMD_TIMEOUT...

Hiroyugane commented 2 months ago

I found the problem, it was a combination of old breadboard and cheep patch cables. I'm realy sorry for not even suspecting the breadboard.

Can confirm. Had the same problem and tried reformatting the sd card several times. Turns out, my SD Reader breakout board pins were too short and did not quite reach into the breadboard - therefore not making a good connection. Used Pin Contact spray and other patch cables. Solved the problem for me.

Thanks for commenting this!

slabua commented 1 month ago

Following :\

ZeynX92 commented 1 month ago

My story with this error: https://github.com/micropython/micropython-lib/issues/871

slabua commented 1 month ago

I might have found something!

spi = SPI(
    id=1,
    sck=Pin(10, Pin.OUT),
    mosi=Pin(11, Pin.OUT),
    miso=Pin(8, Pin.OUT),
)

It seems like some other pins are being bullied by the lib. These are the first listed pins for SPI1 and there is no error. Might as well work for the first listed SPI0 pins.

Also, if the sdcard contains chinese characters, generally some issue with unicode, it doesn't work.