AArch64: Make graphics classes 64-bit compatible
This a merger of two commits submitted to AOSP by the following authors: ashok.bhat@arm.com, david.butcher@arm.coma craig.barber@arm.com, kevin.petit@arm.com and marcus.oakland@arm.com Due to the very large number of internal conflicts, I have chosen to cherry-pick this change instead of letting it merge through AOSP because the merge conflict resolution would be very hard to review. Commit messages below: ================================================ AArch64: Make graphics classes 64-bit compatible Changes in this patch include [x] Long is used to store native pointers as they can be 64-bit. [x] Some minor changes have been done to conform with standard JNI practice (e.g. use of jint instead of int in JNI function prototypes) [x] AssetAtlasManager is not completely 64-bit compatible yet. Specifically mAtlasMap member has to be converted to hold native pointer using long. Added a TODO to AssetAtlasManager.java to indicate the change required. Signed-off-by: Ashok Bhat <ashok.bhat@arm.com> Signed-off-by: Craig Barber <craig.barber@arm.com> Signed-off-by: Kévin PETIT <kevin.petit@arm.com> Signed-off-by: Marcus Oakland <marcus.oakland@arm.com> ================================================================== AArch64: Use long for pointers in graphics/Camera For storing pointers, long is used in android/graphics/Camera class, as native pointers can be 64-bit. In addition, some minor changes have been done to conform with standard JNI practice (e.g. use of jint instead of int in JNI function prototypes) Signed-off-by: Ashok Bhat <ashok.bhat@arm.com> Signed-off-by: Marcus Oakland <marcus.oakland@arm.com> =================================================================== Change-Id: Id5793fa0ebc17ee8b1eecf4b3f327977fdccff71
This commit is contained in:
committed by
Narayan Kamath
parent
729b12c7a9
commit
36bef0bf30
@@ -27,7 +27,7 @@ package android.graphics;
|
||||
* @hide
|
||||
*/
|
||||
public final class LargeBitmap {
|
||||
private int mNativeLargeBitmap;
|
||||
private long mNativeLargeBitmap;
|
||||
private boolean mRecycled;
|
||||
|
||||
/* Private constructor that must received an already allocated native
|
||||
@@ -35,8 +35,8 @@ public final class LargeBitmap {
|
||||
|
||||
This can be called from JNI code.
|
||||
*/
|
||||
private LargeBitmap(int lbm) {
|
||||
mNativeLargeBitmap = lbm;
|
||||
private LargeBitmap(long nativeLbm) {
|
||||
mNativeLargeBitmap = nativeLbm;
|
||||
mRecycled = false;
|
||||
}
|
||||
|
||||
@@ -109,10 +109,10 @@ public final class LargeBitmap {
|
||||
recycle();
|
||||
}
|
||||
|
||||
private static native Bitmap nativeDecodeRegion(int lbm,
|
||||
private static native Bitmap nativeDecodeRegion(long nativeLbm,
|
||||
int start_x, int start_y, int width, int height,
|
||||
BitmapFactory.Options options);
|
||||
private static native int nativeGetWidth(int lbm);
|
||||
private static native int nativeGetHeight(int lbm);
|
||||
private static native void nativeClean(int lbm);
|
||||
private static native int nativeGetWidth(long nativeLbm);
|
||||
private static native int nativeGetHeight(long nativeLbm);
|
||||
private static native void nativeClean(long nativeLbm);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user