Files

243 lines
7.9 KiB
C
Raw Permalink Normal View History

2024-09-27 19:16:49 +08:00
/*
* Copyright (c) 2021 Huawei Device Co., Ltd.
* 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.
*/
/**
* @file ashmem.h
*
* @brief Provides the <b>Ashmem</b> class implemented in c_utils to operate the
* Anonymous Shared Memory (Ashmem).
*/
#ifndef UTILS_BASE_ASHMEM_H
#define UTILS_BASE_ASHMEM_H
#include <cstddef>
#include <linux/ashmem.h>
#ifdef UTILS_CXX_RUST
#include <memory>
#endif
#include "refbase.h"
#include "parcel.h"
namespace OHOS {
class Ashmem;
#ifdef UTILS_CXX_RUST
using c_void = void;
const c_void* AsVoidPtr(const char* inPtr);
const char* AsCharPtr(const c_void* inPtr);
std::shared_ptr<Ashmem> CreateAshmemStd(const char *name, int32_t size);
#endif
/**
* @brief Creates an <b>Ashmem</b> region in the kernel.
*
* @param name Indicates the pointer to the name that will be
* copied and assigned to the <b>Ashmem</b> region in the kernel.
* @param size Indicates the size of the <b>Ashmem</b> region to create.
* @return Returns the file descriptor of the <b>Ashmem</b> region.
*/
int AshmemCreate(const char *name, size_t size);
/**
* @brief Sets the protection flag of an <b>Ashmem</b> region in the kernel.
*
* @param fd Indicates the file descriptor of an <b>Ashmem</b> region.
* @param prot Indicates the value of the protection flag.
* @return Returns <b>0</b> if the operation is successful;
* returns <b>-1</b> otherwise.
*/
int AshmemSetProt(int fd, int prot);
/**
* @brief Obtains the size of a specific <b>Ashmem</b> region in the kernel.
*
* @param fd Indicates the file descriptor of an <b>Ashmem</b> region.
* @return Returns the size of the <b>Ashmem</b> region.
*/
int AshmemGetSize(int fd);
/**
* @brief Provides the <b>Ashmem</b> class implemented in c_utils to
* operate the Anonymous Shared Memory (Ashmem).
*
* You can use the interfaces in this class to create <b>Ashmem</b> regions
* and map them to implement write and read operations.
*
* @note <b>Ashmem</b> regions should be unmapped and closed manually,
* though managed by a smart pointer.
*/
class Ashmem : public virtual RefBase {
public:
/**
* @brief Creates an <b>Ashmem</b> region in the kernel.
*
* The <b>/dev/ashmem</b> file will be opened, whose file
* descriptor will be held by the created <b>Ashmem</b> region.
*
* @param name Indicates the pointer to the name that will be
* copied and assigned to the <b>Ashmem</b> region in the kernel.
* @param size Indicates the size of the <b>Ashmem</b> region.
* @return Returns the created <b>Ashmem</b> region referenced by a
* smart pointer.
* @note Before writing/reading data in the region, use `MapAshmem()`.
*
*/
static sptr<Ashmem> CreateAshmem(const char *name, int32_t size);
/**
* @brief Construct a new Ashmem object.
*
* @param fd File descriptor of an ashmem in kenrel.
* @param size Size of the corresponding ashmem region in kernel.
*/
Ashmem(int fd, int32_t size);
~Ashmem() override;
/**
* @brief Get file descriptor of the corresponding ashmem in kernel.
*
* @return Corresponding file descriptor of this Ashmem object. It will be
* 0 when ashmem is closed.
*/
int GetAshmemFd() const
{
return memoryFd_;
};
/**
* @brief Set the protection flag of ashmem region in kernel.
*
* @param protectionType Value of protection flag.
* @return True if set successful.
*/
bool SetProtection(int protectionType) const;
/**
* @brief Get the protection flag of ashmem region in kernel.
*
* @return Value of protection flag. Refer to linux manual.
*/
int GetProtection() const;
/**
* @brief Get the size of ashmem region in kernel.
*
* @return Value of size.
*/
int32_t GetAshmemSize() const;
#ifdef UTILS_CXX_RUST
void CloseAshmem() const;
bool MapAshmem(int mapType) const;
bool MapReadAndWriteAshmem() const;
bool MapReadOnlyAshmem() const;
void UnmapAshmem() const;
bool WriteToAshmem(const void *data, int32_t size, int32_t offset) const;
const void *ReadFromAshmem(int32_t size, int32_t offset) const;
#else
/**
* @brief Closes this <b>Ashmem</b> region (through the file descriptor).
*
* All inner parameters will be cleared.
*
* @note An <b>Ashmem</b> region will be unmapped by `UnmapAshmem()`
* before being closed.
*/
void CloseAshmem();
/**
* @brief Maps this <b>Ashmem</b> region in the kernel to user space.
*
* @param mapType Indicates the protection flag of the mapped region in
* user space.
* @return Returns <b>true</b> if mapping is successful.
*/
bool MapAshmem(int mapType);
/**
* @brief Maps this <b>Ashmem</b> region in read/write mode.
*
* It calls `MapAshmem(PROT_READ | PROT_WRITE)`.
*
* @return Returns <b>true</b> if mapping is successful.
*/
bool MapReadAndWriteAshmem();
/**
* @brief Maps this <b>Ashmem</b> region in read-only mode.
*
* It calls `MapAshmem(PROT_READ)`.
*
* @return Returns <b>true</b> if mapping is successful.
*/
bool MapReadOnlyAshmem();
/**
* @brief Unmaps this <b>Ashmem</b> region.
*
* Unmapping works only when the <b>Ashmem</b> region has been mapped.
* It will clear the protection flag.
*/
void UnmapAshmem();
/**
* @brief Writes data to the `offset` position of this <b>Ashmem</b> region.
*
* Bounds and the protection flag will be checked.
*
* @param data Indicates the pointer to the data to write.
* @param size Indicates the size of the data to write, in bytes.
* @param offset Indicates the offset from the start position of the
* <b>Ashmem</b> region.
* @return Returns <b>True</b> if the operation is successful; returns
* <b>False</b> if overflow occurs or the protection flag is illegal.
* @note This operation requires the write permission on both the
* <b>Ashmem</b> region in the kernel and the mapped region in user space.
*/
bool WriteToAshmem(const void *data, int32_t size, int32_t offset);
/**
* @brief Reads data from the `offset` position of this <b>Ashmem</b> region.
*
* Bounds and the protection flag will be checked.
*
* @param size Indicates the size of the data to read, in bytes.
* @param offset Indicates the offset from the start position of
* the <b>Ashmem</b> region.
* @return Returns the void-type pointer to the data. `nullptr` is returned
* if overflow occurs or the protection flag is illegal.
* @note This operation requires the read permission on both the
* <b>Ashmem</b> region in the kernel and the mapped region in user space.
*/
const void *ReadFromAshmem(int32_t size, int32_t offset);
#endif
private:
#ifdef UTILS_CXX_RUST
mutable int memoryFd_; // File descriptor of the Ashmem region.
mutable int32_t memorySize_; // Size of the Ashmem region.
mutable int flag_; // Protection flag of the Ashmem region in user space.
mutable void *startAddr_; // Start address of the Ashmem region.
#else
int memoryFd_; // File descriptor of the Ashmem region.
int32_t memorySize_; // Size of the Ashmem region.
int flag_; // Protection flag of the Ashmem region in user space.
void *startAddr_; // Start address of the Ashmem region.
#endif
bool CheckValid(int32_t size, int32_t offset, int cmd) const;
};
} // namespace OHOS
#endif