1*cdec4d36SEric Anholt /* 2*cdec4d36SEric Anholt * Copyright © 2017 Broadcom 3*cdec4d36SEric Anholt * 4*cdec4d36SEric Anholt * Permission is hereby granted, free of charge, to any person obtaining a 5*cdec4d36SEric Anholt * copy of this software and associated documentation files (the "Software"), 6*cdec4d36SEric Anholt * to deal in the Software without restriction, including without limitation 7*cdec4d36SEric Anholt * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8*cdec4d36SEric Anholt * and/or sell copies of the Software, and to permit persons to whom the 9*cdec4d36SEric Anholt * Software is furnished to do so, subject to the following conditions: 10*cdec4d36SEric Anholt * 11*cdec4d36SEric Anholt * The above copyright notice and this permission notice (including the next 12*cdec4d36SEric Anholt * paragraph) shall be included in all copies or substantial portions of the 13*cdec4d36SEric Anholt * Software. 14*cdec4d36SEric Anholt * 15*cdec4d36SEric Anholt * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16*cdec4d36SEric Anholt * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17*cdec4d36SEric Anholt * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18*cdec4d36SEric Anholt * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19*cdec4d36SEric Anholt * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 20*cdec4d36SEric Anholt * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 21*cdec4d36SEric Anholt * IN THE SOFTWARE. 22*cdec4d36SEric Anholt */ 23*cdec4d36SEric Anholt 24*cdec4d36SEric Anholt #include "vc4_drv.h" 25*cdec4d36SEric Anholt 26*cdec4d36SEric Anholt static const char *vc4_fence_get_driver_name(struct dma_fence *fence) 27*cdec4d36SEric Anholt { 28*cdec4d36SEric Anholt return "vc4"; 29*cdec4d36SEric Anholt } 30*cdec4d36SEric Anholt 31*cdec4d36SEric Anholt static const char *vc4_fence_get_timeline_name(struct dma_fence *fence) 32*cdec4d36SEric Anholt { 33*cdec4d36SEric Anholt return "vc4-v3d"; 34*cdec4d36SEric Anholt } 35*cdec4d36SEric Anholt 36*cdec4d36SEric Anholt static bool vc4_fence_enable_signaling(struct dma_fence *fence) 37*cdec4d36SEric Anholt { 38*cdec4d36SEric Anholt return true; 39*cdec4d36SEric Anholt } 40*cdec4d36SEric Anholt 41*cdec4d36SEric Anholt static bool vc4_fence_signaled(struct dma_fence *fence) 42*cdec4d36SEric Anholt { 43*cdec4d36SEric Anholt struct vc4_fence *f = to_vc4_fence(fence); 44*cdec4d36SEric Anholt struct vc4_dev *vc4 = to_vc4_dev(f->dev); 45*cdec4d36SEric Anholt 46*cdec4d36SEric Anholt return vc4->finished_seqno >= f->seqno; 47*cdec4d36SEric Anholt } 48*cdec4d36SEric Anholt 49*cdec4d36SEric Anholt const struct dma_fence_ops vc4_fence_ops = { 50*cdec4d36SEric Anholt .get_driver_name = vc4_fence_get_driver_name, 51*cdec4d36SEric Anholt .get_timeline_name = vc4_fence_get_timeline_name, 52*cdec4d36SEric Anholt .enable_signaling = vc4_fence_enable_signaling, 53*cdec4d36SEric Anholt .signaled = vc4_fence_signaled, 54*cdec4d36SEric Anholt .wait = dma_fence_default_wait, 55*cdec4d36SEric Anholt .release = dma_fence_free, 56*cdec4d36SEric Anholt }; 57