1 /* Copyright (c) 2012-2016, The Linux Foundation. All rights reserved. 2 * 3 * Redistribution and use in source and binary forms, with or without 4 * modification, are permitted provided that the following conditions are 5 * met: 6 * * Redistributions of source code must retain the above copyright 7 * notice, this list of conditions and the following disclaimer. 8 * * Redistributions in binary form must reproduce the above 9 * copyright notice, this list of conditions and the following 10 * disclaimer in the documentation and/or other materials provided 11 * with the distribution. 12 * * Neither the name of The Linux Foundation nor the names of its 13 * contributors may be used to endorse or promote products derived 14 * from this software without specific prior written permission. 15 * 16 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED 17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 20 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 23 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 24 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 25 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN 26 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27 * 28 */ 29 30 #ifndef __QCAMERA_QUEUE_H__ 31 #define __QCAMERA_QUEUE_H__ 32 33 // System dependencies 34 #include <pthread.h> 35 36 // Camera dependencies 37 #include "cam_list.h" 38 39 namespace qcamera { 40 41 typedef bool (*match_fn_data)(void *data, void *user_data, void *match_data); 42 typedef void (*release_data_fn)(void* data, void *user_data); 43 typedef bool (*match_fn)(void *data, void *user_data); 44 45 class QCameraQueue { 46 public: 47 QCameraQueue(); 48 QCameraQueue(release_data_fn data_rel_fn, void *user_data); 49 virtual ~QCameraQueue(); 50 void init(); 51 bool enqueue(void *data); 52 bool enqueueWithPriority(void *data); 53 /* This call will put queue into uninitialized state. 54 * Need to call init() in order to use the queue again */ 55 void flush(); 56 void flushNodes(match_fn match); 57 void flushNodes(match_fn_data match, void *spec_data); 58 void* dequeue(bool bFromHead = true); 59 void* dequeue(match_fn_data match, void *spec_data); 60 void* peek(); 61 bool isEmpty(); getCurrentSize()62 int getCurrentSize() {return m_size;} 63 private: 64 typedef struct { 65 struct cam_list list; 66 void* data; 67 } camera_q_node; 68 69 camera_q_node m_head; // dummy head 70 int m_size; 71 bool m_active; 72 pthread_mutex_t m_lock; 73 release_data_fn m_dataFn; 74 void * m_userData; 75 }; 76 77 }; // namespace qcamera 78 79 #endif /* __QCAMERA_QUEUE_H__ */ 80