summaryrefslogtreecommitdiffstats
path: root/camera
diff options
context:
space:
mode:
authorMarco Nelissen <marcone@google.com>2009-08-13 09:24:47 -0700
committerMarco Nelissen <marcone@google.com>2009-08-13 09:24:47 -0700
commit7907df75e0e3bbbe159f545935db53359e44ec03 (patch)
tree8c05f42ce3dbc28f77fa224021d15102b24f4044 /camera
parent991ac9e1d9c1bc3d45b4e02d28e3151d5ec16af6 (diff)
downloadframeworks_native-7907df75e0e3bbbe159f545935db53359e44ec03.zip
frameworks_native-7907df75e0e3bbbe159f545935db53359e44ec03.tar.gz
frameworks_native-7907df75e0e3bbbe159f545935db53359e44ec03.tar.bz2
In the simulator, make sure that the preview thread is a Java thread,
since we won't be going through the binder in single process mode.
Diffstat (limited to 'camera')
-rw-r--r--camera/libcameraservice/Android.mk10
-rw-r--r--camera/libcameraservice/CameraHardwareStub.h11
2 files changed, 18 insertions, 3 deletions
diff --git a/camera/libcameraservice/Android.mk b/camera/libcameraservice/Android.mk
index be78a62..ecaebff 100644
--- a/camera/libcameraservice/Android.mk
+++ b/camera/libcameraservice/Android.mk
@@ -25,6 +25,10 @@ LOCAL_SRC_FILES:= \
LOCAL_MODULE:= libcamerastub
+ifeq ($(TARGET_SIMULATOR),true)
+LOCAL_CFLAGS += -DSINGLE_PROCESS
+endif
+
LOCAL_SHARED_LIBRARIES:= libui
include $(BUILD_STATIC_LIBRARY)
@@ -48,7 +52,11 @@ LOCAL_SHARED_LIBRARIES:= \
LOCAL_MODULE:= libcameraservice
-LOCAL_CFLAGS+=-DLOG_TAG=\"CameraService\"
+LOCAL_CFLAGS += -DLOG_TAG=\"CameraService\"
+
+ifeq ($(TARGET_SIMULATOR),true)
+LOCAL_CFLAGS += -DSINGLE_PROCESS
+endif
ifeq ($(USE_CAMERA_STUB), true)
LOCAL_STATIC_LIBRARIES += libcamerastub
diff --git a/camera/libcameraservice/CameraHardwareStub.h b/camera/libcameraservice/CameraHardwareStub.h
index efae935..dd3c706 100644
--- a/camera/libcameraservice/CameraHardwareStub.h
+++ b/camera/libcameraservice/CameraHardwareStub.h
@@ -67,8 +67,15 @@ private:
class PreviewThread : public Thread {
CameraHardwareStub* mHardware;
public:
- PreviewThread(CameraHardwareStub* hw)
- : Thread(false), mHardware(hw) { }
+ PreviewThread(CameraHardwareStub* hw) :
+#ifdef SINGLE_PROCESS
+ // In single process mode this thread needs to be a java thread,
+ // since we won't be calling through the binder.
+ Thread(true),
+#else
+ Thread(false),
+#endif
+ mHardware(hw) { }
virtual void onFirstRef() {
run("CameraPreviewThread", PRIORITY_URGENT_DISPLAY);
}