1 #ifndef ANDROID_DVR_BUFFERHUBD_PRODUCER_QUEUE_CHANNEL_H_
2 #define ANDROID_DVR_BUFFERHUBD_PRODUCER_QUEUE_CHANNEL_H_
3 
4 #include "buffer_hub.h"
5 
6 #include <pdx/status.h>
7 #include <private/dvr/bufferhub_rpc.h>
8 
9 namespace android {
10 namespace dvr {
11 
12 class ProducerQueueChannel : public BufferHubChannel {
13  public:
14   static pdx::Status<std::shared_ptr<ProducerQueueChannel>> Create(
15       BufferHubService* service, int channel_id, size_t meta_size_bytes,
16       const UsagePolicy& usage_policy);
17   ~ProducerQueueChannel() override;
18 
19   bool HandleMessage(pdx::Message& message) override;
20   void HandleImpulse(pdx::Message& message) override;
21 
22   BufferInfo GetBufferInfo() const override;
23 
24   // Handles client request to create a new consumer queue attached to current
25   // producer queue.
26   // Returns a handle for the service channel, as well as the size of the
27   // metadata associated with the queue.
28   pdx::Status<pdx::RemoteChannelHandle> OnCreateConsumerQueue(
29       pdx::Message& message);
30 
31   pdx::Status<QueueInfo> OnGetQueueInfo(pdx::Message& message);
32 
33   // Allocate a new BufferHubProducer according to the input spec. Client may
34   // handle this as if a new producer is created through kOpCreateBuffer.
35   pdx::Status<std::vector<std::pair<pdx::RemoteChannelHandle, size_t>>>
36   OnProducerQueueAllocateBuffers(pdx::Message& message, uint32_t width,
37                                  uint32_t height, uint32_t layer_count,
38                                  uint32_t format, uint64_t usage,
39                                  size_t buffer_count);
40 
41   // Detach a BufferHubProducer indicated by |slot|. Note that the buffer must
42   // be in Gain'ed state for the producer queue to detach.
43   pdx::Status<void> OnProducerQueueDetachBuffer(pdx::Message& message,
44                                                 size_t slot);
45 
46   void AddConsumer(ConsumerQueueChannel* channel);
47   void RemoveConsumer(ConsumerQueueChannel* channel);
48 
49  private:
50   ProducerQueueChannel(BufferHubService* service, int channel_id,
51                        size_t meta_size_bytes, const UsagePolicy& usage_policy,
52                        int* error);
53 
54   // Allocate one single producer buffer by |OnProducerQueueAllocateBuffers|.
55   // Note that the newly created buffer's file handle will be pushed to client
56   // and our return type is a RemoteChannelHandle.
57   // Returns the remote channel handle and the slot number for the newly
58   // allocated buffer.
59   pdx::Status<std::pair<pdx::RemoteChannelHandle, size_t>> AllocateBuffer(
60       pdx::Message& message, uint32_t width, uint32_t height,
61       uint32_t layer_count, uint32_t format, uint64_t usage);
62 
63   // Size of the meta data associated with all the buffers allocated from the
64   // queue. Now we assume the metadata size is immutable once the queue is
65   // created.
66   size_t meta_size_bytes_;
67 
68   // A set of variables to control what |usage| bits can this ProducerQueue
69   // allocate.
70   UsagePolicy usage_policy_;
71 
72   // Provides access to the |channel_id| of all consumer channels associated
73   // with this producer.
74   std::vector<ConsumerQueueChannel*> consumer_channels_;
75 
76   // Tracks how many buffers have this queue allocated.
77   size_t capacity_;
78 
79   // Tracks of all buffer producer allocated through this buffer queue. Once
80   // a buffer get allocated, it will take a logical slot in the |buffers_| array
81   // and the slot number will stay unchanged during the entire life cycle of the
82   // queue.
83   std::weak_ptr<ProducerChannel> buffers_[BufferHubRPC::kMaxQueueCapacity];
84 
85   ProducerQueueChannel(const ProducerQueueChannel&) = delete;
86   void operator=(const ProducerQueueChannel&) = delete;
87 };
88 
89 }  // namespace dvr
90 }  // namespace android
91 
92 #endif  // ANDROID_DVR_BUFFERHUBD_PRODUCER_QUEUE_CHANNEL_H_
93