Skip to content

Commit

Permalink
Update tests to check DI tag generation.
Browse files Browse the repository at this point in the history
  • Loading branch information
Diptorup Deb committed Nov 9, 2022
1 parent b05c7fa commit 211d5d8
Showing 1 changed file with 16 additions and 32 deletions.
48 changes: 16 additions & 32 deletions numba_dpex/tests/test_debuginfo.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,16 @@ def debug_option(request):
return request.param


def get_kernel_ir(sycl_queue, fn, sig, debug=None):
kernel = compiler.compile_kernel(
sycl_queue, fn.py_func, sig, None, debug=debug
def get_kernel_ir(fn, sig, debug=None):
kernel = dpex.core.kernel_interface.spirv_kernel.SpirvKernel(
fn, fn.__name__
)
return kernel.assembly
kernel.compile(
arg_types=sig,
debug=debug,
extra_compile_flags=None,
)
return kernel.llvm_module


def make_check(ir, val_to_search):
Expand All @@ -45,15 +50,11 @@ def test_debug_flag_generates_ir_with_debuginfo(debug_option):
Check debug info is emitting to IR if debug parameter is set to True
"""

@dpex.kernel
def foo(x):
x = 1 # noqa

sycl_queue = dpctl.get_current_queue()
sig = (types.int32,)

kernel_ir = get_kernel_ir(sycl_queue, foo, sig, debug=debug_option)

kernel_ir = get_kernel_ir(foo, sig, debug=debug_option)
tag = "!dbg"

if debug_option:
Expand All @@ -68,7 +69,6 @@ def test_debug_info_locals_vars_on_no_opt():
if debug parameter is set to True and optimization is O0
"""

@dpex.kernel
def foo(var_a, var_b, var_c):
i = dpex.get_global_id(0)
var_c[i] = var_a[i] + var_b[i]
Expand All @@ -79,16 +79,14 @@ def foo(var_a, var_b, var_c):
'!DILocalVariable(name: "var_c"',
'!DILocalVariable(name: "i"',
]

sycl_queue = dpctl.get_current_queue()
sig = (
npytypes_array_to_dpex_array(types.float32[:]),
npytypes_array_to_dpex_array(types.float32[:]),
npytypes_array_to_dpex_array(types.float32[:]),
)

with override_config("OPT", 0):
kernel_ir = get_kernel_ir(sycl_queue, foo, sig, debug=True)
kernel_ir = get_kernel_ir(foo, sig, debug=True)

for tag in ir_tags:
assert tag in kernel_ir
Expand All @@ -100,7 +98,6 @@ def test_debug_kernel_local_vars_in_ir():
created in kernel
"""

@dpex.kernel
def foo(arr):
index = dpex.get_global_id(0)
local_d = 9 * 99 + 5
Expand All @@ -110,11 +107,8 @@ def foo(arr):
'!DILocalVariable(name: "index"',
'!DILocalVariable(name: "local_d"',
]

sycl_queue = dpctl.get_current_queue()
sig = (npytypes_array_to_dpex_array(types.float32[:]),)

kernel_ir = get_kernel_ir(sycl_queue, foo, sig, debug=True)
kernel_ir = get_kernel_ir(foo, sig, debug=True)

for tag in ir_tags:
assert tag in kernel_ir
Expand All @@ -130,7 +124,6 @@ def func_sum(a, b):
result = a + b
return result

@dpex.kernel(debug=debug_option)
def data_parallel_sum(a, b, c):
i = dpex.get_global_id(0)
c[i] = func_sum(a[i], b[i])
Expand All @@ -140,16 +133,13 @@ def data_parallel_sum(a, b, c):
r'\!DISubprogram\(name: ".*data_parallel_sum"',
]

sycl_queue = dpctl.get_current_queue()
sig = (
npytypes_array_to_dpex_array(types.float32[:]),
npytypes_array_to_dpex_array(types.float32[:]),
npytypes_array_to_dpex_array(types.float32[:]),
)

kernel_ir = get_kernel_ir(
sycl_queue, data_parallel_sum, sig, debug=debug_option
)
kernel_ir = get_kernel_ir(data_parallel_sum, sig, debug=debug_option)

for tag in ir_tags:
assert debug_option == make_check(kernel_ir, tag)
Expand All @@ -165,7 +155,6 @@ def func_sum(a, b):
result = a + b
return result

@dpex.kernel
def data_parallel_sum(a, b, c):
i = dpex.get_global_id(0)
c[i] = func_sum(a[i], b[i])
Expand All @@ -175,22 +164,20 @@ def data_parallel_sum(a, b, c):
r'\!DISubprogram\(name: ".*data_parallel_sum"',
]

sycl_queue = dpctl.get_current_queue()
sig = (
npytypes_array_to_dpex_array(types.float32[:]),
npytypes_array_to_dpex_array(types.float32[:]),
npytypes_array_to_dpex_array(types.float32[:]),
)

with override_config("DEBUGINFO_DEFAULT", int(debug_option)):
kernel_ir = get_kernel_ir(sycl_queue, data_parallel_sum, sig)
kernel_ir = get_kernel_ir(data_parallel_sum, sig)

for tag in ir_tags:
assert debug_option == make_check(kernel_ir, tag)


def test_debuginfo_DISubprogram_linkageName():
@dpex.kernel
def func(a, b):
i = dpex.get_global_id(0)
b[i] = a[i]
Expand All @@ -199,20 +186,18 @@ def func(a, b):
r'\!DISubprogram\(.*linkageName: ".*e4func.*"',
]

sycl_queue = dpctl.get_current_queue()
sig = (
npytypes_array_to_dpex_array(types.float32[:]),
npytypes_array_to_dpex_array(types.float32[:]),
)

kernel_ir = get_kernel_ir(sycl_queue, func, sig, debug=True)
kernel_ir = get_kernel_ir(func, sig, debug=True)

for tag in ir_tags:
assert make_check(kernel_ir, tag)


def test_debuginfo_DICompileUnit_language_and_producer():
@dpex.kernel
def func(a, b):
i = dpex.get_global_id(0)
b[i] = a[i]
Expand All @@ -222,13 +207,12 @@ def func(a, b):
r'\!DICompileUnit\(.*producer: "numba-dpex"',
]

sycl_queue = dpctl.get_current_queue()
sig = (
npytypes_array_to_dpex_array(types.float32[:]),
npytypes_array_to_dpex_array(types.float32[:]),
)

kernel_ir = get_kernel_ir(sycl_queue, func, sig, debug=True)
kernel_ir = get_kernel_ir(func, sig, debug=True)

for tag in ir_tags:
assert make_check(kernel_ir, tag)

0 comments on commit 211d5d8

Please sign in to comment.