|
-
- #include <SPI.h>
- #include "SdFat.h"
- #include "sdios.h"
- #include "FreeStack.h"
-
-
- const uint8_t chipSelect = SS;
-
- const uint32_t RATE_KB_PER_SEC = 100;
-
- const uint32_t TEST_TIME_SEC = 100;
-
-
- const uint32_t DOT_TIME_MS = 5000UL;
-
-
- const uint32_t BLOCK_COUNT = (1000*RATE_KB_PER_SEC*TEST_TIME_SEC + 511)/512;
-
-
- SdFat sd;
-
-
- SdFile file;
-
-
- uint32_t bgnBlock, endBlock;
-
-
- ArduinoOutStream cout(Serial);
-
-
- #define error(s) sd.errorHalt(F(s))
-
- void setup(void) {
- Serial.begin(9600);
-
-
- while (!Serial) {
- SysCall::yield();
- }
- }
-
- void loop(void) {
-
- do {
- delay(10);
- } while (Serial.available() && Serial.read() >= 0);
-
- cout << F("Type any character to start\n");
- while (!Serial.available()) {
- SysCall::yield();
- }
-
- cout << F("FreeStack: ") << FreeStack() << endl;
-
-
-
- if (!sd.begin(chipSelect, SD_SCK_MHZ(50))) {
- sd.initErrorHalt();
- }
-
-
- sd.remove("RawWrite.txt");
-
-
- if (!file.createContiguous("RawWrite.txt", 512UL*BLOCK_COUNT)) {
- error("createContiguous failed");
- }
-
- if (!file.contiguousRange(&bgnBlock, &endBlock)) {
- error("contiguousRange failed");
- }
-
-
-
-
-
- uint8_t* pCache = (uint8_t*)sd.vol()->cacheClear();
-
-
- memset(pCache, ' ', 512);
- for (uint16_t i = 0; i < 512; i += 64) {
-
- pCache[i + 61] = '0' + (i/64);
- pCache[i + 62] = '\r';
- pCache[i + 63] = '\n';
- }
-
- cout << F("Start raw write of ") << file.fileSize()/1000UL << F(" KB\n");
- cout << F("Target rate: ") << RATE_KB_PER_SEC << F(" KB/sec\n");
- cout << F("Target time: ") << TEST_TIME_SEC << F(" seconds\n");
-
-
- if (!sd.card()->writeStart(bgnBlock, BLOCK_COUNT)) {
- error("writeStart failed");
- }
-
-
- delay(1000);
- uint32_t dotCount = 0;
- uint32_t maxQueuePrint = 0;
- uint32_t maxWriteTime = 0;
- uint32_t minWriteTime = 9999999;
- uint32_t totalWriteTime = 0;
- uint32_t maxQueueSize = 0;
- uint32_t nWrite = 0;
- uint32_t b = 0;
-
-
- uint32_t startTime = millis();
- while (nWrite < BLOCK_COUNT) {
- uint32_t nProduced = RATE_KB_PER_SEC*(millis() - startTime)/512UL;
- uint32_t queueSize = nProduced - nWrite;
- if (queueSize == 0) continue;
- if (queueSize > maxQueueSize) {
- maxQueueSize = queueSize;
- }
- if ((millis() - startTime - dotCount*DOT_TIME_MS) > DOT_TIME_MS) {
- if (maxQueueSize != maxQueuePrint) {
- cout << F("\nQ: ") << maxQueueSize << endl;
- maxQueuePrint = maxQueueSize;
- } else {
- cout << ".";
- if (++dotCount%10 == 0) {
- cout << endl;
- }
- }
- }
-
- uint32_t n = b++;
- for (int8_t d = 5; d >= 0; d--) {
- pCache[d] = n || d == 5 ? n % 10 + '0' : ' ';
- n /= 10;
- }
-
- uint32_t tw = micros();
- if (!sd.card()->writeData(pCache)) {
- error("writeData failed");
- }
- tw = micros() - tw;
- totalWriteTime += tw;
-
- if (tw > maxWriteTime) {
- maxWriteTime = tw;
- }
- if (tw < minWriteTime) {
- minWriteTime = tw;
- }
- nWrite++;
- }
- uint32_t endTime = millis();
- uint32_t avgWriteTime = totalWriteTime/BLOCK_COUNT;
-
- if (!sd.card()->writeStop()) {
- error("writeStop failed");
- }
-
- cout << F("\nDone\n");
- cout << F("maxQueueSize: ") << maxQueueSize << endl;
- cout << F("Elapsed time: ") << setprecision(3)<< 1.e-3*(endTime - startTime);
- cout << F(" seconds\n");
- cout << F("Min block write time: ") << minWriteTime << F(" micros\n");
- cout << F("Max block write time: ") << maxWriteTime << F(" micros\n");
- cout << F("Avg block write time: ") << avgWriteTime << F(" micros\n");
-
- file.close();
- Serial.println();
- }
|