| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 | 
							- /*
 
-  * This program is a simple Print benchmark.
 
-  */
 
- #include <SPI.h>
 
- #include "SdFat.h"
 
- #include "sdios.h"
 
- #include "FreeStack.h"
 
- // SD chip select pin
 
- const uint8_t chipSelect = SS;
 
- // number of lines to print
 
- const uint16_t N_PRINT = 20000;
 
- // file system
 
- SdFat sd;
 
- // test file
 
- SdFile file;
 
- // Serial output stream
 
- ArduinoOutStream 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) {
 
-     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()) {
 
-     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");
 
- }
 
 
  |