/*
* Copyright 2017 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef GrSemaphore_DEFINED
#define GrSemaphore_DEFINED
#include "SkRefCnt.h"
class GrBackendSemaphore;
class GrGpu;
class GrSemaphore : public SkRefCnt {
private:
// This function should only be used in the case of exporting and importing a GrSemaphore object
// from one GrContext to another. When exporting, the GrSemaphore should be set to a null GrGpu,
// and when importing it should be set to the GrGpu of the current context. Once exported, a
// GrSemaphore should not be used with its old context.
void resetGpu(const GrGpu* gpu) { fGpu = gpu; }
// The derived class will init the GrBackendSemaphore. This is used when flushing with signal
// semaphores so we can set the clients GrBackendSemaphore object after we've created the
// internal semaphore.
virtual void setBackendSemaphore(GrBackendSemaphore*) const = 0;
protected:
explicit GrSemaphore(const GrGpu* gpu) : fGpu(gpu) {}
friend class GrGpu; // setBackendSemaphore
friend class GrRenderTargetContext; // setBackendSemaphore
friend class GrResourceProvider; // resetGpu
const GrGpu* fGpu;
};
#endif