2019-04-27 00:33:36 +08:00
|
|
|
/*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
* Copyright © 2018 Intel Corporation
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "igt_gem_utils.h"
|
|
|
|
|
2019-05-28 17:29:49 +08:00
|
|
|
#include "gem/i915_gem_context.h"
|
|
|
|
#include "gem/i915_gem_pm.h"
|
2019-04-27 00:33:36 +08:00
|
|
|
#include "gt/intel_context.h"
|
|
|
|
|
2019-05-28 17:29:49 +08:00
|
|
|
#include "i915_request.h"
|
2019-04-27 00:33:36 +08:00
|
|
|
|
|
|
|
struct i915_request *
|
|
|
|
igt_request_alloc(struct i915_gem_context *ctx, struct intel_engine_cs *engine)
|
|
|
|
{
|
|
|
|
struct intel_context *ce;
|
|
|
|
struct i915_request *rq;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Pinning the contexts may generate requests in order to acquire
|
|
|
|
* GGTT space, so do this first before we reserve a seqno for
|
|
|
|
* ourselves.
|
|
|
|
*/
|
2019-08-08 19:06:12 +08:00
|
|
|
ce = i915_gem_context_get_engine(ctx, engine->legacy_idx);
|
2019-04-27 00:33:36 +08:00
|
|
|
if (IS_ERR(ce))
|
|
|
|
return ERR_CAST(ce);
|
|
|
|
|
|
|
|
rq = intel_context_create_request(ce);
|
|
|
|
intel_context_put(ce);
|
|
|
|
|
|
|
|
return rq;
|
|
|
|
}
|