blob: 9e4fa14aa708553071f97c159c5a395b52d82717 [file] [log] [blame]
Chia-I Wubdf4c562014-08-07 06:36:33 +08001/*
Courtney Goeltzenleuchter9cc421e2015-04-08 15:36:08 -06002 * Vulkan
Chia-I Wubdf4c562014-08-07 06:36:33 +08003 *
4 * Copyright (C) 2014 LunarG, Inc.
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a
7 * copy of this software and associated documentation files (the "Software"),
8 * to deal in the Software without restriction, including without limitation
9 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
10 * and/or sell copies of the Software, and to permit persons to whom the
11 * Software is furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included
14 * in all copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 * DEALINGS IN THE SOFTWARE.
Chia-I Wu44e42362014-09-02 08:32:09 +080023 *
24 * Authors:
25 * Chia-I Wu <olv@lunarg.com>
Chia-I Wubdf4c562014-08-07 06:36:33 +080026 */
27
28#ifndef FENCE_H
29#define FENCE_H
30
31#include "intel.h"
32#include "obj.h"
33
Chia-I Wu046a7a92015-02-17 14:29:01 -070034struct intel_bo;
Chia-I Wubdf4c562014-08-07 06:36:33 +080035struct intel_dev;
36
37struct intel_fence {
38 struct intel_obj obj;
39
Chia-I Wu046a7a92015-02-17 14:29:01 -070040 struct intel_bo *seqno_bo;
Mark Lobodzinskiebe814d2015-04-07 16:07:57 -050041 bool signaled;
Chia-I Wu1db76e02014-09-15 14:21:14 +080042
Chia-I Wu41858c82015-04-04 16:39:25 +080043 void *wsi_data;
Chia-I Wubdf4c562014-08-07 06:36:33 +080044};
45
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -060046static inline struct intel_fence *intel_fence(VkFence fence)
Chia-I Wubdf4c562014-08-07 06:36:33 +080047{
Tony Barbourde4124d2015-07-03 10:33:54 -060048 return *(struct intel_fence **) &fence;
Chia-I Wubdf4c562014-08-07 06:36:33 +080049}
50
51static inline struct intel_fence *intel_fence_from_obj(struct intel_obj *obj)
52{
53 return (struct intel_fence *) obj;
54}
55
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -060056VkResult intel_fence_create(struct intel_dev *dev,
57 const VkFenceCreateInfo *info,
Chia-I Wubdf4c562014-08-07 06:36:33 +080058 struct intel_fence **fence_ret);
59void intel_fence_destroy(struct intel_fence *fence);
60
Courtney Goeltzenleuchter382489d2015-04-10 08:34:15 -060061VkResult intel_fence_wait(struct intel_fence *fence, int64_t timeout_ns);
Chia-I Wubdf4c562014-08-07 06:36:33 +080062
Chia-I Wub56f5df2015-04-04 20:21:10 +080063void intel_fence_copy(struct intel_fence *fence,
64 const struct intel_fence *src);
65
Chia-I Wu046a7a92015-02-17 14:29:01 -070066void intel_fence_set_seqno(struct intel_fence *fence,
67 struct intel_bo *seqno_bo);
Chia-I Wu1db76e02014-09-15 14:21:14 +080068
Chia-I Wubdf4c562014-08-07 06:36:33 +080069#endif /* FENCE_H */