graphicscomposition/openwfcompositionengine/adaptation/include/owfmessagequeue.h
author Faisal Memon <faisal.memon@nokia.com>
Wed, 25 Aug 2010 19:15:42 +0100
branchbug235_bringup_0
changeset 159 e40433e31c87
parent 0 5d03bc08d59c
child 152 9f1c3fea0f87
permissions -rw-r--r--
Fixes needed for actual guest video driver guestvideogw.ldd

/* Copyright (c) 2009 The Khronos Group Inc.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and/or associated documentation files (the
 * "Materials"), to deal in the Materials without restriction, including
 * without limitation the rights to use, copy, modify, merge, publish,
 * distribute, sublicense, and/or sell copies of the Materials, and to
 * permit persons to whom the Materials are furnished to do so, subject to
 * the following conditions:
 *
 * The above copyright notice and this permission notice shall be included
 * in all copies or substantial portions of the Materials.
 *
 * THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
 * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
 * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
 * MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
 */

#ifndef OWF_MESSAGEQUEUE_H_
#define OWF_MESSAGEQUEUE_H_

#include "owftypes.h"
#include "owfsemaphore.h"
#include "owfmutex.h"


#ifdef __cplusplus
extern "C" {
#endif


typedef struct {
    OWFuint                 id;
    void*                   data;
} OWF_MESSAGE;

typedef struct _MSGQUE {
    OWFint                  read;
    OWFint                  write;
} OWF_MESSAGE_QUEUE;

/*
 *  Destroy message queue
 *
 *  \param queue Message queue to destroy
 */
OWF_API_CALL void
OWF_MessageQueue_Destroy(OWF_MESSAGE_QUEUE* queue);

/*
 *  Initialize message queue
 *
 *  \param queue Message queue to initialize
 *  \return 0 if initialization succeeded, < 0 otherwise
 *
 */
OWF_API_CALL OWFint
OWF_MessageQueue_Init(OWF_MESSAGE_QUEUE* queue);

/*
 *  Insert message into message queue (send it to
 *  THE other side)
 *
 *  \param queue Message queue
 *  \param msg Message to send
 *  \param data Message contents
 *
 */
OWF_API_CALL void
OWF_Message_Send(OWF_MESSAGE_QUEUE* queue,
                 OWFuint msg,
                 void* data);
/*
 *  Wait for message
 *
 *  \param queue Message queue
 *  \param msg Where to store the received message
 *  \param timeout Time to wait for the message (microseconds)
 *
 *  \return < 0 if error occurred, 0 if no message was received within
 *  given period of time, > 0 otherwise; received message is stored into
 *  OWF_MESSAGE structure pointed by the msg param
 *
 */
OWF_API_CALL OWFint
OWF_Message_Wait(OWF_MESSAGE_QUEUE* queue,
                 OWF_MESSAGE* msg,
                 OWFint timeout);


#ifdef __cplusplus
}
#endif


#endif