event_record.c 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. #include <stdbool.h>
  2. #include <string.h>
  3. #include "event_record.h"
  4. #include "libs/shark_task.h"
  5. #define MAX_EVENT_SIZE 120
  6. static event_record_t _event[MAX_EVENT_SIZE];
  7. static int event_w_idx = 0;
  8. static bool _event_full = false;
  9. void push_event(event_id_t id, s32 data) {
  10. if (id == Aux_Current_Short) {//when multi aux short, only recode the old
  11. for (int i = 0; i < MAX_EVENT_SIZE; i++) {
  12. if (_event[i].id == Aux_Current_Short) {
  13. if (shark_get_seconds() - _event[i].timestamp <= 1) {
  14. return;
  15. }
  16. }
  17. }
  18. }
  19. event_record_t *pevent = &_event[event_w_idx];
  20. event_w_idx = (event_w_idx + 1) % MAX_EVENT_SIZE;
  21. if (event_w_idx == 0) {
  22. _event_full = true;
  23. }
  24. pevent->id = id;
  25. pevent->timestamp = shark_get_seconds();
  26. pevent->data = data;
  27. }
  28. static int _event_size(void) {
  29. if (_event_full) {
  30. return MAX_EVENT_SIZE;
  31. }
  32. return event_w_idx;
  33. }
  34. int get_event(int num, int offset, u8 *recoder) {
  35. if (offset >= _event_size()) {
  36. return 0;
  37. }
  38. num = MIN(num, _event_size()-offset);
  39. int rtn = 0;
  40. if (_event_full) {
  41. offset += event_w_idx;
  42. }
  43. while(num > 0) {
  44. memcpy(recoder, _event + offset % MAX_EVENT_SIZE, sizeof(event_record_t));
  45. num --;
  46. offset ++;
  47. recoder += sizeof(event_record_t);
  48. rtn ++;
  49. }
  50. return rtn;
  51. }