1*d83cc019SAndroid Build Coastguard Worker /* 2*d83cc019SAndroid Build Coastguard Worker * Copyright © 2018 Intel Corporation 3*d83cc019SAndroid Build Coastguard Worker * 4*d83cc019SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a 5*d83cc019SAndroid Build Coastguard Worker * copy of this software and associated documentation files (the "Software"), 6*d83cc019SAndroid Build Coastguard Worker * to deal in the Software without restriction, including without limitation 7*d83cc019SAndroid Build Coastguard Worker * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8*d83cc019SAndroid Build Coastguard Worker * and/or sell copies of the Software, and to permit persons to whom the 9*d83cc019SAndroid Build Coastguard Worker * Software is furnished to do so, subject to the following conditions: 10*d83cc019SAndroid Build Coastguard Worker * 11*d83cc019SAndroid Build Coastguard Worker * The above copyright notice and this permission notice (including the next 12*d83cc019SAndroid Build Coastguard Worker * paragraph) shall be included in all copies or substantial portions of the 13*d83cc019SAndroid Build Coastguard Worker * Software. 14*d83cc019SAndroid Build Coastguard Worker * 15*d83cc019SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16*d83cc019SAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17*d83cc019SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18*d83cc019SAndroid Build Coastguard Worker * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19*d83cc019SAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 20*d83cc019SAndroid Build Coastguard Worker * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 21*d83cc019SAndroid Build Coastguard Worker * IN THE SOFTWARE. 22*d83cc019SAndroid Build Coastguard Worker * 23*d83cc019SAndroid Build Coastguard Worker */ 24*d83cc019SAndroid Build Coastguard Worker 25*d83cc019SAndroid Build Coastguard Worker #ifndef GPU_CMDS_H 26*d83cc019SAndroid Build Coastguard Worker #define GPU_CMDS_H 27*d83cc019SAndroid Build Coastguard Worker 28*d83cc019SAndroid Build Coastguard Worker #include <intel_bufmgr.h> 29*d83cc019SAndroid Build Coastguard Worker #include <i915_drm.h> 30*d83cc019SAndroid Build Coastguard Worker 31*d83cc019SAndroid Build Coastguard Worker #include "media_fill.h" 32*d83cc019SAndroid Build Coastguard Worker #include "gen7_media.h" 33*d83cc019SAndroid Build Coastguard Worker #include "gen8_media.h" 34*d83cc019SAndroid Build Coastguard Worker #include "intel_reg.h" 35*d83cc019SAndroid Build Coastguard Worker #include "drmtest.h" 36*d83cc019SAndroid Build Coastguard Worker #include "intel_batchbuffer.h" 37*d83cc019SAndroid Build Coastguard Worker #include "intel_chipset.h" 38*d83cc019SAndroid Build Coastguard Worker #include <assert.h> 39*d83cc019SAndroid Build Coastguard Worker 40*d83cc019SAndroid Build Coastguard Worker void 41*d83cc019SAndroid Build Coastguard Worker gen7_render_flush(struct intel_batchbuffer *batch, uint32_t batch_end); 42*d83cc019SAndroid Build Coastguard Worker 43*d83cc019SAndroid Build Coastguard Worker void 44*d83cc019SAndroid Build Coastguard Worker gen7_render_context_flush(struct intel_batchbuffer *batch, uint32_t batch_end); 45*d83cc019SAndroid Build Coastguard Worker 46*d83cc019SAndroid Build Coastguard Worker uint32_t 47*d83cc019SAndroid Build Coastguard Worker gen7_fill_curbe_buffer_data(struct intel_batchbuffer *batch, 48*d83cc019SAndroid Build Coastguard Worker uint8_t color); 49*d83cc019SAndroid Build Coastguard Worker uint32_t 50*d83cc019SAndroid Build Coastguard Worker gen11_fill_curbe_buffer_data(struct intel_batchbuffer *batch); 51*d83cc019SAndroid Build Coastguard Worker 52*d83cc019SAndroid Build Coastguard Worker uint32_t 53*d83cc019SAndroid Build Coastguard Worker gen7_fill_surface_state(struct intel_batchbuffer *batch, 54*d83cc019SAndroid Build Coastguard Worker const struct igt_buf *buf, 55*d83cc019SAndroid Build Coastguard Worker uint32_t format, 56*d83cc019SAndroid Build Coastguard Worker int is_dst); 57*d83cc019SAndroid Build Coastguard Worker 58*d83cc019SAndroid Build Coastguard Worker uint32_t 59*d83cc019SAndroid Build Coastguard Worker gen7_fill_binding_table(struct intel_batchbuffer *batch, 60*d83cc019SAndroid Build Coastguard Worker const struct igt_buf *dst); 61*d83cc019SAndroid Build Coastguard Worker uint32_t 62*d83cc019SAndroid Build Coastguard Worker gen11_fill_binding_table(struct intel_batchbuffer *batch, 63*d83cc019SAndroid Build Coastguard Worker const struct igt_buf *src,const struct igt_buf *dst); 64*d83cc019SAndroid Build Coastguard Worker 65*d83cc019SAndroid Build Coastguard Worker uint32_t 66*d83cc019SAndroid Build Coastguard Worker gen7_fill_kernel(struct intel_batchbuffer *batch, 67*d83cc019SAndroid Build Coastguard Worker const uint32_t kernel[][4], 68*d83cc019SAndroid Build Coastguard Worker size_t size); 69*d83cc019SAndroid Build Coastguard Worker 70*d83cc019SAndroid Build Coastguard Worker uint32_t 71*d83cc019SAndroid Build Coastguard Worker gen7_fill_interface_descriptor(struct intel_batchbuffer *batch, 72*d83cc019SAndroid Build Coastguard Worker const struct igt_buf *dst, 73*d83cc019SAndroid Build Coastguard Worker const uint32_t kernel[][4], 74*d83cc019SAndroid Build Coastguard Worker size_t size); 75*d83cc019SAndroid Build Coastguard Worker 76*d83cc019SAndroid Build Coastguard Worker void 77*d83cc019SAndroid Build Coastguard Worker gen7_emit_state_base_address(struct intel_batchbuffer *batch); 78*d83cc019SAndroid Build Coastguard Worker 79*d83cc019SAndroid Build Coastguard Worker void 80*d83cc019SAndroid Build Coastguard Worker gen7_emit_vfe_state(struct intel_batchbuffer *batch, uint32_t threads, 81*d83cc019SAndroid Build Coastguard Worker uint32_t urb_entries, uint32_t urb_size, 82*d83cc019SAndroid Build Coastguard Worker uint32_t curbe_size, uint32_t mode); 83*d83cc019SAndroid Build Coastguard Worker 84*d83cc019SAndroid Build Coastguard Worker void 85*d83cc019SAndroid Build Coastguard Worker gen7_emit_curbe_load(struct intel_batchbuffer *batch, uint32_t curbe_buffer); 86*d83cc019SAndroid Build Coastguard Worker 87*d83cc019SAndroid Build Coastguard Worker void 88*d83cc019SAndroid Build Coastguard Worker gen7_emit_interface_descriptor_load(struct intel_batchbuffer *batch, 89*d83cc019SAndroid Build Coastguard Worker uint32_t interface_descriptor); 90*d83cc019SAndroid Build Coastguard Worker 91*d83cc019SAndroid Build Coastguard Worker void 92*d83cc019SAndroid Build Coastguard Worker gen7_emit_media_objects(struct intel_batchbuffer *batch, 93*d83cc019SAndroid Build Coastguard Worker unsigned int x, unsigned int y, 94*d83cc019SAndroid Build Coastguard Worker unsigned int width, unsigned int height); 95*d83cc019SAndroid Build Coastguard Worker 96*d83cc019SAndroid Build Coastguard Worker void 97*d83cc019SAndroid Build Coastguard Worker gen7_emit_gpgpu_walk(struct intel_batchbuffer *batch, 98*d83cc019SAndroid Build Coastguard Worker unsigned int x, unsigned int y, 99*d83cc019SAndroid Build Coastguard Worker unsigned int width, unsigned int height); 100*d83cc019SAndroid Build Coastguard Worker 101*d83cc019SAndroid Build Coastguard Worker uint32_t 102*d83cc019SAndroid Build Coastguard Worker gen8_spin_curbe_buffer_data(struct intel_batchbuffer *batch, 103*d83cc019SAndroid Build Coastguard Worker uint32_t iters); 104*d83cc019SAndroid Build Coastguard Worker 105*d83cc019SAndroid Build Coastguard Worker uint32_t 106*d83cc019SAndroid Build Coastguard Worker gen8_fill_surface_state(struct intel_batchbuffer *batch, 107*d83cc019SAndroid Build Coastguard Worker const struct igt_buf *buf, 108*d83cc019SAndroid Build Coastguard Worker uint32_t format, 109*d83cc019SAndroid Build Coastguard Worker int is_dst); 110*d83cc019SAndroid Build Coastguard Worker uint32_t 111*d83cc019SAndroid Build Coastguard Worker gen11_fill_surface_state(struct intel_batchbuffer *batch, 112*d83cc019SAndroid Build Coastguard Worker const struct igt_buf *buf, 113*d83cc019SAndroid Build Coastguard Worker uint32_t surface_type, 114*d83cc019SAndroid Build Coastguard Worker uint32_t format, 115*d83cc019SAndroid Build Coastguard Worker uint32_t vertical_alignment, 116*d83cc019SAndroid Build Coastguard Worker uint32_t horizontal_alignment, 117*d83cc019SAndroid Build Coastguard Worker int is_dst); 118*d83cc019SAndroid Build Coastguard Worker uint32_t 119*d83cc019SAndroid Build Coastguard Worker gen8_fill_interface_descriptor(struct intel_batchbuffer *batch, 120*d83cc019SAndroid Build Coastguard Worker const struct igt_buf *dst, 121*d83cc019SAndroid Build Coastguard Worker const uint32_t kernel[][4], 122*d83cc019SAndroid Build Coastguard Worker size_t size); 123*d83cc019SAndroid Build Coastguard Worker uint32_t 124*d83cc019SAndroid Build Coastguard Worker gen11_fill_interface_descriptor(struct intel_batchbuffer *batch, 125*d83cc019SAndroid Build Coastguard Worker const struct igt_buf *src,const struct igt_buf *dst, 126*d83cc019SAndroid Build Coastguard Worker const uint32_t kernel[][4], 127*d83cc019SAndroid Build Coastguard Worker size_t size); 128*d83cc019SAndroid Build Coastguard Worker void 129*d83cc019SAndroid Build Coastguard Worker gen8_emit_state_base_address(struct intel_batchbuffer *batch); 130*d83cc019SAndroid Build Coastguard Worker 131*d83cc019SAndroid Build Coastguard Worker void 132*d83cc019SAndroid Build Coastguard Worker gen8_emit_media_state_flush(struct intel_batchbuffer *batch); 133*d83cc019SAndroid Build Coastguard Worker 134*d83cc019SAndroid Build Coastguard Worker void 135*d83cc019SAndroid Build Coastguard Worker gen8_emit_vfe_state(struct intel_batchbuffer *batch, uint32_t threads, 136*d83cc019SAndroid Build Coastguard Worker uint32_t urb_entries, uint32_t urb_size, 137*d83cc019SAndroid Build Coastguard Worker uint32_t curbe_size); 138*d83cc019SAndroid Build Coastguard Worker 139*d83cc019SAndroid Build Coastguard Worker void 140*d83cc019SAndroid Build Coastguard Worker gen8_emit_gpgpu_walk(struct intel_batchbuffer *batch, 141*d83cc019SAndroid Build Coastguard Worker unsigned int x, unsigned int y, 142*d83cc019SAndroid Build Coastguard Worker unsigned int width, unsigned int height); 143*d83cc019SAndroid Build Coastguard Worker 144*d83cc019SAndroid Build Coastguard Worker void 145*d83cc019SAndroid Build Coastguard Worker gen_emit_media_object(struct intel_batchbuffer *batch, unsigned int xoffset, 146*d83cc019SAndroid Build Coastguard Worker unsigned int yoffset); 147*d83cc019SAndroid Build Coastguard Worker 148*d83cc019SAndroid Build Coastguard Worker void 149*d83cc019SAndroid Build Coastguard Worker gen9_emit_state_base_address(struct intel_batchbuffer *batch); 150*d83cc019SAndroid Build Coastguard Worker 151*d83cc019SAndroid Build Coastguard Worker #endif /* GPU_CMDS_H */ 152