選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

PrintBenchmarkSD.ino 2.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. /*
  2. * This program is a simple Print benchmark.
  3. */
  4. #include <SPI.h>
  5. #include <SD.h>
  6. // SD chip select pin
  7. const uint8_t chipSelect = SS;
  8. // number of lines to print
  9. const uint16_t N_PRINT = 20000;
  10. // test file
  11. File file;
  12. //------------------------------------------------------------------------------
  13. void error(char* s) {
  14. Serial.println(s);
  15. while(1);
  16. }
  17. //------------------------------------------------------------------------------
  18. void setup() {
  19. Serial.begin(9600);
  20. while (!Serial) {
  21. // wait for Leonardo
  22. }
  23. }
  24. //------------------------------------------------------------------------------
  25. void loop() {
  26. uint32_t maxLatency;
  27. uint32_t minLatency;
  28. uint32_t totalLatency;
  29. while (Serial.read() >= 0) {
  30. }
  31. // F() stores strings in flash to save RAM
  32. Serial.println(F("Type any character to start"));
  33. while (Serial.read() <= 0) {
  34. }
  35. delay(400); // catch Due reset problem
  36. // initialize the SD card
  37. if (!SD.begin(chipSelect)) {
  38. error("begin");
  39. }
  40. Serial.println(F("Starting print test. Please wait.\n"));
  41. // do write test
  42. for (int test = 0; test < 2; test++) {
  43. file = SD.open("bench.txt", FILE_WRITE);
  44. if (!file) {
  45. error("open failed");
  46. }
  47. switch(test) {
  48. case 0:
  49. Serial.println(F("Test of println(uint16_t)"));
  50. break;
  51. case 1:
  52. Serial.println(F("Test of println(double)"));
  53. break;
  54. }
  55. maxLatency = 0;
  56. minLatency = 999999;
  57. totalLatency = 0;
  58. uint32_t t = millis();
  59. for (uint16_t i = 0; i < N_PRINT; i++) {
  60. uint32_t m = micros();
  61. switch(test) {
  62. case 0:
  63. file.println(i);
  64. break;
  65. case 1:
  66. file.println((double)0.01*i);
  67. break;
  68. }
  69. if (file.getWriteError()) {
  70. error("write failed");
  71. }
  72. m = micros() - m;
  73. if (maxLatency < m) {
  74. maxLatency = m;
  75. }
  76. if (minLatency > m) {
  77. minLatency = m;
  78. }
  79. totalLatency += m;
  80. }
  81. file.flush();
  82. t = millis() - t;
  83. double s = file.size();
  84. Serial.print(F("Time "));
  85. Serial.print(0.001*t);
  86. Serial.println(F(" sec"));
  87. Serial.print(F("File size "));
  88. Serial.print(0.001*s);
  89. Serial.print(F(" KB\n"));
  90. Serial.print(F("Write "));
  91. Serial.print(s/t);
  92. Serial.print(F(" KB/sec\n"));
  93. Serial.print(F("Maximum latency: "));
  94. Serial.print(maxLatency);
  95. Serial.print(F(" usec, Minimum Latency: "));
  96. Serial.print(minLatency);
  97. Serial.print(F(" usec, Avg Latency: "));
  98. Serial.print(totalLatency/N_PRINT);
  99. Serial.println(F(" usec\n"));
  100. SD.remove("bench.txt");
  101. }
  102. file.close();
  103. Serial.println(F("Done!\n"));
  104. }