summaryrefslogtreecommitdiff
path: root/gralloc4/src/4.x/GrallocMapper.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'gralloc4/src/4.x/GrallocMapper.cpp')
-rw-r--r--gralloc4/src/4.x/GrallocMapper.cpp154
1 files changed, 129 insertions, 25 deletions
diff --git a/gralloc4/src/4.x/GrallocMapper.cpp b/gralloc4/src/4.x/GrallocMapper.cpp
index c0b5f5f..11ee90b 100644
--- a/gralloc4/src/4.x/GrallocMapper.cpp
+++ b/gralloc4/src/4.x/GrallocMapper.cpp
@@ -18,6 +18,7 @@
#include "GrallocMapper.h"
#include "hidl_common/BufferDescriptor.h"
#include "hidl_common/MapperMetadata.h"
+#include "hidl_common/Mapper.h"
#include "allocator/mali_gralloc_ion.h"
@@ -26,7 +27,9 @@ namespace arm
namespace mapper
{
+namespace hidl {
using android::hardware::graphics::mapper::V4_0::Error;
+} // namespace hidl
using android::hardware::graphics::mapper::V4_0::BufferDescriptor;
using android::hardware::graphics::mapper::V4_0::IMapper;
using android::hardware::Return;
@@ -34,7 +37,6 @@ using android::hardware::hidl_handle;
using android::hardware::hidl_vec;
using android::hardware::Void;
-
GrallocMapper::GrallocMapper() {}
GrallocMapper::~GrallocMapper() {}
@@ -43,12 +45,12 @@ Return<void> GrallocMapper::createDescriptor(const BufferDescriptorInfo &descrip
{
if (common::validateDescriptorInfo(descriptorInfo))
{
- hidl_cb(Error::NONE, common::grallocEncodeBufferDescriptor<uint8_t>(descriptorInfo));
+ hidl_cb(hidl::Error::NONE, common::grallocEncodeBufferDescriptor<uint8_t>(descriptorInfo));
}
else
{
MALI_GRALLOC_LOGE("Invalid attributes to create descriptor for Mapper 3.0");
- hidl_cb(Error::BAD_VALUE, BufferDescriptor());
+ hidl_cb(hidl::Error::BAD_VALUE, BufferDescriptor());
}
return Void();
@@ -56,73 +58,156 @@ Return<void> GrallocMapper::createDescriptor(const BufferDescriptorInfo &descrip
Return<void> GrallocMapper::importBuffer(const hidl_handle &rawHandle, importBuffer_cb hidl_cb)
{
- common::importBuffer(rawHandle, hidl_cb);
+ if (!rawHandle.getNativeHandle()) {
+ hidl_cb(hidl::Error::BAD_BUFFER, nullptr);
+ return Void();
+ }
+
+ auto *inHandle = const_cast<native_handle_t *>(rawHandle.getNativeHandle());
+ buffer_handle_t outHandle = nullptr;
+
+ hidl::Error err = static_cast<hidl::Error>(
+ common::importBuffer(inHandle, &outHandle));
+
+ hidl_cb(err, static_cast<void*>(const_cast<native_handle_t*>(outHandle)));
return Void();
}
-Return<Error> GrallocMapper::freeBuffer(void *buffer)
+Return<hidl::Error> GrallocMapper::freeBuffer(void *buffer)
{
- return common::freeBuffer(buffer);
+ buffer_handle_t handle = common::getBuffer(buffer);
+ if (handle == nullptr) return hidl::Error::BAD_BUFFER;
+ return static_cast<hidl::Error>(common::freeBuffer(handle));
}
-Return<Error> GrallocMapper::validateBufferSize(void *buffer, const BufferDescriptorInfo &descriptorInfo,
+Return<hidl::Error> GrallocMapper::validateBufferSize(void *buffer, const BufferDescriptorInfo &descriptorInfo,
uint32_t in_stride)
{
/* All Gralloc allocated buffers must be conform to local descriptor validation */
if (!common::validateDescriptorInfo<BufferDescriptorInfo>(descriptorInfo))
{
MALI_GRALLOC_LOGE("Invalid descriptor attributes for validating buffer size");
- return Error::BAD_VALUE;
+ return hidl::Error::BAD_VALUE;
}
- return common::validateBufferSize(buffer, descriptorInfo, in_stride);
+ return static_cast<hidl::Error>(common::validateBufferSize(buffer, descriptorInfo, in_stride));
+}
+
+static bool getFenceFd(const hidl_handle &fenceHandle, int *outFenceFd) {
+ auto const handle = fenceHandle.getNativeHandle();
+ if (handle && handle->numFds > 1) {
+ MALI_GRALLOC_LOGE("Invalid fence handle with %d fds",
+ handle->numFds);
+ return false;
+ }
+
+ *outFenceFd = (handle && handle->numFds == 1) ? handle->data[0] : -1;
+ return true;
}
Return<void> GrallocMapper::lock(void *buffer, uint64_t cpuUsage, const IMapper::Rect &accessRegion,
const hidl_handle &acquireFence, lock_cb hidl_cb)
{
- common::lock(buffer, cpuUsage, accessRegion, acquireFence, hidl_cb);
+ void *outData = nullptr;
+ int fenceFd;
+ if (!getFenceFd(acquireFence, &fenceFd)) {
+ hidl_cb(hidl::Error::BAD_VALUE, nullptr);
+ return Void();
+ }
+
+ hidl::Error err = static_cast<hidl::Error>(
+ common::lock(static_cast<buffer_handle_t>(buffer), cpuUsage,
+ common::GrallocRect(accessRegion), fenceFd, &outData));
+ if (err != hidl::Error::NONE) outData = nullptr;
+ hidl_cb(err, outData);
return Void();
}
+/*
+ * Populates the HIDL fence handle for the given fence object
+ *
+ * @param fenceFd [in] Fence file descriptor
+ * @param handleStorage [in] HIDL handle storage for fence
+ *
+ * @return HIDL fence handle
+ */
+static hidl_handle buildFenceHandle(int fenceFd, char *handleStorage) {
+ native_handle_t *handle = nullptr;
+ if (fenceFd >= 0) {
+ handle = native_handle_init(handleStorage, 1, 0);
+ handle->data[0] = fenceFd;
+ }
+
+ return hidl_handle(handle);
+}
+
Return<void> GrallocMapper::unlock(void *buffer, unlock_cb hidl_cb)
{
- common::unlock(buffer, hidl_cb);
+ int fenceFd = -1;
+ const native_handle_t *handle = common::getBuffer(buffer);
+
+ if (handle == nullptr) {
+ hidl_cb(hidl::Error::BAD_BUFFER, nullptr);
+ }
+
+ hidl::Error err =
+ static_cast<hidl::Error>(common::unlock(handle, &fenceFd));
+ if (err == hidl::Error::NONE) {
+ NATIVE_HANDLE_DECLARE_STORAGE(fenceStorage, 1, 0);
+ hidl_cb(err, buildFenceHandle(fenceFd, fenceStorage));
+
+ if (fenceFd >= 0) {
+ close(fenceFd);
+ }
+ } else {
+ hidl_cb(err, nullptr);
+ }
return Void();
}
Return<void> GrallocMapper::flushLockedBuffer(void *buffer, flushLockedBuffer_cb hidl_cb)
{
- common::flushLockedBuffer(buffer, hidl_cb);
+ hidl::Error err = static_cast<hidl::Error>(common::flushLockedBuffer(static_cast<buffer_handle_t>(buffer)));
+ hidl_cb(err, hidl_handle{});
return Void();
}
-Return<Error> GrallocMapper::rereadLockedBuffer(void *buffer)
+Return<hidl::Error> GrallocMapper::rereadLockedBuffer(void *buffer)
{
- return common::rereadLockedBuffer(buffer);
+ return static_cast<hidl::Error>(common::rereadLockedBuffer(common::getBuffer(buffer)));
}
Return<void> GrallocMapper::get(void *buffer, const MetadataType &metadataType, IMapper::get_cb hidl_cb)
{
- common::get(buffer, metadataType, hidl_cb);
+ std::vector<uint8_t> vec;
+ hidl::Error err = static_cast<hidl::Error>(
+ common::get(common::getBuffer(buffer), common::MetadataType(metadataType), vec));
+ hidl_cb(err, hidl_vec(vec));
return Void();
}
-Return<Error> GrallocMapper::set(void *buffer, const MetadataType &metadataType, const hidl_vec<uint8_t> &metadata)
+Return<hidl::Error> GrallocMapper::set(void *buffer, const MetadataType &metadataType, const hidl_vec<uint8_t> &metadata)
{
- return common::set(buffer, metadataType, metadata);
+ buffer_handle_t bufferHandle = common::getBuffer(buffer);
+ return static_cast<hidl::Error>(common::set(bufferHandle, common::MetadataType(metadataType), metadata));
}
Return<void> GrallocMapper::getFromBufferDescriptorInfo(const BufferDescriptorInfo &description,
const MetadataType &metadataType,
getFromBufferDescriptorInfo_cb hidl_cb)
{
- common::getFromBufferDescriptorInfo(description, metadataType, hidl_cb);
+ std::vector<uint8_t> vec;
+ hidl::Error err = static_cast<hidl::Error>(common::getFromBufferDescriptorInfo(
+ description, common::MetadataType(metadataType), vec));
+ hidl_cb(err, vec);
return Void();
}
Return<void> GrallocMapper::getTransportSize(void *buffer, getTransportSize_cb hidl_cb)
{
- common::getTransportSize(buffer, hidl_cb);
+ uint32_t outNumFds = 0, outNumInts = 0;
+ buffer_handle_t bufferHandle = common::getBuffer(buffer);
+ hidl::Error err = static_cast<hidl::Error>(common::getTransportSize(bufferHandle, &outNumFds, &outNumInts));
+ hidl_cb(err, outNumFds, outNumInts);
return Void();
}
@@ -131,33 +216,52 @@ Return<void> GrallocMapper::isSupported(const IMapper::BufferDescriptorInfo &des
if (!common::validateDescriptorInfo<BufferDescriptorInfo>(description))
{
MALI_GRALLOC_LOGE("Invalid descriptor attributes for validating buffer size");
- hidl_cb(Error::BAD_VALUE, false);
+ hidl_cb(hidl::Error::BAD_VALUE, false);
}
- common::isSupported(description, hidl_cb);
+ hidl_cb(hidl::Error::NONE, common::isSupported(description));
return Void();
}
Return<void> GrallocMapper::listSupportedMetadataTypes(listSupportedMetadataTypes_cb hidl_cb)
{
- common::listSupportedMetadataTypes(hidl_cb);
+ std::vector<common::MetadataTypeDescription> desc = common::listSupportedMetadataTypes();
+ std::vector<IMapper::MetadataTypeDescription> hidl_description(desc.size());
+ std::copy(desc.begin(), desc.end(), hidl_description.begin());
+ hidl_cb(hidl::Error::NONE, hidl_vec(hidl_description));
return Void();
}
Return<void> GrallocMapper::dumpBuffer(void *buffer, dumpBuffer_cb hidl_cb)
{
- common::dumpBuffer(buffer, hidl_cb);
+ common::BufferDump out;
+ hidl::Error err = static_cast<hidl::Error>(common::dumpBuffer(common::getBuffer(buffer), out));
+ hidl_cb(err, static_cast<IMapper::BufferDump>(out));
return Void();
}
Return<void> GrallocMapper::dumpBuffers(dumpBuffers_cb hidl_cb)
{
- common::dumpBuffers(hidl_cb);
+ auto bufferDump = common::dumpBuffers();
+ std::vector<IMapper::BufferDump> outBufDump;
+ for (auto dump : bufferDump) {
+ outBufDump.push_back(static_cast<IMapper::BufferDump>(dump));
+ }
+ hidl_cb(hidl::Error::NONE, hidl_vec(outBufDump));
return Void();
}
Return<void> GrallocMapper::getReservedRegion(void *buffer, getReservedRegion_cb hidl_cb)
{
- common::getReservedRegion(buffer, hidl_cb);
+ void *reservedRegion = nullptr;
+ uint64_t reservedSize = 0;
+ hidl::Error err = static_cast<hidl::Error>(
+ common::getReservedRegion(static_cast<buffer_handle_t>(buffer),
+ &reservedRegion, reservedSize));
+ if (err != hidl::Error::NONE) {
+ reservedRegion = nullptr;
+ reservedSize = 0;
+ }
+ hidl_cb(err, reservedRegion, reservedSize);
return Void();
}