/* * Copyright 2016 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef ANDROID_AAUDIO_SHARED_MEMORY_PARCELABLE_H #define ANDROID_AAUDIO_SHARED_MEMORY_PARCELABLE_H #include #include #include #include namespace aaudio { // Arbitrary limits for range checks. #define MAX_SHARED_MEMORIES (32) #define MAX_MMAP_OFFSET_BYTES (32 * 1024 * 8) #define MAX_MMAP_SIZE_BYTES (32 * 1024 * 8) /** * This is a parcelable description of a shared memory referenced by a file descriptor. * It may be divided into several regions. * The memory can be shared using Binder or simply shared between threads. */ class SharedMemoryParcelable { public: SharedMemoryParcelable() = default; // Ctor from a parcelable representation. // Since the parcelable object owns a unique FD, move semantics are provided to avoid the need // to dupe. explicit SharedMemoryParcelable(android::media::SharedFileRegion&& parcelable); /** * Make a dup() of the fd and store it for later use. * * @param fd * @param sizeInBytes */ void setup(const android::base::unique_fd& fd, int32_t sizeInBytes); void setup(const SharedMemoryParcelable& sharedMemoryParcelable); // mmap() shared memory aaudio_result_t resolve(int32_t offsetInBytes, int32_t sizeInBytes, void **regionAddressPtr); // munmap() any mapped memory aaudio_result_t close(); aaudio_result_t closeAndReleaseFd(); int32_t getSizeInBytes(); bool isInUse() const { return mFd.get() != -1; } void dump() const; // Extract a parcelable representation of this object. // Since we own a unique FD, move semantics are provided to avoid the need to dupe. android::media::SharedFileRegion parcelable() &&; // Copy this instance. Duplicates the underlying FD. SharedMemoryParcelable dup() const; private: #define MMAP_UNRESOLVED_ADDRESS reinterpret_cast(MAP_FAILED) android::base::unique_fd mFd; int64_t mSizeInBytes = 0; int64_t mOffsetInBytes = 0; uint8_t *mResolvedAddress = MMAP_UNRESOLVED_ADDRESS; aaudio_result_t resolveSharedMemory(const android::base::unique_fd& fd); aaudio_result_t validate() const; }; } /* namespace aaudio */ #endif //ANDROID_AAUDIO_SHARED_MEMORY_PARCELABLE_H