This post is older than 2 years and might not be relevant anymore
More Info: Consider searching for newer posts

Custom mesh model incomplete data received on the other side

We are trying to implement models inside the mesh. So we've started with a functional example of the generic on off and tried to update it according to our needs.

The custom model

typedef struct __attribute((packed))
{
  uint32_t tai_seconds;
} time_set_msg_pkt_t;

/** Mandatory parameters for the Time Set message. */
typedef struct
{
   uint64_t tai_seconds;                                           
} time_set_params_t;

Modified generic on off client logic for sending a different type of message:

 time_set_msg_pkt_t msg;
    msg.tai_seconds = 0x123456789A;
    message_create(p_client, 0x5C,
                   (const uint8_t *) &msg, sizeof(time_set_msg_pkt_t),
                   &p_client->access_message.message);
 

On the other side we extract the data using the following snipped.

static inline bool set_params_validate(const access_message_rx_t * p_rx_msg, const time_set_msg_pkt_t * p_params)
{
    printf("Validating received message length: %d \n", p_rx_msg->length);
    printf("Extracted tai_seconds(hex): %x\n", p_params -> tai_seconds);
    printf("Extracted tai_seconds(dec): %d\n", p_params -> tai_seconds);
    return true;   
}

static void handle_set(access_model_handle_t model_handle, const access_message_rx_t * p_rx_msg, void * p_args)
{
    time_setup_server_t * p_server = (time_setup_server_t *) p_args;

     
    time_set_params_t in_data = {0};
    time_status_params_t out_data = {0};
    const time_set_msg_pkt_t * p_msg_params_packed = (const time_set_msg_pkt_t *) p_rx_msg-> p_data;
    printf("Extracting parameters data\n");
    printf("Received data pointer: %x\n", p_rx_msg -> p_data);
    printf("Received data(hex): %x\n", *p_rx_msg -> p_data);
   
    if (set_params_validate(p_rx_msg, p_msg_params_packed))
    {
    
    }
}
    

Unfortunately this will result in the following output

Extracting parameters data
Received data pointer: 2000eb99
Received data(hex): 9a
Validating received message length: 8
Extracted tai_seconds(hex): 3456789a
Extracted tai_seconds(dec): 878082202

Where should i look for the extra 0x12 at the beginning of the message ( received 0x3456789a vs expected 0x123456789a )?

Parents Reply Children
No Data
Related