Fixed
Status Update
Comments
dw...@gmail.com <dw...@gmail.com> #2
Project: platform/frameworks/support
Branch: androidx-master-dev
commit 87230c0d52d3d534692a31c8ffbb378fc3508111
Author: Chris Craik <ccraik@google.com>
Date: Tue Oct 08 08:28:15 2019
Remove warmup log and array alloc from critical path
Bug:142058671
Test: ./gradlew benchmark:benchmark-benchmark:cC # with systrace / method tracing
When transitioning out of warmup, saw array allocation in method
trace, and log work in systrace. Still more improvements to make here.
Change-Id: Ibddbc3dd90e7802d3777f690be1a684ced4fc339
M benchmark/common/src/main/java/androidx/benchmark/BenchmarkState.kt
M benchmark/common/src/main/java/androidx/benchmark/WarmupManager.kt
https://android-review.googlesource.com/1134877
https://goto.google.com/android-sha1/87230c0d52d3d534692a31c8ffbb378fc3508111
Branch: androidx-master-dev
commit 87230c0d52d3d534692a31c8ffbb378fc3508111
Author: Chris Craik <ccraik@google.com>
Date: Tue Oct 08 08:28:15 2019
Remove warmup log and array alloc from critical path
Bug:142058671
Test: ./gradlew benchmark:benchmark-benchmark:cC # with systrace / method tracing
When transitioning out of warmup, saw array allocation in method
trace, and log work in systrace. Still more improvements to make here.
Change-Id: Ibddbc3dd90e7802d3777f690be1a684ced4fc339
M benchmark/common/src/main/java/androidx/benchmark/BenchmarkState.kt
M benchmark/common/src/main/java/androidx/benchmark/WarmupManager.kt
fu...@google.com <fu...@google.com> #3
Project: platform/frameworks/support
Branch: androidx-master-dev
commit b15ef41ce16efc5c3b7d3dfe0d04157ffa474ff2
Author: Chris Craik <ccraik@google.com>
Date: Tue Oct 08 15:06:18 2019
Add tracing to benchmark
Bug:142058671
Test: tests in benchmark-benchmark, with systrace
Change-Id: Ic7c35ad8c8b18e478ad2a19627df92e3241d8a0a
M benchmark/common/api/1.0.0-rc01.txt
M benchmark/common/api/current.txt
M benchmark/common/api/public_plus_experimental_1.0.0-rc01.txt
M benchmark/common/api/public_plus_experimental_current.txt
M benchmark/common/api/restricted_1.0.0-rc01.txt
M benchmark/common/api/restricted_current.txt
M benchmark/common/src/main/java/androidx/benchmark/BenchmarkState.kt
A benchmark/common/src/main/java/androidx/benchmark/TraceCompat.kt
M benchmark/junit4/src/main/java/androidx/benchmark/junit4/BenchmarkRule.kt
https://android-review.googlesource.com/1136816
https://goto.google.com/android-sha1/b15ef41ce16efc5c3b7d3dfe0d04157ffa474ff2
Branch: androidx-master-dev
commit b15ef41ce16efc5c3b7d3dfe0d04157ffa474ff2
Author: Chris Craik <ccraik@google.com>
Date: Tue Oct 08 15:06:18 2019
Add tracing to benchmark
Bug:142058671
Test: tests in benchmark-benchmark, with systrace
Change-Id: Ic7c35ad8c8b18e478ad2a19627df92e3241d8a0a
M benchmark/common/api/1.0.0-rc01.txt
M benchmark/common/api/current.txt
M benchmark/common/api/public_plus_experimental_1.0.0-rc01.txt
M benchmark/common/api/public_plus_experimental_current.txt
M benchmark/common/api/restricted_1.0.0-rc01.txt
M benchmark/common/api/restricted_current.txt
M benchmark/common/src/main/java/androidx/benchmark/BenchmarkState.kt
A benchmark/common/src/main/java/androidx/benchmark/TraceCompat.kt
M benchmark/junit4/src/main/java/androidx/benchmark/junit4/BenchmarkRule.kt
dw...@gmail.com <dw...@gmail.com> #4
Project: platform/frameworks/support
Branch: androidx-master-dev
commit 345f86d34f7e373f464c0d8185e392b067a2de4a
Author: Chris Craik <ccraik@google.com>
Date: Wed Oct 09 17:37:17 2019
Bump thread priority of benchmarks and JIT during benchmarks
The JIT thread is so low priority that other parallel tasks can starve
it, especially for the first few benchmarks when a process runs.
The system can spin up significant background work right after install
and/or instrumentation start, and on locked devices with only two big
cores, there aren't enough CPUs to go around - warmup and benchmark
both complete before relevant JIT is complete.
Now, we bump the priority of both the benchmark and JIT thread.
Tracing benchmarks show that the JIT thread goes much faster, which
should significantly reduce the chance we capture results on unjitted
code.
This may also motivate us to use CPU affinity + locked small cores in
the future, we can keep monitoring.
Test: ./gradlew benchmark:b-c:cC
Test: ./gradlew benchmark:b-b:cC
Test: ./gradlew recyclerview:r-b:cC
This CL also adds more logging, and unifies all logging under
"benchmark" tag. This logging was very useful in discovering and
diagnosing the priority problem, since it showed the edge cases where
jit finished *during* the measure pass.
Bug: 140773023
Bug: 142058671
Change-Id: If542e3cb8867165cf7b4688090ee534e68a23562
M benchmark/common/src/androidTest/java/androidx/benchmark/BenchmarkStateTest.kt
M benchmark/common/src/main/java/androidx/benchmark/BenchmarkState.kt
A benchmark/common/src/main/java/androidx/benchmark/ThreadPriority.kt
M benchmark/common/src/main/java/androidx/benchmark/WarmupManager.kt
M benchmark/junit4/src/main/java/androidx/benchmark/junit4/BenchmarkRule.kt
https://android-review.googlesource.com/1138018
https://goto.google.com/android-sha1/345f86d34f7e373f464c0d8185e392b067a2de4a
Branch: androidx-master-dev
commit 345f86d34f7e373f464c0d8185e392b067a2de4a
Author: Chris Craik <ccraik@google.com>
Date: Wed Oct 09 17:37:17 2019
Bump thread priority of benchmarks and JIT during benchmarks
The JIT thread is so low priority that other parallel tasks can starve
it, especially for the first few benchmarks when a process runs.
The system can spin up significant background work right after install
and/or instrumentation start, and on locked devices with only two big
cores, there aren't enough CPUs to go around - warmup and benchmark
both complete before relevant JIT is complete.
Now, we bump the priority of both the benchmark and JIT thread.
Tracing benchmarks show that the JIT thread goes much faster, which
should significantly reduce the chance we capture results on unjitted
code.
This may also motivate us to use CPU affinity + locked small cores in
the future, we can keep monitoring.
Test: ./gradlew benchmark:b-c:cC
Test: ./gradlew benchmark:b-b:cC
Test: ./gradlew recyclerview:r-b:cC
This CL also adds more logging, and unifies all logging under
"benchmark" tag. This logging was very useful in discovering and
diagnosing the priority problem, since it showed the edge cases where
jit finished *during* the measure pass.
Bug: 140773023
Bug: 142058671
Change-Id: If542e3cb8867165cf7b4688090ee534e68a23562
M benchmark/common/src/androidTest/java/androidx/benchmark/BenchmarkStateTest.kt
M benchmark/common/src/main/java/androidx/benchmark/BenchmarkState.kt
A benchmark/common/src/main/java/androidx/benchmark/ThreadPriority.kt
M benchmark/common/src/main/java/androidx/benchmark/WarmupManager.kt
M benchmark/junit4/src/main/java/androidx/benchmark/junit4/BenchmarkRule.kt
fu...@google.com <fu...@google.com> #5
As part of trying to reland Owen's looping arch change, I verified that it does significantly improve this problem, see attached .json files - specifically the measured numbers.
E.g. Parameterized benchmark, before (both variants):
"runs": [
18,
12,
12,
12,
12,
"runs": [
17,
5,
5,
6,
5,
After:
"runs": [
14,
11,
11,
11,
11,
"runs": [
4,
4,
4,
4,
4,
Or TrivialJavaBenchmark, Before:
"runs": [
24,
12,
12,
12,
12,
After:
runs": [
11,
11,
11,
11,
11,
Let's mark this fixed once the warmup rearch lands again.
E.g. Parameterized benchmark, before (both variants):
"runs": [
18,
12,
12,
12,
12,
"runs": [
17,
5,
5,
6,
5,
After:
"runs": [
14,
11,
11,
11,
11,
"runs": [
4,
4,
4,
4,
4,
Or TrivialJavaBenchmark, Before:
"runs": [
24,
12,
12,
12,
12,
After:
runs": [
11,
11,
11,
11,
11,
Let's mark this fixed once the warmup rearch lands again.
sc...@google.com <sc...@google.com> #6
In addition, we've lowered back down our measurements for our smallest (noop) benchmarks. Looks like making warmup and measurement more similar means we've fully jitted a lot more code. Since tiny benchmarks measure quickly, we were likely not giving the code in measurement codepaths time to jit.
I'd guess much of the remaining cost for the first loop is likely branch mispredictions for the loop early return itself (used only during measurement), but that only seems to only significantly affect the first benchmark (the first 'after' number above in ParameterizedBenchmark).
I'd guess much of the remaining cost for the first loop is likely branch mispredictions for the loop early return itself (used only during measurement), but that only seems to only significantly affect the first benchmark (the first 'after' number above in ParameterizedBenchmark).
dw...@gmail.com <dw...@gmail.com> #7
Hello, thanks for response. I does not have this device - it's my tester reproduce this bug.
The crash in startPreview I see on crashlytics.
In my own logcat i see exception that was catched Camera is closed.
I'll try to grab system logs and send you.
The crash in startPreview I see on crashlytics.
In my own logcat i see exception that was catched Camera is closed.
I'll try to grab system logs and send you.
dw...@gmail.com <dw...@gmail.com> #8
Hello, this is logcat of this crash Fatal Exception: java.lang.RuntimeException
startPreview failed
I hope it'll help, thanks
startPreview failed
I hope it'll help, thanks
sc...@google.com <sc...@google.com> #9
Yes. This is helpful. I am able to get more context about the problem .
E/RequestThread-0(28446): Hit timeout for jpeg callback!
W/CaptureCollector(28446): Jpeg buffers dropped for request: 1
This is probably a bug in android 5.0 framework. We'll see if we can workaround it.
E/RequestThread-0(28446): Hit timeout for jpeg callback!
W/CaptureCollector(28446): Jpeg buffers dropped for request: 1
This is probably a bug in android 5.0 framework. We'll see if we can workaround it.
sc...@google.com <sc...@google.com> #10
found same issue reported on samsung s4 android 5.0 using camear2 API.
https://cmsdk.com/android/taking-picture-with-flash--camera2.html
so we can be sure that cameraX does not cause the problem. and we are looking into whether it is possible to workaround it on behalf of apps.
so we can be sure that cameraX does not cause the problem. and we are looking into whether it is possible to workaround it on behalf of apps.
dw...@gmail.com <dw...@gmail.com> #11
Thanks for response! Okay, I think we will not enable this camera on android 5.0. Will start from 5.1. If you fix this somehow it would be awesome! Good luck!
ap...@google.com <ap...@google.com> #12
Project: platform/frameworks/support
Branch: androidx-master-dev
commit 9216b72657b3fe5ff8cbe9db3255919fd67963cd
Author: Scott Nien <scottnien@google.com>
Date: Fri Oct 30 16:41:07 2020
Disable auto flash AE mode in Samsung A3 devices
Preview stops working after taking a photo in auto flash AE mode
in Samsung A3 devices. There is no solution to fix that issues.
For now we can only turn off the auto flash mode to workaround it.
Relnote:"Disabled auto flash on Samsung A3 devices to fix the crash
when taking a photo with auto flash AE mode on Samsung A3 devices."
Test: AutoFlashAEModeDisablerTest
Bug: 157535165
Change-Id: Ia5fe30075e4ec65abe4030e4589a35e3c30a607f
M camera/camera-camera2/src/main/java/androidx/camera/camera2/internal/Camera2CameraControlImpl.java
A camera/camera-camera2/src/main/java/androidx/camera/camera2/internal/compat/quirk/CrashWhenTakingPhotoWithAutoFlashAEModeQuirk.java
M camera/camera-camera2/src/main/java/androidx/camera/camera2/internal/compat/quirk/DeviceQuirksLoader.java
A camera/camera-camera2/src/main/java/androidx/camera/camera2/internal/compat/workaround/AutoFlashAEModeDisabler.java
A camera/camera-camera2/src/test/java/androidx/camera/camera2/internal/compat/workaround/AutoFlashAEModeDisablerTest.java
M camera/camera-core/src/main/java/androidx/camera/core/ImageCapture.java
https://android-review.googlesource.com/1481136
Branch: androidx-master-dev
commit 9216b72657b3fe5ff8cbe9db3255919fd67963cd
Author: Scott Nien <scottnien@google.com>
Date: Fri Oct 30 16:41:07 2020
Disable auto flash AE mode in Samsung A3 devices
Preview stops working after taking a photo in auto flash AE mode
in Samsung A3 devices. There is no solution to fix that issues.
For now we can only turn off the auto flash mode to workaround it.
Relnote:"Disabled auto flash on Samsung A3 devices to fix the crash
when taking a photo with auto flash AE mode on Samsung A3 devices."
Test: AutoFlashAEModeDisablerTest
Bug: 157535165
Change-Id: Ia5fe30075e4ec65abe4030e4589a35e3c30a607f
M camera/camera-camera2/src/main/java/androidx/camera/camera2/internal/Camera2CameraControlImpl.java
A camera/camera-camera2/src/main/java/androidx/camera/camera2/internal/compat/quirk/CrashWhenTakingPhotoWithAutoFlashAEModeQuirk.java
M camera/camera-camera2/src/main/java/androidx/camera/camera2/internal/compat/quirk/DeviceQuirksLoader.java
A camera/camera-camera2/src/main/java/androidx/camera/camera2/internal/compat/workaround/AutoFlashAEModeDisabler.java
A camera/camera-camera2/src/test/java/androidx/camera/camera2/internal/compat/workaround/AutoFlashAEModeDisablerTest.java
M camera/camera-core/src/main/java/androidx/camera/core/ImageCapture.java
sc...@google.com <sc...@google.com> #13
Hi dwajot1
FYI, starting from beta12 (to be released in November), CameraX will disable the auto flash on Samsung A3 devices to workaround the issue at CameraX side. It would be nice if you can check that after beta12 is release.
FYI, starting from beta12 (to be released in November), CameraX will disable the auto flash on Samsung A3 devices to workaround the issue at CameraX side. It would be nice if you can check that after beta12 is release.
al...@gmail.com <al...@gmail.com> #14
Fatal Exception: java.lang.RuntimeException
startPreview failed
Reported in crashlytics after integrating camerax.
Device: Galaxy Note 4
Android build : 5.0.1
startPreview failed
Reported in crashlytics after integrating camerax.
Device: Galaxy Note 4
Android build : 5.0.1
sc...@google.com <sc...@google.com> #15
Thanks for reporting this !
+ Wenhung,
Please help disabling FLASH_MODE_AUTO on Galaxy Note 4 as well
+ Wenhung,
Please help disabling FLASH_MODE_AUTO on Galaxy Note 4 as well
we...@google.com <we...@google.com> #16
Hi ali,
It seems like Galaxy Note 4 has multiple chipsets.
Would you mind providing the device model or type id? We'd like to set a list of devices to workaround this issue.
It seems like Galaxy Note 4 has multiple chipsets.
Would you mind providing the device model or type id? We'd like to set a list of devices to workaround this issue.
Description
ANDROID OS BUILD NUMBER: (Samsung SM-A300H version 5.0.2)
DEVICE NAME: (Samsung Galaxy A3)
DESCRIPTION:
I'm adding camerax to app and my tester find issue on one device - when use ImageCapture.FLASH_MODE_AUTO and capture image in dark when flash triggered - app crashed
Fatal Exception: java.lang.RuntimeException
startPreview failed
android.hardware.Camera.startPreview (Camera.java)
android.hardware.camera2.legacy.RequestThreadManager.startPreview (RequestThreadManager.java:275)
android.hardware.camera2.legacy.RequestThreadManager.doPreviewCapture (RequestThreadManager.java:317)
android.hardware.camera2.legacy.RequestThreadManager.access$1600 (RequestThreadManager.java:61)
android.hardware.camera2.legacy.RequestThreadManager$5.handleMessage (RequestThreadManager.java:756)
android.os.Handler.dispatchMessage (Handler.java:98)
android.os.Looper.loop (Looper.java:135)
android.os.HandlerThread.run (HandlerThread.java:61)
STEPS TO REPRODUCE:
1. use Samsung Galaxy A3
2. set ImageCapture.FLASH_MODE_AUTO
3. take a picture in dark
OBSERVED RESULTS:
app crashed
EXPECTED RESULTS:
taking picture or handle exception
REPRODUCIBILITY: (5 of 5, 1 of 100, etc)
5 of 5
ADDITIONAL INFORMATION:
In our log I see different crash:
Throwable occurred: androidx.camera.core.ImageCaptureException: Camera is closed.
at androidx.camera.core.ImageCapture$ImageCaptureRequest.lambda$notifyCallbackError$1$ImageCapture$ImageCaptureRequest(ImageCapture.java:1963)
at androidx.camera.core.-$$Lambda$ImageCapture$ImageCaptureRequest$1G7WSvt8TANxhZtOyewefm68pg4.run(lambda)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5536)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1397)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1192)
Caused by: androidx.camera.core.CameraClosedException: Camera is closed.
at androidx.camera.core.ImageCapture.abortImageCaptureRequests(ImageCapture.java:703)
at androidx.camera.core.ImageCapture.onStateOffline(ImageCapture.java:699)
at androidx.camera.camera2.internal.Camera2CameraImpl.lambda$notifyStateOfflineToUseCases$12(Camera2CameraImpl.java:689)
at androidx.camera.camera2.internal.-$$Lambda$Camera2CameraImpl$hp2EIAmfp4eGOX-qpuivXiBeeMA.run(lambda)
CODE FRAGMENTS (this will help us troubleshoot your issues):
this is how I bindCameraUseCases
val metrics = DisplayMetrics().also { viewFinder.display.getRealMetrics(it) }
val screenAspectRatio = aspectRatio(metrics.widthPixels, metrics.heightPixels)
val rotation = viewFinder.display.rotation
val cameraSelector = CameraSelector.Builder().requireLensFacing(lensFacing).build()
val cameraProviderFuture = ProcessCameraProvider.getInstance(this)
cameraProviderFuture.addListener(Runnable {
val cameraProvider: ProcessCameraProvider = cameraProviderFuture.get()
preview = Preview.Builder()
.setTargetAspectRatio(screenAspectRatio)
.setTargetRotation(rotation)
.build()
imageCapture = ImageCapture.Builder()
.setCaptureMode(ImageCapture.CAPTURE_MODE_MINIMIZE_LATENCY)
.setTargetAspectRatio(screenAspectRatio)
.setTargetRotation(rotation)
.setFlashMode(ImageCapture.FLASH_MODE_AUTO)
.build()
cameraProvider.unbindAll()
try {
camera = cameraProvider.bindToLifecycle(this, cameraSelector, preview, imageCapture)
preview?.setSurfaceProvider(viewFinder.createSurfaceProvider(camera?.cameraInfo))
} catch (exc: Exception) {
}
}, ContextCompat.getMainExecutor(this))
private fun aspectRatio(width: Int, height: Int): Int {
val previewRatio = max(width, height).toDouble() / min(width, height)
if (abs(previewRatio - RATIO_4_3_VALUE) <= abs(previewRatio - RATIO_16_9_VALUE)) {
return AspectRatio.RATIO_4_3
}
return AspectRatio.RATIO_16_9
}
This is how I set imageCaptureLitener
imageCapture?.let { imageCapture ->
val photoFile = createFile()
val metadata = ImageCapture.Metadata().apply {
isReversedHorizontal = lensFacing == CameraSelector.LENS_FACING_FRONT
}
val outputOptions = ImageCapture.OutputFileOptions.Builder(photoFile)
.setMetadata(metadata)
.build()
imageCapture.takePicture(outputOptions, cameraExecutor, object : ImageCapture.OnImageSavedCallback {
override fun onError(exc: ImageCaptureException) {
}
override fun onImageSaved(output: ImageCapture.OutputFileResults) {
setGalleryThumbnail(photoFile.path)
valuesList.add(0, photoFile.path)
}
})
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
container.postDelayed({
container.foreground = ColorDrawable(Color.WHITE)
container.postDelayed(
{ container.foreground = null }, ANIMATION_FAST_MILLIS)
}, ANIMATION_SLOW_MILLIS)
}
}