vkweigher.Version_res.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. #define CANARD_DSDLC_INTERNAL
  2. #include <vkweigher.Version_res.h>
  3. #include <string.h>
  4. #ifdef CANARD_DSDLC_TEST_BUILD
  5. #include <test_helpers.h>
  6. #endif
  7. uint32_t vkweigher_VersionResponse_encode(struct vkweigher_VersionResponse* msg, uint8_t* buffer
  8. #if CANARD_ENABLE_TAO_OPTION
  9. , bool tao
  10. #endif
  11. ) {
  12. uint32_t bit_ofs = 0;
  13. memset(buffer, 0, VKWEIGHER_VERSION_RESPONSE_MAX_SIZE);
  14. _vkweigher_VersionResponse_encode(buffer, &bit_ofs, msg,
  15. #if CANARD_ENABLE_TAO_OPTION
  16. tao
  17. #else
  18. true
  19. #endif
  20. );
  21. return ((bit_ofs+7)/8);
  22. }
  23. /*
  24. return true if the decode is invalid
  25. */
  26. bool vkweigher_VersionResponse_decode(const CanardRxTransfer* transfer, struct vkweigher_VersionResponse* msg) {
  27. #if CANARD_ENABLE_TAO_OPTION
  28. if (transfer->tao && (transfer->payload_len > VKWEIGHER_VERSION_RESPONSE_MAX_SIZE)) {
  29. return true; /* invalid payload length */
  30. }
  31. #endif
  32. uint32_t bit_ofs = 0;
  33. if (_vkweigher_VersionResponse_decode(transfer, &bit_ofs, msg,
  34. #if CANARD_ENABLE_TAO_OPTION
  35. transfer->tao
  36. #else
  37. true
  38. #endif
  39. )) {
  40. return true; /* invalid payload */
  41. }
  42. const uint32_t byte_len = (bit_ofs+7U)/8U;
  43. #if CANARD_ENABLE_TAO_OPTION
  44. // if this could be CANFD then the dlc could indicating more bytes than
  45. // we actually have
  46. if (!transfer->tao) {
  47. return byte_len > transfer->payload_len;
  48. }
  49. #endif
  50. return byte_len != transfer->payload_len;
  51. }
  52. #ifdef CANARD_DSDLC_TEST_BUILD
  53. struct vkweigher_VersionResponse sample_vkweigher_VersionResponse_msg(void) {
  54. struct vkweigher_VersionResponse msg;
  55. for (size_t i=0; i < 16; i++) {
  56. msg.fw_ver[i] = (int8_t)random_bitlen_signed_val(8);
  57. }
  58. msg.SN_num = (uint32_t)random_bitlen_unsigned_val(32);
  59. return msg;
  60. }
  61. #endif