peoblema con libreria SD

He intentado ejecutar el ejemplo de datalogger de la libreria SD.h, pero tras vrarias escrituras consecutivas en el fichero, el programa se cuelga y deja de funcionar. Alguien me podria dar una pista de q puede estar pasando? Estoy utilizando un arduino mega2560 R3, un ethernet shield R3 y una tarjeta SdHC de 4 GB. Gracias por adelantado...

Si pones el código que estas ejecutando seguro te podemos guiar mejor.

Un saludo :wink:

Hola, os adjunto el codigo. Es un fichero de ejemplo de la libreria SD.h.

El problema que estoy teniendo es que al ejecutarlo, solamente me hace un bucle (en otras ocasiones me llega a hacer hasta 4) y despues se para la ejecucion.


/*
  SD card datalogger
 
 This example shows how to log data from three analog sensors 
 to an SD card using the SD library.
 	
 The circuit:
 * analog sensors on analog ins 0, 1, and 2
 * SD card attached to SPI bus as follows:
 ** MOSI - pin 11
 ** MISO - pin 12
 ** CLK - pin 13
 ** CS - pin 4
 
 created  24 Nov 2010
 modified 9 Apr 2012
 by Tom Igoe
 
 This example code is in the public domain.
 	 
 */

#include <SPI.h>
#include <SD.h>

// On the Ethernet Shield, CS is pin 4. Note that even if it's not
// used as the CS pin, the hardware CS pin (10 on most Arduino boards,
// 53 on the Mega) must be left as an output or the SD library
// functions will not work.

const int SD_CS = 4;
void setup()
{
 // Open serial communications and wait for port to open:
  Serial.begin(9600);
   while (!Serial) {
    ; // wait for serial port to connect. Needed for Leonardo only
  }


  Serial.print("Initializing SD card...");
  // make sure that the default chip select pin is set to
  // output, even if you don't use it:
   pinMode(10, OUTPUT);
  digitalWrite(10, HIGH);
   pinMode(SD_CS, OUTPUT);      
  digitalWrite(SD_CS, HIGH);
  
  // see if the card is present and can be initialized:
  if (!SD.begin(SD_CS)) {
    Serial.println("Card failed, or not present");
    // don't do anything more:
    return;
  }
  Serial.println("card initialized.");
}

void loop()
{
  // make a string for assembling the data to log:
  String dataString = "";

  // read three sensors and append to the string:
  for (int analogPin = 0; analogPin < 3; analogPin++) {
    int sensor = analogRead(analogPin);
    dataString += String(sensor);
    if (analogPin < 2) {
      dataString += ","; 
    }
  }

  // open the file. note that only one file can be open at a time,
  // so you have to close this one before opening another.
  File dataFile = SD.open("datalog.txt", FILE_WRITE);

  // if the file is available, write to it:
  if (dataFile) {
    dataFile.println(dataString);
    dataFile.close();
    // print to the serial port too:
    Serial.println(dataString);
  }  
  // if the file isn't open, pop up an error:
  else {
    Serial.println("error opening datalog.txt");
  } 
}

La salida que he optenido ahora mismo por el Serial Monitor al ejecutar el codigo es la siguiente:

Initializing SD card...card initialized.
393,356,339

y ahi se ha quedado... He probado este codigo en un Arduino Mega 2560 y en un Arduino Uno, con resultados semejantes. Sera problema de la librería? o de la tarjeta (una TDK SDHC de 4 GB, la he formateado con SDFormatter)? La verdad estoy bloqueado, este codigo lo estoy utilizando en un proyecto de mayor envergadura y me tiene paralizado...

Mira antes de usar la targeta de la forma como la formateas puede ser que el problema te venga de ahi.