1# Copyright © 2017 Intel Corporation 2 3# Permission is hereby granted, free of charge, to any person obtaining a copy 4# of this software and associated documentation files (the "Software"), to deal 5# in the Software without restriction, including without limitation the rights 6# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 7# copies of the Software, and to permit persons to whom the Software is 8# furnished to do so, subject to the following conditions: 9 10# The above copyright notice and this permission notice shall be included in 11# all copies or substantial portions of the Software. 12 13# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 14# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 15# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 16# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 17# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 18# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 19# SOFTWARE. 20 21files_i965 = files( 22 'brw_binding_tables.c', 23 'brw_blorp.c', 24 'brw_blorp.h', 25 'brw_bufmgr.c', 26 'brw_bufmgr.h', 27 'brw_clear.c', 28 'brw_clip.c', 29 'brw_compute.c', 30 'brw_conditional_render.c', 31 'brw_context.c', 32 'brw_context.h', 33 'brw_cs.c', 34 'brw_cs.h', 35 'brw_curbe.c', 36 'brw_defines.h', 37 'brw_disk_cache.c', 38 'brw_draw.c', 39 'brw_draw.h', 40 'brw_draw_upload.c', 41 'brw_ff_gs.c', 42 'brw_ff_gs_emit.c', 43 'brw_ff_gs.h', 44 'brw_formatquery.c', 45 'brw_gs.c', 46 'brw_gs.h', 47 'brw_gs_surface_state.c', 48 'brw_link.cpp', 49 'brw_meta_util.c', 50 'brw_meta_util.h', 51 'brw_misc_state.c', 52 'brw_multisample_state.h', 53 'brw_nir_uniforms.cpp', 54 'brw_object_purgeable.c', 55 'brw_pipe_control.c', 56 'brw_performance_query.h', 57 'brw_performance_query.c', 58 'brw_program.c', 59 'brw_program.h', 60 'brw_program_binary.c', 61 'brw_program_cache.c', 62 'brw_primitive_restart.c', 63 'brw_queryobj.c', 64 'brw_reset.c', 65 'brw_sf.c', 66 'brw_state.h', 67 'brw_state_upload.c', 68 'brw_structs.h', 69 'brw_surface_formats.c', 70 'brw_sync.c', 71 'brw_tcs.c', 72 'brw_tcs_surface_state.c', 73 'brw_tes.c', 74 'brw_tes_surface_state.c', 75 'brw_urb.c', 76 'brw_util.c', 77 'brw_util.h', 78 'brw_vs.c', 79 'brw_vs.h', 80 'brw_vs_surface_state.c', 81 'brw_wm.c', 82 'brw_wm.h', 83 'brw_wm_surface_state.c', 84 'gen4_blorp_exec.h', 85 'gen6_clip_state.c', 86 'gen6_constant_state.c', 87 'gen6_depth_state.c', 88 'gen6_multisample_state.c', 89 'gen6_queryobj.c', 90 'gen6_sampler_state.c', 91 'gen6_sol.c', 92 'gen6_urb.c', 93 'gen7_l3_state.c', 94 'gen7_misc_state.c', 95 'gen7_sol_state.c', 96 'gen7_urb.c', 97 'gen8_depth_state.c', 98 'gen8_multisample_state.c', 99 'hsw_queryobj.c', 100 'hsw_sol.c', 101 'intel_batchbuffer.c', 102 'intel_batchbuffer.h', 103 'intel_blit.c', 104 'intel_blit.h', 105 'intel_buffer_objects.c', 106 'intel_buffer_objects.h', 107 'intel_buffers.c', 108 'intel_buffers.h', 109 'intel_copy_image.c', 110 'intel_extensions.c', 111 'intel_fbo.c', 112 'intel_fbo.h', 113 'intel_image.h', 114 'intel_mipmap_tree.c', 115 'intel_mipmap_tree.h', 116 'intel_pixel_bitmap.c', 117 'intel_pixel.c', 118 'intel_pixel_copy.c', 119 'intel_pixel_draw.c', 120 'intel_pixel.h', 121 'intel_pixel_read.c', 122 'intel_screen.c', 123 'intel_screen.h', 124 'intel_state.c', 125 'intel_tex.c', 126 'intel_tex_copy.c', 127 'intel_tex.h', 128 'intel_tex_image.c', 129 'intel_tex_obj.h', 130 'intel_tex_validate.c', 131 'intel_tiled_memcpy.c', 132 'intel_tiled_memcpy.h', 133 'intel_upload.c', 134 'libdrm_macros.h', 135) 136 137i965_gen_libs = [] 138foreach v : ['40', '45', '50', '60', '70', '75', '80', '90', '100'] 139 i965_gen_libs += static_library( 140 'libi965_gen@0@'.format(v), 141 ['genX_blorp_exec.c', 'genX_state_upload.c', gen_xml_pack], 142 include_directories : [inc_common, inc_intel, inc_dri_common], 143 c_args : [ 144 c_vis_args, no_override_init_args, '-msse2', 145 '-DGEN_VERSIONx10=@0@'.format(v), 146 ], 147 dependencies : [dep_libdrm, idep_nir_headers], 148 ) 149endforeach 150 151i965_oa_sources = [] 152foreach hw : ['hsw', 'bdw', 'chv', 'sklgt2', 'sklgt3', 'sklgt4', 'bxt', 153 'kblgt2', 'kblgt3', 'glk', 'cflgt2', 'cflgt3'] 154 _name = 'brw_oa_@0@'.format(hw) 155 i965_oa_sources += custom_target( 156 _name, 157 input : ['brw_oa.py', '@0@.xml'.format(_name)], 158 output : ['@0@.c'.format(_name), '@0@.h'.format(_name)], 159 command : [ 160 prog_python2, '@INPUT0@', '--chipset', hw, '--code', '@OUTPUT0@', 161 '--header', '@OUTPUT1@', '@INPUT1@', 162 ], 163 ) 164endforeach 165 166libi965 = static_library( 167 'i965', 168 [files_i965, i965_oa_sources, ir_expression_operation_h, 169 xmlpool_options_h], 170 include_directories : [ 171 inc_common, inc_intel, inc_dri_common, inc_util, inc_drm_uapi, 172 ], 173 c_args : [c_vis_args, no_override_init_args, '-msse2'], 174 cpp_args : [cpp_vis_args, '-msse2'], 175 link_with : [ 176 i965_gen_libs, libintel_common, libisl, libintel_compiler, libblorp, 177 ], 178 dependencies : [dep_libdrm, dep_valgrind, idep_nir_headers], 179) 180 181dri_drivers += libi965 182dri_link += 'i965_dri.so' 183