Best way to use FreeRTOS message system

Hi List I have the following function that is designed to send a message via the FreeRTOS message system to my I2C module. It then waits until the message has been processed and then retrieves the results. My question is, Is this the best way in which to do this or is there a better more efficient way in which to achieve the above function. void Load_Current_I2C_GPO_Register(void) { I2C_CmdMsg TheMsgStruct;   I2C_CmdMsg *TheMsgPtr; TheMsgStruct.I2C_Status = I2C_DoCmd;  // set the command status TheMsgPtr = &TheMsgStruct; // create a pointer to the message structure     if (xQueueSendToBack( TheI2C_Queue, ( void * ) TheMsgPtr, ( portTickType ) 10 )!= pdPASS)     SPI_DtaMessage->I2C_Status = I2C_CmdError;// message did not get posted     else     {    // the message was posted successfully     // wait until the I2C command has been processed     while(TheMsgStruct.I2C_Status == I2C_DoCmd);     // Load the new GPO register data from the message structure     GPO_0_Byte = TheMsgStruct.Byte_1;     GPO_1_Byte = TheMsgStruct.Byte_1;     SPI_DtaMessage->I2C_Status = I2C_CmdDone;       } } Kind Regards Grant Brown

Best way to use FreeRTOS message system

Without examining too much a couple of points. Be careful passing a pointer to a stack variable. In this case it is fine as the variable remains valid until after you have waited for the result. You are polling for the result which will only work in the task processing the message has a higher priority than the task running this code. Consider using a blocking mechanism like a semaphore, that will put task to sleep until there is actually some processing to do. That would be much more efficient.