atomqueue.h

Go to the documentation of this file.
00001 /*
00002  * Copyright (c) 2010, Kelvin Lawson. All rights reserved.
00003  *
00004  * Redistribution and use in source and binary forms, with or without
00005  * modification, are permitted provided that the following conditions
00006  * are met:
00007  *
00008  * 1. Redistributions of source code must retain the above copyright
00009  *    notice, this list of conditions and the following disclaimer.
00010  * 2. Redistributions in binary form must reproduce the above copyright
00011  *    notice, this list of conditions and the following disclaimer in the
00012  *    documentation and/or other materials provided with the distribution.
00013  * 3. No personal names or organizations' names associated with the
00014  *    Atomthreads project may be used to endorse or promote products
00015  *    derived from this software without specific prior written permission.
00016  *
00017  * THIS SOFTWARE IS PROVIDED BY THE ATOMTHREADS PROJECT AND CONTRIBUTORS
00018  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
00019  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
00020  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE
00021  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00022  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00023  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00024  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00025  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00026  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00027  * POSSIBILITY OF SUCH DAMAGE.
00028  */
00029 #ifndef __ATOM_QUEUE_H
00030 #define __ATOM_QUEUE_H
00031 
00032 typedef struct atom_queue
00033 {
00034     ATOM_TCB *  putSuspQ;       /* Queue of threads waiting to send */
00035     ATOM_TCB *  getSuspQ;       /* Queue of threads waiting to receive */
00036     uint8_t *   buff_ptr;       /* Pointer to queue data area */
00037     uint32_t    unit_size;      /* Size of each message */
00038     uint32_t    max_num_msgs;   /* Max number of storable messages */
00039     uint32_t    insert_index;   /* Next byte index to insert into */
00040     uint32_t    remove_index;   /* Next byte index to remove from */
00041     uint32_t    num_msgs_stored;/* Number of messages stored */
00042 } ATOM_QUEUE;
00043 
00044 extern uint8_t atomQueueCreate (ATOM_QUEUE *qptr, uint8_t *buff_ptr, uint32_t unit_size, uint32_t max_num_msgs);
00045 extern uint8_t atomQueueDelete (ATOM_QUEUE *qptr);
00046 extern uint8_t atomQueueGet (ATOM_QUEUE *qptr, int32_t timeout, uint8_t *msgptr);
00047 extern uint8_t atomQueuePut (ATOM_QUEUE *qptr, int32_t timeout, uint8_t *msgptr);
00048 
00049 #endif /* __ATOM_QUEUE_H */

Generated on Fri Jun 4 01:00:01 2010 for atomthreads by  doxygen 1.6.1