intel_renderstate.h 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /* SPDX-License-Identifier: MIT */
  2. /*
  3. * Copyright © 2014 Intel Corporation
  4. */
  5. #ifndef _INTEL_RENDERSTATE_H_
  6. #define _INTEL_RENDERSTATE_H_
  7. #include <linux/types.h>
  8. #include "i915_gem.h"
  9. #include "i915_gem_ww.h"
  10. struct i915_request;
  11. struct intel_context;
  12. struct i915_vma;
  13. struct intel_renderstate_rodata {
  14. const u32 *reloc;
  15. const u32 *batch;
  16. const u32 batch_items;
  17. };
  18. #define RO_RENDERSTATE(_g) \
  19. const struct intel_renderstate_rodata gen ## _g ## _null_state = { \
  20. .reloc = gen ## _g ## _null_state_relocs, \
  21. .batch = gen ## _g ## _null_state_batch, \
  22. .batch_items = sizeof(gen ## _g ## _null_state_batch)/4, \
  23. }
  24. extern const struct intel_renderstate_rodata gen6_null_state;
  25. extern const struct intel_renderstate_rodata gen7_null_state;
  26. extern const struct intel_renderstate_rodata gen8_null_state;
  27. extern const struct intel_renderstate_rodata gen9_null_state;
  28. struct intel_renderstate {
  29. struct i915_gem_ww_ctx ww;
  30. const struct intel_renderstate_rodata *rodata;
  31. struct i915_vma *vma;
  32. u32 batch_offset;
  33. u32 batch_size;
  34. u32 aux_offset;
  35. u32 aux_size;
  36. };
  37. int intel_renderstate_init(struct intel_renderstate *so,
  38. struct intel_context *ce);
  39. int intel_renderstate_emit(struct intel_renderstate *so,
  40. struct i915_request *rq);
  41. void intel_renderstate_fini(struct intel_renderstate *so,
  42. struct intel_context *ce);
  43. #endif /* _INTEL_RENDERSTATE_H_ */