Home | History | Annotate | Download | only in oboeservice
      1 /*
      2  * Copyright (C) 2016 The Android Open Source Project
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License");
      5  * you may not use this file except in compliance with the License.
      6  * You may obtain a copy of the License at
      7  *
      8  *      http://www.apache.org/licenses/LICENSE-2.0
      9  *
     10  * Unless required by applicable law or agreed to in writing, software
     11  * distributed under the License is distributed on an "AS IS" BASIS,
     12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13  * See the License for the specific language governing permissions and
     14  * limitations under the License.
     15  */
     16 
     17 #ifndef AAUDIO_AAUDIO_STREAM_TRACKER_H
     18 #define AAUDIO_AAUDIO_STREAM_TRACKER_H
     19 
     20 #include <time.h>
     21 #include <pthread.h>
     22 
     23 #include <aaudio/AAudio.h>
     24 
     25 #include "binding/AAudioCommon.h"
     26 
     27 #include "AAudioServiceStreamBase.h"
     28 
     29 namespace aaudio {
     30 
     31 class AAudioStreamTracker {
     32 
     33 public:
     34     /**
     35      * Find the stream associated with the handle.
     36      * Decrement its reference counter. If zero and the stream needs
     37      * to be closed then remove the stream and return a pointer to the stream.
     38      * Otherwise return null if it does not need to be closed.
     39      *
     40      * @param streamHandle
     41      * @return strong pointer to the stream if it needs to be closed, or nullptr
     42      */
     43     android::sp<AAudioServiceStreamBase> decrementAndRemoveStreamByHandle(
     44             aaudio_handle_t streamHandle);
     45 
     46     /**
     47      * Look up a stream based on the handle.
     48      * Increment its service reference count if found.
     49      *
     50      * @param streamHandle
     51      * @return strong pointer to the stream if found, or nullptr
     52      */
     53     android::sp<aaudio::AAudioServiceStreamBase> getStreamByHandleAndIncrement(
     54             aaudio_handle_t streamHandle);
     55 
     56     /**
     57      * Look up a stream based on the AudioPolicy portHandle.
     58      * Increment its service reference count if found.
     59      *
     60      * @param portHandle
     61      * @return strong pointer to the stream if found, or nullptr
     62      */
     63     android::sp<aaudio::AAudioServiceStreamBase> findStreamByPortHandleAndIncrement(
     64             audio_port_handle_t portHandle);
     65 
     66     /**
     67      * Store a strong pointer to the stream and return a unique handle for future reference.
     68      * The handle is guaranteed not to collide with an existing stream.
     69      * @param serviceStream
     70      * @return handle for identifying the stream
     71      */
     72     aaudio_handle_t addStreamForHandle(android::sp<AAudioServiceStreamBase> serviceStream);
     73 
     74     /**
     75      * @return string that can be added to dumpsys
     76      */
     77     std::string dump() const;
     78 
     79 private:
     80     static aaudio_handle_t bumpHandle(aaudio_handle_t handle);
     81 
     82     // Track stream using a unique handle that wraps. Only use positive half.
     83     mutable std::mutex                mHandleLock;
     84     // protected by mHandleLock
     85     aaudio_handle_t                   mPreviousHandle = 0;
     86     // protected by mHandleLock
     87     std::map<aaudio_handle_t, android::sp<aaudio::AAudioServiceStreamBase>> mStreamsByHandle;
     88 };
     89 
     90 
     91 } /* namespace aaudio */
     92 
     93 #endif /* AAUDIO_AAUDIO_STREAM_TRACKER_H */
     94