summaryrefslogtreecommitdiff
path: root/tools/gator/daemon/Fifo.h
diff options
context:
space:
mode:
authorPhilippe Langlais <philippe.langlais@stericsson.com>2012-05-23 13:42:19 +0200
committerPhilippe Langlais <philippe.langlais@stericsson.com>2012-05-23 13:42:19 +0200
commit8bc478b8c8c63667b4809af36d7942de666593a0 (patch)
tree5ebb5c5b289999bc980e348403e1730ee4e31a00 /tools/gator/daemon/Fifo.h
parent2b24a2ac921ef485d58b922a2dd8dc7b7c0803a2 (diff)
parent09f333ed6069575a71fabc999c4dc39b6594d727 (diff)
Merge remote-tracking branch 'armlt/3.3-armlt-gator-5.10' into stable-ubuntu-ux500-3.3-1
Conflicts: drivers/Kconfig
Diffstat (limited to 'tools/gator/daemon/Fifo.h')
-rw-r--r--tools/gator/daemon/Fifo.h33
1 files changed, 33 insertions, 0 deletions
diff --git a/tools/gator/daemon/Fifo.h b/tools/gator/daemon/Fifo.h
new file mode 100644
index 00000000000..548ba278806
--- /dev/null
+++ b/tools/gator/daemon/Fifo.h
@@ -0,0 +1,33 @@
+/**
+ * Copyright (C) ARM Limited 2010-2012. All rights reserved.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ */
+
+#ifndef __FIFO_H__
+#define __FIFO_H__
+
+#include <semaphore.h>
+
+class Fifo {
+public:
+ Fifo(int singleBufferSize, int totalBufferSize);
+ ~Fifo();
+ int numBytesFilled();
+ bool isEmpty();
+ bool isFull();
+ bool willFill(int additional);
+ char* start();
+ char* write(int length);
+ char* read(int* length);
+
+private:
+ int mSingleBufferSize, mWrite, mRead, mReadCommit, mRaggedEnd, mWrapThreshold;
+ sem_t mWaitForSpaceSem, mWaitForDataSem;
+ char* mBuffer;
+ bool mEnd;
+};
+
+#endif //__FIFO_H__