Simple single-color 8x8x8 LED Cube with AVRs
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

transmit.c 4.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. /*
  2. * transmit.c
  3. *
  4. * Copyright 2011 Thomas Buck <xythobuz@me.com>
  5. * Copyright 2011 Max Nuding <max.nuding@gmail.com>
  6. * Copyright 2011 Felix Bäder <baeder.felix@gmail.com>
  7. *
  8. * This file is part of LED-Cube.
  9. *
  10. * LED-Cube is free software: you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation, either version 3 of the License, or
  13. * (at your option) any later version.
  14. *
  15. * LED-Cube is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU General Public License
  21. * along with LED-Cube. If not, see <http://www.gnu.org/licenses/>.
  22. */
  23. #include <avr/io.h>
  24. #include <util/delay.h>
  25. #include <stdint.h>
  26. #include <stdlib.h>
  27. #include <avr/wdt.h>
  28. #include "memLayer.h"
  29. #include "serial.h"
  30. #include "time.h"
  31. #include "strings.h"
  32. #include "audio.h"
  33. #define OK 0x42
  34. #define ERROR 0x23
  35. #define TIMEOUTPERFRAME 500
  36. // These are global variables from main.c
  37. extern char buffer[11];
  38. void recieveAnimations(void) {
  39. uint8_t animCount, a, frameCount, f, i, c;
  40. uint16_t completeCount = 0;
  41. uint8_t *frame = (uint8_t *)malloc(65);
  42. uint64_t timestamp = getSystemTime();
  43. uint64_t timeout = TIMEOUTPERFRAME;
  44. serialWrite(OK); // We are ready...
  45. while (!serialHasChar()) { // Wait for answer
  46. if ((getSystemTime() - timestamp) <= timeout) {
  47. wdt_reset();
  48. } else {
  49. setAnimationCount(0);
  50. return;
  51. }
  52. }
  53. c = serialGet();
  54. animCount = c; // Got animation count
  55. serialWrite(OK);
  56. for (a = 0; a < animCount; a++) {
  57. while (!serialHasChar()) { // Wait for answer
  58. if ((getSystemTime() - timestamp) <= timeout) {
  59. wdt_reset();
  60. } else {
  61. setAnimationCount(0);
  62. return;
  63. }
  64. }
  65. c = serialGet();
  66. frameCount = c; // Got frame count
  67. serialWrite(OK);
  68. for (f = 0; f < frameCount; f++) {
  69. timeout += TIMEOUTPERFRAME;
  70. while (!serialHasChar()) { // Wait for answer
  71. if ((getSystemTime() - timestamp) <= timeout) {
  72. wdt_reset();
  73. } else {
  74. setAnimationCount(0);
  75. return;
  76. }
  77. }
  78. c = serialGet();
  79. frame[64] = c; // Got duration
  80. serialWrite(OK);
  81. for (i = 0; i < 64; i++) {
  82. while (!serialHasChar()) { // Wait for answer
  83. if ((getSystemTime() - timestamp) <= timeout) {
  84. wdt_reset();
  85. } else {
  86. setAnimationCount(0);
  87. return;
  88. }
  89. }
  90. c = serialGet();
  91. frame[i] = c; // Got data byte
  92. }
  93. serialWrite(OK);
  94. setFrame(completeCount++, frame);
  95. }
  96. }
  97. free(frame);
  98. while (!serialHasChar()) { // Wait for answer
  99. if ((getSystemTime() - timestamp) <= timeout) {
  100. wdt_reset();
  101. } else {
  102. setAnimationCount(0);
  103. return;
  104. }
  105. }
  106. c = serialGet();
  107. while (!serialHasChar()) { // Wait for answer
  108. if ((getSystemTime() - timestamp) <= timeout) {
  109. wdt_reset();
  110. } else {
  111. setAnimationCount(0);
  112. return;
  113. }
  114. }
  115. c = serialGet();
  116. while (!serialHasChar()) { // Wait for answer
  117. if ((getSystemTime() - timestamp) <= timeout) {
  118. wdt_reset();
  119. } else {
  120. setAnimationCount(0);
  121. return;
  122. }
  123. }
  124. c = serialGet();
  125. while (!serialHasChar()) { // Wait for answer
  126. if ((getSystemTime() - timestamp) <= timeout) {
  127. wdt_reset();
  128. } else {
  129. setAnimationCount(0);
  130. return;
  131. }
  132. }
  133. c = serialGet();
  134. serialWrite(OK);
  135. setAnimationCount(completeCount);
  136. }
  137. // TODO: Rewrite for new Serial API
  138. void transmitAnimations(void) {
  139. serialWrite(ERROR);
  140. }
  141. void sendAudioData(void) {
  142. uint8_t i;
  143. uint8_t *audioData = getAudioData();
  144. if (audioData == NULL) {
  145. serialWriteString(getString(21));
  146. } else {
  147. serialWriteString(getString(22));
  148. for (i = 0; i < 7; i++) {
  149. serialWrite(i + '0');
  150. serialWriteString(": ");
  151. itoa(audioData[i], buffer, 10);
  152. serialWriteString(buffer);
  153. serialWrite('\n');
  154. }
  155. }
  156. }
  157. void printTime(void) {
  158. serialWriteString(getString(14));
  159. serialWriteString(ltoa(getSystemTime(), buffer, 10));
  160. serialWriteString("ms");
  161. if (getSystemTime() > 60000) {
  162. serialWriteString(" (");
  163. serialWriteString(itoa(getSystemTime() / 60000, buffer, 10));
  164. serialWriteString(" min)");
  165. }
  166. if (getSystemTime() > 1000) {
  167. serialWriteString(" (");
  168. serialWriteString(itoa(getSystemTime() / 1000, buffer, 10));
  169. itoa(getSystemTime() % 1000, buffer, 10);
  170. if (buffer[0] != '\0')
  171. serialWrite('.');
  172. if (buffer[2] == '\0')
  173. serialWrite('0');
  174. if (buffer[1] == '\0')
  175. serialWrite('0');
  176. if (buffer[0] != '\0')
  177. serialWriteString(buffer);
  178. serialWriteString("s)\n");
  179. } else {
  180. serialWrite('\n');
  181. }
  182. }
  183. void dumpFrame(uint8_t *f) {
  184. uint8_t zeile, spalte;
  185. for (zeile = 0; zeile < 8; zeile++) {
  186. serialWrite(zeile + '0');
  187. serialWriteString(": ");
  188. for (spalte = 0; spalte < 8; spalte++) {
  189. itoa(f[(8 * zeile) + spalte], buffer, 16);
  190. serialWriteString(buffer);
  191. serialWrite(' ');
  192. }
  193. serialWrite('\n');
  194. }
  195. serialWriteString("Duration: ");
  196. itoa(f[64], buffer, 10);
  197. serialWriteString(buffer);
  198. serialWrite('\n');
  199. }