Skip to main content

AREthGetData

Valid for: CANoe DE • CANoe4SW DE

Function Syntax

  • dword AREthGetData(dword messageHandle, dword bufferLength, char buffer[]); // form 1
  • dword AREthGetData(dword messageHandle, dword bufferLength, byte buffer[]); // form 2
  • dword AREthGetData(dword messageHandle, dword bufferLength, struct buffer[]); // form 3

Description

This function can be used to query the raw data of a SOME/IP message.

Parameters

  • messageHandle: Handle of the received SOME/IP message (see OnAREthMessage)
  • bufferLength: Size of the buffer in bytes
  • buffer: Data are copied to this buffer

Return Values

  • 0: An error occurred. The error can be evaluated using the AREthGetLastError function.
  • >0: Number of copied bytes

Example

void OnAREthMessage(dword messageHandle)
{
  BYTE buffer[200];
  BYTE bufferMsg[200];
  dword count;
  dword size;
  CHAR dest[200];

  count = 0;

  // Check if message is a non Service Discovery message
  if(AREthGetMessageId(messageHandle) != 0xFFFF8100)
  {
    // Check if message is a Notification message
    if(AREthGetMessageType(messageHandle) == 0x2)
    {
      write("SOME/IP Notification message received!\n");

      // write whole message data (including header and payload) to write window
      size = AREthSerializeMessage(messageHandle, elcount(bufferMsg), bufferMsg);
      write("Message size: %d", size);
      snprintf(dest, elcount(dest), "%s", "");
      for(count = 0; count < size; count++)
      {
        snprintf(dest, elcount(dest), "%s %02x", dest, bufferMsg[count]);
      }
      write("Serialized Message: %s", dest);

      // write only message payload to write window
      size = AREthGetData(messageHandle, elcount(buffer), buffer);
      write("Payload size: %d", size);
      snprintf(dest, elcount(dest), "%s", "");
      for(count = 0; count < size; count++)
      {
        snprintf(dest, elcount(dest), "%s %02x", dest, buffer[count]);
      }
      write("Serialized Payload: %s\n", dest);
    } // if
  } // if
}
See Also