blob: 526058c338d01d42ef7fcb56b587f648c8103537 [file] [log] [blame]
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CC_RESOURCES_RASTERIZER_H_
#define CC_RESOURCES_RASTERIZER_H_
#include <bitset>
#include <vector>
#include "base/callback.h"
#include "cc/resources/resource_format.h"
#include "cc/resources/task_graph_runner.h"
namespace cc {
class ImageDecodeTask;
class RasterTask;
class Resource;
class RasterBuffer;
class CC_EXPORT RasterizerTaskClient {
public:
virtual scoped_ptr<RasterBuffer> AcquireBufferForRaster(
const Resource* resource) = 0;
virtual void ReleaseBufferForRaster(scoped_ptr<RasterBuffer> buffer) = 0;
protected:
virtual ~RasterizerTaskClient() {}
};
class CC_EXPORT RasterizerTask : public Task {
public:
typedef std::vector<scoped_refptr<RasterizerTask>> Vector;
virtual void ScheduleOnOriginThread(RasterizerTaskClient* client) = 0;
virtual void CompleteOnOriginThread(RasterizerTaskClient* client) = 0;
virtual void RunReplyOnOriginThread() = 0;
// Type-checking downcast routines.
virtual ImageDecodeTask* AsImageDecodeTask();
virtual RasterTask* AsRasterTask();
void WillSchedule();
void DidSchedule();
bool HasBeenScheduled() const;
void WillComplete();
void DidComplete();
bool HasCompleted() const;
protected:
RasterizerTask();
~RasterizerTask() override;
bool did_schedule_;
bool did_complete_;
};
class CC_EXPORT ImageDecodeTask : public RasterizerTask {
public:
typedef std::vector<scoped_refptr<ImageDecodeTask>> Vector;
// Overridden from RasterizerTask:
ImageDecodeTask* AsImageDecodeTask() override;
protected:
ImageDecodeTask();
~ImageDecodeTask() override;
};
class CC_EXPORT RasterTask : public RasterizerTask {
public:
typedef std::vector<scoped_refptr<RasterTask>> Vector;
// Overridden from RasterizerTask:
RasterTask* AsRasterTask() override;
const Resource* resource() const { return resource_; }
const ImageDecodeTask::Vector& dependencies() const { return dependencies_; }
protected:
RasterTask(const Resource* resource, ImageDecodeTask::Vector* dependencies);
~RasterTask() override;
private:
const Resource* resource_;
ImageDecodeTask::Vector dependencies_;
};
static const size_t kNumberOfTaskSets = 2;
typedef size_t TaskSet;
typedef std::bitset<kNumberOfTaskSets> TaskSetCollection;
class CC_EXPORT RasterizerClient {
public:
virtual void DidFinishRunningTasks(TaskSet task_set) = 0;
virtual TaskSetCollection TasksThatShouldBeForcedToComplete() const = 0;
protected:
virtual ~RasterizerClient() {}
};
struct CC_EXPORT RasterTaskQueue {
struct CC_EXPORT Item {
class TaskComparator {
public:
explicit TaskComparator(const RasterTask* task) : task_(task) {}
bool operator()(const Item& item) const { return item.task == task_; }
private:
const RasterTask* task_;
};
typedef std::vector<Item> Vector;
Item(RasterTask* task, const TaskSetCollection& task_sets);
~Item();
RasterTask* task;
TaskSetCollection task_sets;
};
RasterTaskQueue();
~RasterTaskQueue();
void Swap(RasterTaskQueue* other);
void Reset();
Item::Vector items;
};
// This interface can be used to schedule and run raster tasks. The client will
// be notified asynchronously when the set of tasks marked as "required for
// activation" have finished running and when all scheduled tasks have finished
// running. The client can call CheckForCompletedTasks() at any time to dispatch
// pending completion callbacks for all tasks that have finished running.
class CC_EXPORT Rasterizer {
public:
// Set the client instance to be notified when finished running tasks.
virtual void SetClient(RasterizerClient* client) = 0;
// Tells the worker pool to shutdown after canceling all previously scheduled
// tasks. Reply callbacks are still guaranteed to run when
// CheckForCompletedTasks() is called.
virtual void Shutdown() = 0;
// Schedule running of raster tasks in |queue| and all dependencies.
// Previously scheduled tasks that are not in |queue| will be canceled unless
// already running. Once scheduled, reply callbacks are guaranteed to run for
// all tasks even if they later get canceled by another call to
// ScheduleTasks().
virtual void ScheduleTasks(RasterTaskQueue* queue) = 0;
// Check for completed tasks and dispatch reply callbacks.
virtual void CheckForCompletedTasks() = 0;
protected:
virtual ~Rasterizer() {}
};
} // namespace cc
#endif // CC_RESOURCES_RASTERIZER_H_