From: Jason Ekstrand Date: Thu, 31 May 2018 01:16:50 +0000 (-0700) Subject: anv: Add some anv_address helpers X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=94081ffc80cc993c1c76cf427d8efd37e68de6f8;p=mesa.git anv: Add some anv_address helpers Reviewed-by: Scott D Phillips --- diff --git a/src/intel/vulkan/anv_private.h b/src/intel/vulkan/anv_private.h index 60444d99a42..bcd2197e7f9 100644 --- a/src/intel/vulkan/anv_private.h +++ b/src/intel/vulkan/anv_private.h @@ -1120,6 +1120,30 @@ struct anv_address { uint32_t offset; }; +#define ANV_NULL_ADDRESS ((struct anv_address) { NULL, 0 }) + +static inline bool +anv_address_is_null(struct anv_address addr) +{ + return addr.bo == NULL && addr.offset == 0; +} + +static inline uint64_t +anv_address_physical(struct anv_address addr) +{ + if (addr.bo && (addr.bo->flags & EXEC_OBJECT_PINNED)) + return gen_canonical_address(addr.bo->offset + addr.offset); + else + return gen_canonical_address(addr.offset); +} + +static inline struct anv_address +anv_address_add(struct anv_address addr, uint64_t offset) +{ + addr.offset += offset; + return addr; +} + static inline uint64_t _anv_combine_address(struct anv_batch *batch, void *location, const struct anv_address address, uint32_t delta)