Buffer.cpp 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. #include "Buffer.h"
  2. #include "lang_var.h"
  3. Buffer::Buffer(){
  4. bufA = (uint8_t*)malloc(BUF_SIZE);
  5. bufB = (uint8_t*)malloc(BUF_SIZE);
  6. }
  7. void Buffer::createPcapFile(fs::FS* fs, String fn){
  8. int i=0;
  9. do{
  10. fileName = "/"+fn+"_"+(String)i+".pcap";
  11. i++;
  12. } while(fs->exists(fileName));
  13. Serial.println(fileName);
  14. file = fs->open(fileName, FILE_WRITE);
  15. file.close();
  16. }
  17. void Buffer::open(){
  18. bufSizeA = 0;
  19. bufSizeB = 0;
  20. bufSizeB = 0;
  21. writing = true;
  22. write(uint32_t(0xa1b2c3d4)); // magic number
  23. write(uint16_t(2)); // major version number
  24. write(uint16_t(4)); // minor version number
  25. write(int32_t(0)); // GMT to local correction
  26. write(uint32_t(0)); // accuracy of timestamps
  27. write(uint32_t(SNAP_LEN)); // max length of captured packets, in octets
  28. write(uint32_t(105)); // data link type
  29. }
  30. void Buffer::close(fs::FS* fs){
  31. if(!writing) return;
  32. forceSave(fs);
  33. writing = false;
  34. Serial.println(text01);
  35. }
  36. void Buffer::addPacket(uint8_t* buf, uint32_t len){
  37. // buffer is full -> drop packet
  38. if((useA && bufSizeA + len >= BUF_SIZE && bufSizeB > 0) || (!useA && bufSizeB + len >= BUF_SIZE && bufSizeA > 0)){
  39. //Serial.print(";");
  40. return;
  41. }
  42. if(useA && bufSizeA + len + 16 >= BUF_SIZE && bufSizeB == 0){
  43. useA = false;
  44. //Serial.println("\nswitched to buffer B");
  45. }
  46. else if(!useA && bufSizeB + len + 16 >= BUF_SIZE && bufSizeA == 0){
  47. useA = true;
  48. //Serial.println("\nswitched to buffer A");
  49. }
  50. uint32_t microSeconds = micros(); // e.g. 45200400 => 45s 200ms 400us
  51. uint32_t seconds = (microSeconds/1000)/1000; // e.g. 45200400/1000/1000 = 45200 / 1000 = 45s
  52. microSeconds -= seconds*1000*1000; // e.g. 45200400 - 45*1000*1000 = 45200400 - 45000000 = 400us (because we only need the offset)
  53. write(seconds); // ts_sec
  54. write(microSeconds); // ts_usec
  55. write(len); // incl_len
  56. write(len); // orig_len
  57. write(buf, len); // packet payload
  58. }
  59. void Buffer::write(int32_t n){
  60. uint8_t buf[4];
  61. buf[0] = n;
  62. buf[1] = n >> 8;
  63. buf[2] = n >> 16;
  64. buf[3] = n >> 24;
  65. write(buf,4);
  66. }
  67. void Buffer::write(uint32_t n){
  68. uint8_t buf[4];
  69. buf[0] = n;
  70. buf[1] = n >> 8;
  71. buf[2] = n >> 16;
  72. buf[3] = n >> 24;
  73. write(buf,4);
  74. }
  75. void Buffer::write(uint16_t n){
  76. uint8_t buf[2];
  77. buf[0] = n;
  78. buf[1] = n >> 8;
  79. write(buf,2);
  80. }
  81. void Buffer::write(uint8_t* buf, uint32_t len){
  82. if(!writing) return;
  83. if(useA){
  84. memcpy(&bufA[bufSizeA], buf, len);
  85. bufSizeA += len;
  86. }else{
  87. memcpy(&bufB[bufSizeB], buf, len);
  88. bufSizeB += len;
  89. }
  90. }
  91. void Buffer::save(fs::FS* fs){
  92. if(saving) return; // makes sure the function isn't called simultaneously on different cores
  93. // buffers are already emptied, therefor saving is unecessary
  94. if((useA && bufSizeB == 0) || (!useA && bufSizeA == 0)){
  95. //Serial.printf("useA: %s, bufA %u, bufB %u\n",useA ? "true" : "false",bufSizeA,bufSizeB); // for debug porpuses
  96. return;
  97. }
  98. //Serial.println("saving file");
  99. uint32_t startTime = millis();
  100. uint32_t finishTime;
  101. file = fs->open(fileName, FILE_APPEND);
  102. if (!file) {
  103. Serial.println(text02 + fileName+"'");
  104. //useSD = false;
  105. return;
  106. }
  107. saving = true;
  108. uint32_t len;
  109. if(useA){
  110. file.write(bufB, bufSizeB);
  111. len = bufSizeB;
  112. bufSizeB = 0;
  113. }
  114. else{
  115. file.write(bufA, bufSizeA);
  116. len = bufSizeA;
  117. bufSizeA = 0;
  118. }
  119. file.close();
  120. finishTime = millis() - startTime;
  121. //Serial.printf("\n%u bytes written for %u ms\n", len, finishTime);
  122. saving = false;
  123. }
  124. void Buffer::forceSave(fs::FS* fs){
  125. uint32_t len = bufSizeA + bufSizeB;
  126. if(len == 0) return;
  127. file = fs->open(fileName, FILE_APPEND);
  128. if (!file) {
  129. Serial.println(text02+fileName+"'");
  130. //useSD = false;
  131. return;
  132. }
  133. saving = true;
  134. writing = false;
  135. if(useA){
  136. if(bufSizeB > 0){
  137. file.write(bufB, bufSizeB);
  138. bufSizeB = 0;
  139. }
  140. if(bufSizeA > 0){
  141. file.write(bufA, bufSizeA);
  142. bufSizeA = 0;
  143. }
  144. } else {
  145. if(bufSizeA > 0){
  146. file.write(bufA, bufSizeA);
  147. bufSizeA = 0;
  148. }
  149. if(bufSizeB > 0){
  150. file.write(bufB, bufSizeB);
  151. bufSizeB = 0;
  152. }
  153. }
  154. file.close();
  155. //Serial.printf("saved %u bytes\n",len);
  156. saving = false;
  157. writing = true;
  158. }
  159. void Buffer::forceSaveSerial() {
  160. uint32_t len = bufSizeA + bufSizeB;
  161. if(len == 0) return;
  162. saving = true;
  163. writing = false;
  164. if(useA){
  165. if(bufSizeB > 0){
  166. Serial1.write(bufB, bufSizeB);
  167. bufSizeB = 0;
  168. }
  169. if(bufSizeA > 0){
  170. Serial1.write(bufA, bufSizeA);
  171. bufSizeA = 0;
  172. }
  173. } else {
  174. if(bufSizeA > 0){
  175. Serial1.write(bufA, bufSizeA);
  176. bufSizeA = 0;
  177. }
  178. if(bufSizeB > 0){
  179. Serial1.write(bufB, bufSizeB);
  180. bufSizeB = 0;
  181. }
  182. }
  183. saving = false;
  184. writing = true;
  185. }