Merge "SharedMemory API changes" into oc-mr1-dev
This commit is contained in:
committed by
Android (Google) Code Review
commit
edf3384307
@@ -31077,7 +31077,6 @@ package android.os {
|
||||
ctor public MemoryFile(java.lang.String, int) throws java.io.IOException;
|
||||
method public deprecated synchronized boolean allowPurging(boolean) throws java.io.IOException;
|
||||
method public void close();
|
||||
method public java.io.FileDescriptor getFileDescriptor() throws java.io.IOException;
|
||||
method public java.io.InputStream getInputStream();
|
||||
method public java.io.OutputStream getOutputStream();
|
||||
method public deprecated boolean isPurgingAllowed();
|
||||
@@ -31509,8 +31508,6 @@ package android.os {
|
||||
method public void close();
|
||||
method public static android.os.SharedMemory create(java.lang.String, int) throws android.system.ErrnoException;
|
||||
method public int describeContents();
|
||||
method public int getFd();
|
||||
method public java.io.FileDescriptor getFileDescriptor();
|
||||
method public int getSize();
|
||||
method public java.nio.ByteBuffer map(int, int, int) throws android.system.ErrnoException;
|
||||
method public java.nio.ByteBuffer mapReadOnly() throws android.system.ErrnoException;
|
||||
|
||||
@@ -33920,7 +33920,6 @@ package android.os {
|
||||
ctor public MemoryFile(java.lang.String, int) throws java.io.IOException;
|
||||
method public deprecated synchronized boolean allowPurging(boolean) throws java.io.IOException;
|
||||
method public void close();
|
||||
method public java.io.FileDescriptor getFileDescriptor() throws java.io.IOException;
|
||||
method public java.io.InputStream getInputStream();
|
||||
method public java.io.OutputStream getOutputStream();
|
||||
method public deprecated boolean isPurgingAllowed();
|
||||
@@ -34381,8 +34380,6 @@ package android.os {
|
||||
method public void close();
|
||||
method public static android.os.SharedMemory create(java.lang.String, int) throws android.system.ErrnoException;
|
||||
method public int describeContents();
|
||||
method public int getFd();
|
||||
method public java.io.FileDescriptor getFileDescriptor();
|
||||
method public int getSize();
|
||||
method public java.nio.ByteBuffer map(int, int, int) throws android.system.ErrnoException;
|
||||
method public java.nio.ByteBuffer mapReadOnly() throws android.system.ErrnoException;
|
||||
|
||||
@@ -31234,7 +31234,6 @@ package android.os {
|
||||
ctor public MemoryFile(java.lang.String, int) throws java.io.IOException;
|
||||
method public deprecated synchronized boolean allowPurging(boolean) throws java.io.IOException;
|
||||
method public void close();
|
||||
method public java.io.FileDescriptor getFileDescriptor() throws java.io.IOException;
|
||||
method public java.io.InputStream getInputStream();
|
||||
method public java.io.OutputStream getOutputStream();
|
||||
method public deprecated boolean isPurgingAllowed();
|
||||
@@ -31667,8 +31666,6 @@ package android.os {
|
||||
method public void close();
|
||||
method public static android.os.SharedMemory create(java.lang.String, int) throws android.system.ErrnoException;
|
||||
method public int describeContents();
|
||||
method public int getFd();
|
||||
method public java.io.FileDescriptor getFileDescriptor();
|
||||
method public int getSize();
|
||||
method public java.nio.ByteBuffer map(int, int, int) throws android.system.ErrnoException;
|
||||
method public java.nio.ByteBuffer mapReadOnly() throws android.system.ErrnoException;
|
||||
|
||||
@@ -219,6 +219,8 @@ public class MemoryFile {
|
||||
* The returned file descriptor is not duplicated.
|
||||
*
|
||||
* @throws IOException If the memory file has been closed.
|
||||
*
|
||||
* @hide
|
||||
*/
|
||||
public FileDescriptor getFileDescriptor() throws IOException {
|
||||
return mSharedMemory.getFileDescriptor();
|
||||
|
||||
@@ -60,7 +60,8 @@ public final class SharedMemory implements Parcelable, Closeable {
|
||||
}
|
||||
|
||||
mMemoryRegistration = new MemoryRegistration(mSize);
|
||||
mCleaner = Cleaner.create(this, new Closer(mFileDescriptor, mMemoryRegistration));
|
||||
mCleaner = Cleaner.create(mFileDescriptor,
|
||||
new Closer(mFileDescriptor, mMemoryRegistration));
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -138,6 +139,8 @@ public final class SharedMemory implements Parcelable, Closeable {
|
||||
* This FileDescriptor is interoperable with the ASharedMemory NDK APIs.
|
||||
*
|
||||
* @return Returns the FileDescriptor associated with this object.
|
||||
*
|
||||
* @hide Exists only for MemoryFile interop
|
||||
*/
|
||||
public @NonNull FileDescriptor getFileDescriptor() {
|
||||
return mFileDescriptor;
|
||||
@@ -150,6 +153,8 @@ public final class SharedMemory implements Parcelable, Closeable {
|
||||
* This fd is interoperable with the ASharedMemory NDK APIs.
|
||||
*
|
||||
* @return Returns the native fd associated with this object, or -1 if it is already closed.
|
||||
*
|
||||
* @hide Exposed for native ASharedMemory_dupFromJava()
|
||||
*/
|
||||
public int getFd() {
|
||||
return mFileDescriptor.getInt$();
|
||||
|
||||
@@ -198,6 +198,7 @@ LIBANDROID {
|
||||
ASharedMemory_create; # introduced=26
|
||||
ASharedMemory_getSize; # introduced=26
|
||||
ASharedMemory_setProt; # introduced=26
|
||||
ASharedMemory_dupFromJava; # introduced=27
|
||||
AStorageManager_delete;
|
||||
AStorageManager_getMountedObbPath;
|
||||
AStorageManager_isObbMounted;
|
||||
|
||||
@@ -14,10 +14,36 @@
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
#include <jni.h>
|
||||
|
||||
#include <android/sharedmem.h>
|
||||
#include <android/sharedmem_jni.h>
|
||||
#include <cutils/ashmem.h>
|
||||
#include <log/log.h>
|
||||
#include <utils/Errors.h>
|
||||
|
||||
#include <mutex>
|
||||
#include <unistd.h>
|
||||
|
||||
static struct {
|
||||
jclass clazz;
|
||||
jmethodID getFd;
|
||||
} sSharedMemory;
|
||||
|
||||
static void jniInit(JNIEnv* env) {
|
||||
static std::once_flag sJniInitialized;
|
||||
std::call_once(sJniInitialized, [](JNIEnv* env) {
|
||||
jclass clazz = env->FindClass("android/os/SharedMemory");
|
||||
LOG_ALWAYS_FATAL_IF(clazz == nullptr, "Failed to find android.os.SharedMemory");
|
||||
sSharedMemory.clazz = (jclass) env->NewGlobalRef(clazz);
|
||||
LOG_ALWAYS_FATAL_IF(sSharedMemory.clazz == nullptr,
|
||||
"Failed to create global ref of android.os.SharedMemory");
|
||||
sSharedMemory.getFd = env->GetMethodID(sSharedMemory.clazz, "getFd", "()I");
|
||||
LOG_ALWAYS_FATAL_IF(sSharedMemory.getFd == nullptr,
|
||||
"Failed to find method SharedMemory#getFd()");
|
||||
}, env);
|
||||
}
|
||||
|
||||
int ASharedMemory_create(const char *name, size_t size) {
|
||||
if (size == 0) {
|
||||
return android::BAD_VALUE;
|
||||
@@ -32,3 +58,20 @@ size_t ASharedMemory_getSize(int fd) {
|
||||
int ASharedMemory_setProt(int fd, int prot) {
|
||||
return ashmem_set_prot_region(fd, prot);
|
||||
}
|
||||
|
||||
int ASharedMemory_dupFromJava(JNIEnv* env, jobject javaSharedMemory) {
|
||||
if (env == nullptr || javaSharedMemory == nullptr) {
|
||||
return -1;
|
||||
}
|
||||
jniInit(env);
|
||||
if (!env->IsInstanceOf(javaSharedMemory, sSharedMemory.clazz)) {
|
||||
ALOGW("ASharedMemory_dupFromJava called with object "
|
||||
"that's not an instanceof android.os.SharedMemory");
|
||||
return -1;
|
||||
}
|
||||
int fd = env->CallIntMethod(javaSharedMemory, sSharedMemory.getFd);
|
||||
if (fd != -1) {
|
||||
fd = dup(fd);
|
||||
}
|
||||
return fd;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user