diff options
author | Philippe Langlais <philippe.langlais@stericsson.com> | 2012-05-23 13:42:19 +0200 |
---|---|---|
committer | Philippe Langlais <philippe.langlais@stericsson.com> | 2012-05-23 13:42:19 +0200 |
commit | 8bc478b8c8c63667b4809af36d7942de666593a0 (patch) | |
tree | 5ebb5c5b289999bc980e348403e1730ee4e31a00 /tools/gator/daemon/Fifo.h | |
parent | 2b24a2ac921ef485d58b922a2dd8dc7b7c0803a2 (diff) | |
parent | 09f333ed6069575a71fabc999c4dc39b6594d727 (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.h | 33 |
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__
|