igt_dummyload.h 3.13 KB
Newer Older
Abdiel Janulgue's avatar
Abdiel Janulgue committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
/*
 * Copyright © 2016 Intel Corporation
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice (including the next
 * paragraph) shall be included in all copies or substantial portions of the
 * Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 * IN THE SOFTWARE.
 *
 */

#ifndef __IGT_DUMMYLOAD_H__
#define __IGT_DUMMYLOAD_H__

#include <stdint.h>
#include <time.h>

31 32
#include "igt_core.h"
#include "igt_list.h"
33
#include "i915_drm.h"
Abdiel Janulgue's avatar
Abdiel Janulgue committed
34 35 36 37 38 39

typedef struct igt_spin {
	unsigned int handle;
	timer_t timer;
	struct igt_list link;
	uint32_t *batch;
40
	int out_fence;
41 42 43 44
	struct drm_i915_gem_exec_object2 obj[2];
	struct drm_i915_gem_execbuffer2 execbuf;
	uint32_t poll_handle;
	bool *running;
Abdiel Janulgue's avatar
Abdiel Janulgue committed
45 46
} igt_spin_t;

47 48 49 50 51 52 53
struct igt_spin_factory {
	uint32_t ctx;
	uint32_t dependency;
	unsigned int engine;
	unsigned int flags;
};

54 55 56 57
#define IGT_SPIN_FENCE_OUT     (1 << 0)
#define IGT_SPIN_POLL_RUN      (1 << 1)
#define IGT_SPIN_FAST          (1 << 2)
#define IGT_SPIN_NO_PREEMPTION (1 << 3)
58 59 60 61 62 63 64 65 66 67

igt_spin_t *
__igt_spin_batch_factory(int fd, const struct igt_spin_factory *opts);
igt_spin_t *
igt_spin_batch_factory(int fd, const struct igt_spin_factory *opts);

#define __igt_spin_batch_new(fd, ...) \
	__igt_spin_batch_factory(fd, &((struct igt_spin_factory){__VA_ARGS__}))
#define igt_spin_batch_new(fd, ...) \
	igt_spin_batch_factory(fd, &((struct igt_spin_factory){__VA_ARGS__}))
68

Abdiel Janulgue's avatar
Abdiel Janulgue committed
69 70 71 72
void igt_spin_batch_set_timeout(igt_spin_t *spin, int64_t ns);
void igt_spin_batch_end(igt_spin_t *spin);
void igt_spin_batch_free(int fd, igt_spin_t *spin);

73 74 75 76 77 78
static inline void igt_spin_busywait_until_running(igt_spin_t *spin)
{
	while (!READ_ONCE(*spin->running))
		;
}

Abdiel Janulgue's avatar
Abdiel Janulgue committed
79 80
void igt_terminate_spin_batches(void);

81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
enum igt_cork_type {
	CORK_SYNC_FD = 1,
	CORK_VGEM_HANDLE
};

struct igt_cork_vgem {
	int device;
	uint32_t fence;
};

struct igt_cork_sw_sync {
	int timeline;
};

struct igt_cork {
	enum igt_cork_type type;

	union {
		int fd;

		struct igt_cork_vgem vgem;
		struct igt_cork_sw_sync sw_sync;
	};
};

#define IGT_CORK(name, cork_type) struct igt_cork name = { .type = cork_type, .fd = -1}
#define IGT_CORK_HANDLE(name) IGT_CORK(name, CORK_VGEM_HANDLE)
#define IGT_CORK_FENCE(name) IGT_CORK(name, CORK_SYNC_FD)

uint32_t igt_cork_plug(struct igt_cork *cork, int fd);
void igt_cork_unplug(struct igt_cork *cork);

Abdiel Janulgue's avatar
Abdiel Janulgue committed
113
#endif /* __IGT_DUMMYLOAD_H__ */