| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 | /* * This program is a simple Print benchmark. */#include <SPI.h>#include "SdFat.h"#include "sdios.h"#include "FreeStack.h"// SD chip select pinconst uint8_t chipSelect = SS;// number of lines to printconst uint16_t N_PRINT = 20000;// file systemSdFat sd;// test fileSdFile file;// Serial output streamArduinoOutStream cout(Serial);//------------------------------------------------------------------------------// store error strings in flash to save RAM#define error(s) sd.errorHalt(F(s))//------------------------------------------------------------------------------void setup() {  Serial.begin(9600);  // Wait for USB Serial   while (!Serial) {    SysCall::yield();  }}//------------------------------------------------------------------------------void loop() {  uint32_t maxLatency;  uint32_t minLatency;  uint32_t totalLatency;  // Read any existing Serial data.  do {    delay(10);  } while (Serial.available() && Serial.read() >= 0);  // F stores strings in flash to save RAM  cout << F("Type any character to start\n");  while (!Serial.available()) {    SysCall::yield();  }  delay(400);  // catch Due reset problem  cout << F("FreeStack: ") << FreeStack() << endl;  // Initialize at the highest speed supported by the board that is  // not over 50 MHz. Try a lower speed if SPI errors occur.  if (!sd.begin(chipSelect, SD_SCK_MHZ(50))) {    sd.initErrorHalt();  }  cout << F("Type is FAT") << int(sd.vol()->fatType()) << endl;  cout << F("Starting print test.  Please wait.\n\n");  // do write test  for (int test = 0; test < 6; test++) {    char fileName[13] = "bench0.txt";    fileName[5] = '0' + test;    // open or create file - truncate existing file.    if (!file.open(fileName, O_RDWR | O_CREAT | O_TRUNC)) {      error("open failed");    }    maxLatency = 0;    minLatency = 999999;    totalLatency = 0;    switch(test) {    case 0:      cout << F("Test of println(uint16_t)\n");      break;    case 1:      cout << F("Test of printField(uint16_t, char)\n");      break;    case 2:      cout << F("Test of println(uint32_t)\n");      break;    case 3:      cout << F("Test of printField(uint32_t, char)\n");      break;    case 4:      cout << F("Test of println(float)\n");      break;    case 5:      cout << F("Test of printField(float, char)\n");      break;    }    uint32_t t = millis();    for (uint16_t i = 0; i < N_PRINT; i++) {      uint32_t m = micros();      switch(test) {      case 0:        file.println(i);        break;      case 1:        file.printField(i, '\n');        break;      case 2:        file.println(12345678UL + i);        break;      case 3:        file.printField(12345678UL + i, '\n');        break;      case 4:        file.println((float)0.01*i);        break;      case 5:        file.printField((float)0.01*i, '\n');        break;      }      if (file.getWriteError()) {        error("write failed");      }      m = micros() - m;      if (maxLatency < m) {        maxLatency = m;      }      if (minLatency > m) {        minLatency = m;      }      totalLatency += m;    }    file.close();    t = millis() - t;    double s = file.fileSize();    cout << F("Time ") << 0.001*t << F(" sec\n");    cout << F("File size ") << 0.001*s << F(" KB\n");    cout << F("Write ") << s/t << F(" KB/sec\n");    cout << F("Maximum latency: ") << maxLatency;    cout << F(" usec, Minimum Latency: ") << minLatency;    cout << F(" usec, Avg Latency: ");    cout << totalLatency/N_PRINT << F(" usec\n\n");  }  cout << F("Done!\n\n");}
 |