* commit 'bbfbe93c0d2d6c7818e23219d2925f02ddf5bd92': SurfaceFlinger: give SF its own vsync phase
This commit is contained in:
commit
cd65a2c51e
@ -66,6 +66,13 @@ else
|
||||
LOCAL_CFLAGS += -DVSYNC_EVENT_PHASE_OFFSET_NS=0
|
||||
endif
|
||||
|
||||
# See build/target/board/generic/BoardConfig.mk for a description of this setting.
|
||||
ifneq ($(SF_VSYNC_EVENT_PHASE_OFFSET_NS),)
|
||||
LOCAL_CFLAGS += -DSF_VSYNC_EVENT_PHASE_OFFSET_NS=$(SF_VSYNC_EVENT_PHASE_OFFSET_NS)
|
||||
else
|
||||
LOCAL_CFLAGS += -DSF_VSYNC_EVENT_PHASE_OFFSET_NS=0
|
||||
endif
|
||||
|
||||
ifneq ($(PRESENT_TIME_OFFSET_FROM_VSYNC_NS),)
|
||||
LOCAL_CFLAGS += -DPRESENT_TIME_OFFSET_FROM_VSYNC_NS=$(PRESENT_TIME_OFFSET_FROM_VSYNC_NS)
|
||||
else
|
||||
|
@ -117,6 +117,9 @@ static const bool runningWithoutSyncFramework = false;
|
||||
// conservatively (or at least with awareness of the trade-off being made).
|
||||
static const int64_t vsyncPhaseOffsetNs = VSYNC_EVENT_PHASE_OFFSET_NS;
|
||||
|
||||
// This is the phase offset at which SurfaceFlinger's composition runs.
|
||||
static const int64_t sfVsyncPhaseOffsetNs = SF_VSYNC_EVENT_PHASE_OFFSET_NS;
|
||||
|
||||
// ---------------------------------------------------------------------------
|
||||
|
||||
const String16 sHardwareTest("android.permission.HARDWARE_TEST");
|
||||
@ -440,7 +443,11 @@ status_t SurfaceFlinger::selectEGLConfig(EGLDisplay display, EGLint nativeVisual
|
||||
|
||||
class DispSyncSource : public VSyncSource, private DispSync::Callback {
|
||||
public:
|
||||
DispSyncSource(DispSync* dispSync) : mValue(0), mDispSync(dispSync) {}
|
||||
DispSyncSource(DispSync* dispSync, nsecs_t phaseOffset, bool traceVsync) :
|
||||
mValue(0),
|
||||
mPhaseOffset(phaseOffset),
|
||||
mTraceVsync(traceVsync),
|
||||
mDispSync(dispSync) {}
|
||||
|
||||
virtual ~DispSyncSource() {}
|
||||
|
||||
@ -448,7 +455,7 @@ public:
|
||||
// Do NOT lock the mutex here so as to avoid any mutex ordering issues
|
||||
// with locking it in the onDispSyncEvent callback.
|
||||
if (enable) {
|
||||
status_t err = mDispSync->addEventListener(vsyncPhaseOffsetNs,
|
||||
status_t err = mDispSync->addEventListener(mPhaseOffset,
|
||||
static_cast<DispSync::Callback*>(this));
|
||||
if (err != NO_ERROR) {
|
||||
ALOGE("error registering vsync callback: %s (%d)",
|
||||
@ -478,8 +485,10 @@ private:
|
||||
Mutex::Autolock lock(mMutex);
|
||||
callback = mCallback;
|
||||
|
||||
mValue = (mValue + 1) % 2;
|
||||
ATRACE_INT("VSYNC", mValue);
|
||||
if (mTraceVsync) {
|
||||
mValue = (mValue + 1) % 2;
|
||||
ATRACE_INT("VSYNC", mValue);
|
||||
}
|
||||
}
|
||||
|
||||
if (callback != NULL) {
|
||||
@ -489,6 +498,9 @@ private:
|
||||
|
||||
int mValue;
|
||||
|
||||
const nsecs_t mPhaseOffset;
|
||||
const bool mTraceVsync;
|
||||
|
||||
DispSync* mDispSync;
|
||||
sp<VSyncSource::Callback> mCallback;
|
||||
Mutex mMutex;
|
||||
@ -590,9 +602,13 @@ void SurfaceFlinger::init() {
|
||||
getDefaultDisplayDevice()->makeCurrent(mEGLDisplay, mEGLContext);
|
||||
|
||||
// start the EventThread
|
||||
sp<VSyncSource> vsyncSrc = new DispSyncSource(&mPrimaryDispSync);
|
||||
sp<VSyncSource> vsyncSrc = new DispSyncSource(&mPrimaryDispSync,
|
||||
vsyncPhaseOffsetNs, true);
|
||||
mEventThread = new EventThread(vsyncSrc);
|
||||
mEventQueue.setEventThread(mEventThread);
|
||||
sp<VSyncSource> sfVsyncSrc = new DispSyncSource(&mPrimaryDispSync,
|
||||
sfVsyncPhaseOffsetNs, false);
|
||||
mSFEventThread = new EventThread(sfVsyncSrc);
|
||||
mEventQueue.setEventThread(mSFEventThread);
|
||||
|
||||
mEventControlThread = new EventControlThread(this);
|
||||
mEventControlThread->run("EventControl", PRIORITY_URGENT_DISPLAY);
|
||||
|
@ -429,6 +429,7 @@ private:
|
||||
nsecs_t mBootTime;
|
||||
bool mGpuToCpuSupported;
|
||||
sp<EventThread> mEventThread;
|
||||
sp<EventThread> mSFEventThread;
|
||||
sp<EventControlThread> mEventControlThread;
|
||||
EGLContext mEGLContext;
|
||||
EGLConfig mEGLConfig;
|
||||
|
Loading…
Reference in New Issue
Block a user